X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ian/git?p=subdirmk.git;a=blobdiff_plain;f=README;h=27dd8556a77c05ecd047b7aaa5aa23c3a7f2957e;hp=cfd7ad03d1853cc3b8e68b6847ee1df079d401ca;hb=411c2cad33613d6790cb819e8bd91a7f58a3998f;hpb=c0b216c79763f720df20e002fc14c9348a0e05c2 diff --git a/README b/README index cfd7ad0..27dd855 100644 --- a/README +++ b/README @@ -174,22 +174,22 @@ Path construction &-expansions are built from the following: Relative paths in... build source - This directory & &, - Top level . &; + This directory & &^ + Top level . &~ In more detail, with all the various options laid out: Recommended Relative paths in... Absolute paths in... for build source build source - This lc &file &,file $(PWD)/&file $(abs_src)/&file - directory any &/file &,/file $(PWD)&/file $(abs_src)/&/file - several & f g h &, f g h $(addprefix...) + This lc &file &^file $(PWD)/&file $(abs_src)/&file + directory any &/file &^/file $(PWD)&/file $(abs_src)/&/file + several & f g h &^ f g h $(addprefix...) - Top lc file &;file - level any file &;/file $(PWD)/file $(abs_src)/file + Top lc file &~file + level any file &~/file $(PWD)/file $(abs_src)/file .mk.in file $(src)/file $(PWD)/file $(abs_src)/file - several f g h &; f g h $(addprefix...) + several f g h &~ f g h $(addprefix...) (This assumes you have appropriate make variables src, PWD and abs_src.) @@ -224,28 +224,28 @@ empty string). &/ => sub/dir/ or nothing &=/ => sub/dir or . -&,lc => $(top_srcdir)/sub/dir/lc -&,/ => $(top_srcdir)/sub/dir/ +&^lc => $(top_srcdir)/sub/dir/lc +&^/ => $(top_srcdir)/sub/dir/ -&;lc => $(top_srcdir)/lc -&;/ => $(top_srcdir)/ +&~lc => $(top_srcdir)/lc +&~/ => $(top_srcdir)/ In general: - = return subdir without delimiter (not allowed with `,' `;') - , pathname of this subdirectory in source tree - ; pathname of top level of source tree + = return subdir without delimiter (not allowed with `^' `~') + ^ pathname of this subdirectory in source tree + ~ pathname of top level of source tree / terminates the escape (needed if next is not lwsp or space) lwsp starts multi-word processing (see below) So pathname syntax is a subset of: - '&' [ ',' | ';' ] [ lc | '/' ] + '&' [ '^' | '~' ] [ lc | '/' ] && => && for convenience in shell runes \& => & general escaping mechanism & thing thing... & -&, thing thing... & -&; thing thing... & +&^ thing thing... & +&~ thing thing... & Convenience syntax for prefixing multiple filenames. Introduced by & followed by lwsp where lc could go. Each lwsp-separated non-ws word is prefixed by &/ etc. @@ -371,6 +371,13 @@ makefiles, you may find that just `make' is broken now and cannot get far enough to regenerate a working set of makefiles. If this happens just rerun ./config.status by hand. +If you go back and forth between different versions of your code you +can sometimes find that `make' complains that one of your Subdir.sd.mk +files is missing: typically, if iot was used and therefore a +dependency in some other version of your code. If you run `make +clean' (or `make realclean') these dependencies are suppressed, which +will clear up the problem. + Legal information -----------------