archive.mk revision 1.9 1 1.9 rillig # $NetBSD: archive.mk,v 1.9 2020/10/08 18:37:26 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.7 rillig # archive handling. That's why it is more complicated and detailed than
8 1.7 rillig # strictly necessary.
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 MAKE_CMD= ${.MAKE} -f ${MAKEFILE}
14 1.1 rillig RUN?= @set -eu;
15 1.1 rillig
16 1.1 rillig all:
17 1.6 rillig .if ${.PARSEDIR:tA} != ${.CURDIR:tA}
18 1.8 rillig @cd ${MAKEFILE:H} && cp ${FILES} [at]*.mk ${.CURDIR}
19 1.6 rillig .endif
20 1.9 rillig # The following targets create and remove files. The filesystem cache in
21 1.9 rillig # dir.c would probably not handle this correctly, therefore each of the
22 1.9 rillig # targets is run in its separate sub-make.
23 1.2 rillig ${RUN} ${MAKE_CMD} remove-archive
24 1.1 rillig ${RUN} ${MAKE_CMD} create-archive
25 1.1 rillig ${RUN} ${MAKE_CMD} list-archive
26 1.4 rillig ${RUN} ${MAKE_CMD} list-archive-wildcard
27 1.1 rillig ${RUN} ${MAKE_CMD} depend-on-existing-member
28 1.1 rillig ${RUN} ${MAKE_CMD} depend-on-nonexistent-member
29 1.1 rillig ${RUN} ${MAKE_CMD} remove-archive
30 1.1 rillig
31 1.9 rillig create-archive: ${ARCHIVE} pre post
32 1.7 rillig
33 1.7 rillig # The indirect references with the $$ cover the code in Arch_ParseArchive
34 1.7 rillig # that calls Var_Parse. It's an esoteric scenario since at the point where
35 1.7 rillig # Arch_ParseArchive is called, the dependency line is already fully expanded.
36 1.7 rillig #
37 1.9 rillig ${ARCHIVE}: $${:Ulibprog.a}(archive.mk modmisc.mk $${:Uvarmisc.mk}) pre post
38 1.1 rillig ar cru ${.TARGET} ${.OODATE}
39 1.1 rillig ranlib ${.TARGET}
40 1.1 rillig
41 1.9 rillig list-archive: ${ARCHIVE} pre post
42 1.1 rillig ar t ${.ALLSRC}
43 1.1 rillig
44 1.4 rillig # XXX: I had expected that this dependency would select all *.mk files from
45 1.4 rillig # the archive. Instead, the globbing is done in the current directory.
46 1.5 rillig # To prevent an overly long file list, the pattern is restricted to [at]*.mk.
47 1.9 rillig list-archive-wildcard: ${ARCHIVE}([at]*.mk) pre post
48 1.4 rillig ${RUN} printf '%s\n' ${.ALLSRC:O:@member@${.TARGET:Q}': '${member:Q}@}
49 1.4 rillig
50 1.9 rillig depend-on-existing-member: ${ARCHIVE}(archive.mk) pre post
51 1.1 rillig ${RUN} echo $@
52 1.1 rillig
53 1.9 rillig depend-on-nonexistent-member: ${ARCHIVE}(nonexistent.mk) pre post
54 1.1 rillig ${RUN} echo $@
55 1.1 rillig
56 1.9 rillig remove-archive: pre post
57 1.3 rillig rm -f ${ARCHIVE}
58 1.9 rillig
59 1.9 rillig pre: .USEBEFORE
60 1.9 rillig @echo Making ${.TARGET} ${.OODATE:C,.+,out-of-date,W} ${.OODATE}
61 1.9 rillig post: .USE
62 1.9 rillig @echo
63