Home | History | Annotate | Line # | Download | only in unit-tests
archive.mk revision 1.11
      1  1.11  rillig # $NetBSD: archive.mk,v 1.11 2020/11/15 14:07:53 rillig Exp $
      2   1.1  rillig #
      3   1.1  rillig # Very basic demonstration of handling archives, based on the description
      4   1.1  rillig # in PSD.doc/tutorial.ms.
      5   1.7  rillig #
      6   1.7  rillig # This test aims at covering the code, not at being an introduction to
      7  1.11  rillig # archive handling. That's why it deviates from the tutorial style of
      8  1.11  rillig # several other tests.
      9   1.1  rillig 
     10   1.7  rillig ARCHIVE=	libprog.a
     11   1.7  rillig FILES=		archive.mk modmisc.mk varmisc.mk
     12   1.1  rillig 
     13   1.1  rillig all:
     14   1.6  rillig .if ${.PARSEDIR:tA} != ${.CURDIR:tA}
     15   1.8  rillig 	@cd ${MAKEFILE:H} && cp ${FILES} [at]*.mk ${.CURDIR}
     16   1.6  rillig .endif
     17   1.9  rillig # The following targets create and remove files.  The filesystem cache in
     18   1.9  rillig # dir.c would probably not handle this correctly, therefore each of the
     19   1.9  rillig # targets is run in its separate sub-make.
     20  1.11  rillig 	@${MAKE} -f ${MAKEFILE} remove-archive
     21  1.11  rillig 	@${MAKE} -f ${MAKEFILE} create-archive
     22  1.11  rillig 	@${MAKE} -f ${MAKEFILE} list-archive
     23  1.11  rillig 	@${MAKE} -f ${MAKEFILE} list-archive-wildcard
     24  1.11  rillig 	@${MAKE} -f ${MAKEFILE} depend-on-existing-member
     25  1.11  rillig 	@${MAKE} -f ${MAKEFILE} depend-on-nonexistent-member
     26  1.11  rillig 	@${MAKE} -f ${MAKEFILE} remove-archive
     27   1.1  rillig 
     28   1.9  rillig create-archive: ${ARCHIVE} pre post
     29   1.7  rillig 
     30   1.7  rillig # The indirect references with the $$ cover the code in Arch_ParseArchive
     31   1.7  rillig # that calls Var_Parse.  It's an esoteric scenario since at the point where
     32   1.7  rillig # Arch_ParseArchive is called, the dependency line is already fully expanded.
     33   1.7  rillig #
     34   1.9  rillig ${ARCHIVE}: $${:Ulibprog.a}(archive.mk modmisc.mk $${:Uvarmisc.mk}) pre post
     35  1.10  rillig 	ar cru ${.TARGET} ${.OODATE:O}
     36   1.1  rillig 	ranlib ${.TARGET}
     37   1.1  rillig 
     38   1.9  rillig list-archive: ${ARCHIVE} pre post
     39   1.1  rillig 	ar t ${.ALLSRC}
     40   1.1  rillig 
     41   1.4  rillig # XXX: I had expected that this dependency would select all *.mk files from
     42   1.4  rillig # the archive.  Instead, the globbing is done in the current directory.
     43  1.11  rillig #
     44   1.5  rillig # To prevent an overly long file list, the pattern is restricted to [at]*.mk.
     45   1.9  rillig list-archive-wildcard: ${ARCHIVE}([at]*.mk) pre post
     46  1.11  rillig 	@printf '%s\n' ${.ALLSRC:O:@member@${.TARGET:Q}': '${member:Q}@}
     47   1.4  rillig 
     48   1.9  rillig depend-on-existing-member: ${ARCHIVE}(archive.mk) pre post
     49  1.11  rillig 	@echo $@
     50   1.1  rillig 
     51   1.9  rillig depend-on-nonexistent-member: ${ARCHIVE}(nonexistent.mk) pre post
     52  1.11  rillig 	@echo $@
     53   1.1  rillig 
     54   1.9  rillig remove-archive: pre post
     55   1.3  rillig 	rm -f ${ARCHIVE}
     56   1.9  rillig 
     57   1.9  rillig pre: .USEBEFORE
     58  1.10  rillig 	@echo Making ${.TARGET} ${.OODATE:C,.+,out-of-date,W} ${.OODATE:O}
     59   1.9  rillig post: .USE
     60   1.9  rillig 	@echo
     61