1*6a7405f5SSimon J. Gerraty.\" $NetBSD: make.1,v 1.381 2024/11/14 19:30:13 sjg Exp $ 23955d011SMarcel Moolenaar.\" 33955d011SMarcel Moolenaar.\" Copyright (c) 1990, 1993 43955d011SMarcel Moolenaar.\" The Regents of the University of California. All rights reserved. 53955d011SMarcel Moolenaar.\" 63955d011SMarcel Moolenaar.\" Redistribution and use in source and binary forms, with or without 73955d011SMarcel Moolenaar.\" modification, are permitted provided that the following conditions 83955d011SMarcel Moolenaar.\" are met: 93955d011SMarcel Moolenaar.\" 1. Redistributions of source code must retain the above copyright 103955d011SMarcel Moolenaar.\" notice, this list of conditions and the following disclaimer. 113955d011SMarcel Moolenaar.\" 2. Redistributions in binary form must reproduce the above copyright 123955d011SMarcel Moolenaar.\" notice, this list of conditions and the following disclaimer in the 133955d011SMarcel Moolenaar.\" documentation and/or other materials provided with the distribution. 143955d011SMarcel Moolenaar.\" 3. Neither the name of the University nor the names of its contributors 153955d011SMarcel Moolenaar.\" may be used to endorse or promote products derived from this software 163955d011SMarcel Moolenaar.\" without specific prior written permission. 173955d011SMarcel Moolenaar.\" 183955d011SMarcel Moolenaar.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 193955d011SMarcel Moolenaar.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 203955d011SMarcel Moolenaar.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 213955d011SMarcel Moolenaar.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 223955d011SMarcel Moolenaar.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 233955d011SMarcel Moolenaar.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 243955d011SMarcel Moolenaar.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 253955d011SMarcel Moolenaar.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 263955d011SMarcel Moolenaar.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 273955d011SMarcel Moolenaar.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 283955d011SMarcel Moolenaar.\" SUCH DAMAGE. 293955d011SMarcel Moolenaar.\" 303955d011SMarcel Moolenaar.\" from: @(#)make.1 8.4 (Berkeley) 3/19/94 313955d011SMarcel Moolenaar.\" 32*6a7405f5SSimon J. Gerraty.Dd November 14, 2024 333955d011SMarcel Moolenaar.Dt MAKE 1 343955d011SMarcel Moolenaar.Os 353955d011SMarcel Moolenaar.Sh NAME 363955d011SMarcel Moolenaar.Nm make 373955d011SMarcel Moolenaar.Nd maintain program dependencies 383955d011SMarcel Moolenaar.Sh SYNOPSIS 393955d011SMarcel Moolenaar.Nm 40e2eeea75SSimon J. Gerraty.Op Fl BeikNnqrSstWwX 413955d011SMarcel Moolenaar.Op Fl C Ar directory 423955d011SMarcel Moolenaar.Op Fl D Ar variable 433955d011SMarcel Moolenaar.Op Fl d Ar flags 443955d011SMarcel Moolenaar.Op Fl f Ar makefile 453955d011SMarcel Moolenaar.Op Fl I Ar directory 463955d011SMarcel Moolenaar.Op Fl J Ar private 473955d011SMarcel Moolenaar.Op Fl j Ar max_jobs 483955d011SMarcel Moolenaar.Op Fl m Ar directory 493955d011SMarcel Moolenaar.Op Fl T Ar file 503955d011SMarcel Moolenaar.Op Fl V Ar variable 518695518cSSimon J. Gerraty.Op Fl v Ar variable 524fde40d9SSimon J. Gerraty.Op Ar variable\| Ns Cm \&= Ns Ar value 534fde40d9SSimon J. Gerraty.Op Ar target No ... 543955d011SMarcel Moolenaar.Sh DESCRIPTION 553955d011SMarcel Moolenaar.Nm 563955d011SMarcel Moolenaaris a program designed to simplify the maintenance of other programs. 573955d011SMarcel MoolenaarIts input is a list of specifications as to the files upon which programs 583955d011SMarcel Moolenaarand other files depend. 593955d011SMarcel MoolenaarIf no 603955d011SMarcel Moolenaar.Fl f Ar makefile 614fde40d9SSimon J. Gerratyoption is given, 623955d011SMarcel Moolenaar.Nm 63*6a7405f5SSimon J. Gerratylooks for the makefiles listed in 64*6a7405f5SSimon J. Gerraty.Va .MAKE.MAKEFILE_PREFERENCE 65*6a7405f5SSimon J. Gerraty(default 66*6a7405f5SSimon J. Gerraty.Sq Pa makefile , 67*6a7405f5SSimon J. Gerraty.Sq Pa Makefile ) 683955d011SMarcel Moolenaarin order to find the specifications. 693955d011SMarcel MoolenaarIf the file 70954401e6SSimon J. Gerraty.Sq Pa .depend 714fde40d9SSimon J. Gerratyexists, it is read, see 724fde40d9SSimon J. Gerraty.Xr mkdep 1 . 733955d011SMarcel Moolenaar.Pp 743955d011SMarcel MoolenaarThis manual page is intended as a reference document only. 753955d011SMarcel MoolenaarFor a more thorough description of 763955d011SMarcel Moolenaar.Nm 773955d011SMarcel Moolenaarand makefiles, please refer to 784fde40d9SSimon J. Gerraty.%T "PMake \- A Tutorial" 794fde40d9SSimon J. Gerraty(from 1993). 803955d011SMarcel Moolenaar.Pp 813955d011SMarcel Moolenaar.Nm 824fde40d9SSimon J. Gerratyprepends the contents of the 834fde40d9SSimon J. Gerraty.Ev MAKEFLAGS 843955d011SMarcel Moolenaarenvironment variable to the command line arguments before parsing them. 853955d011SMarcel Moolenaar.Pp 863955d011SMarcel MoolenaarThe options are as follows: 873955d011SMarcel Moolenaar.Bl -tag -width Ds 883955d011SMarcel Moolenaar.It Fl B 893955d011SMarcel MoolenaarTry to be backwards compatible by executing a single shell per command and 904fde40d9SSimon J. Gerratyby making the sources of a dependency line in sequence. 913955d011SMarcel Moolenaar.It Fl C Ar directory 923955d011SMarcel MoolenaarChange to 933955d011SMarcel Moolenaar.Ar directory 943955d011SMarcel Moolenaarbefore reading the makefiles or doing anything else. 953955d011SMarcel MoolenaarIf multiple 963955d011SMarcel Moolenaar.Fl C 973955d011SMarcel Moolenaaroptions are specified, each is interpreted relative to the previous one: 983955d011SMarcel Moolenaar.Fl C Pa / Fl C Pa etc 993955d011SMarcel Moolenaaris equivalent to 1003955d011SMarcel Moolenaar.Fl C Pa /etc . 1013955d011SMarcel Moolenaar.It Fl D Ar variable 1023955d011SMarcel MoolenaarDefine 1033955d011SMarcel Moolenaar.Ar variable 104dba7b0efSSimon J. Gerratyto be 1, in the global scope. 1054fde40d9SSimon J. Gerraty.It Fl d Oo Cm \- Oc Ns Ar flags 1063955d011SMarcel MoolenaarTurn on debugging, and specify which portions of 1073955d011SMarcel Moolenaar.Nm 1083955d011SMarcel Moolenaarare to print debugging information. 1093955d011SMarcel MoolenaarUnless the flags are preceded by 1104fde40d9SSimon J. Gerraty.Ql \- , 1113955d011SMarcel Moolenaarthey are added to the 1124fde40d9SSimon J. Gerraty.Ev MAKEFLAGS 1134fde40d9SSimon J. Gerratyenvironment variable and are passed on to any child make processes. 1143955d011SMarcel MoolenaarBy default, debugging information is printed to standard error, 1153955d011SMarcel Moolenaarbut this can be changed using the 1164fde40d9SSimon J. Gerraty.Cm F 1173955d011SMarcel Moolenaardebugging flag. 1183955d011SMarcel MoolenaarThe debugging output is always unbuffered; in addition, if debugging 1193955d011SMarcel Moolenaaris enabled but debugging output is not directed to standard output, 1204fde40d9SSimon J. Gerratythe standard output is line buffered. 1214fde40d9SSimon J. GerratyThe available 1224fde40d9SSimon J. Gerraty.Ar flags 1234fde40d9SSimon J. Gerratyare: 1243955d011SMarcel Moolenaar.Bl -tag -width Ds 1254fde40d9SSimon J. Gerraty.It Cm A 1263955d011SMarcel MoolenaarPrint all possible debugging information; 1273955d011SMarcel Moolenaarequivalent to specifying all of the debugging flags. 1284fde40d9SSimon J. Gerraty.It Cm a 1293955d011SMarcel MoolenaarPrint debugging information about archive searching and caching. 1304fde40d9SSimon J. Gerraty.It Cm C 1314fde40d9SSimon J. GerratyPrint debugging information about the current working directory. 1324fde40d9SSimon J. Gerraty.It Cm c 1333955d011SMarcel MoolenaarPrint debugging information about conditional evaluation. 1344fde40d9SSimon J. Gerraty.It Cm d 1353955d011SMarcel MoolenaarPrint debugging information about directory searching and caching. 1364fde40d9SSimon J. Gerraty.It Cm e 1373955d011SMarcel MoolenaarPrint debugging information about failed commands and targets. 1384fde40d9SSimon J. Gerraty.It Cm F Ns Oo Cm \&+ Oc Ns Ar filename 1393955d011SMarcel MoolenaarSpecify where debugging output is written. 1403955d011SMarcel MoolenaarThis must be the last flag, because it consumes the remainder of 1413955d011SMarcel Moolenaarthe argument. 1423955d011SMarcel MoolenaarIf the character immediately after the 1434fde40d9SSimon J. Gerraty.Cm F 1443955d011SMarcel Moolenaarflag is 1453955d011SMarcel Moolenaar.Ql \&+ , 1464fde40d9SSimon J. Gerratythe file is opened in append mode; 1474fde40d9SSimon J. Gerratyotherwise the file is overwritten. 1483955d011SMarcel MoolenaarIf the file name is 1493955d011SMarcel Moolenaar.Ql stdout 1503955d011SMarcel Moolenaaror 1514fde40d9SSimon J. Gerraty.Ql stderr , 1524fde40d9SSimon J. Gerratydebugging output is written to the standard output or standard error output 1534fde40d9SSimon J. Gerratyrespectively (and the 1543955d011SMarcel Moolenaar.Ql \&+ 1553955d011SMarcel Moolenaaroption has no effect). 1564fde40d9SSimon J. GerratyOtherwise, the output is written to the named file. 1574fde40d9SSimon J. GerratyIf the file name ends with 1584fde40d9SSimon J. Gerraty.Ql .%d , 1594fde40d9SSimon J. Gerratythe 1603955d011SMarcel Moolenaar.Ql %d 1613955d011SMarcel Moolenaaris replaced by the pid. 1624fde40d9SSimon J. Gerraty.It Cm f 1633955d011SMarcel MoolenaarPrint debugging information about loop evaluation. 1644fde40d9SSimon J. Gerraty.It Cm g1 1653955d011SMarcel MoolenaarPrint the input graph before making anything. 1664fde40d9SSimon J. Gerraty.It Cm g2 1673955d011SMarcel MoolenaarPrint the input graph after making everything, or before exiting 1683955d011SMarcel Moolenaaron error. 1694fde40d9SSimon J. Gerraty.It Cm g3 1703955d011SMarcel MoolenaarPrint the input graph before exiting on error. 1714fde40d9SSimon J. Gerraty.It Cm h 1722c3632d1SSimon J. GerratyPrint debugging information about hash table operations. 1734fde40d9SSimon J. Gerraty.It Cm j 1743955d011SMarcel MoolenaarPrint debugging information about running multiple shells. 1754fde40d9SSimon J. Gerraty.It Cm L 1762c3632d1SSimon J. GerratyTurn on lint checks. 1774fde40d9SSimon J. GerratyThis throws errors for variable assignments that do not parse correctly, 1784fde40d9SSimon J. Gerratyat the time of assignment, so the file and line number are available. 1794fde40d9SSimon J. Gerraty.It Cm l 1803955d011SMarcel MoolenaarPrint commands in Makefiles regardless of whether or not they are prefixed by 1813955d011SMarcel Moolenaar.Ql @ 1824fde40d9SSimon J. Gerratyor other 1834fde40d9SSimon J. Gerraty.Dq quiet 1844fde40d9SSimon J. Gerratyflags. 1854fde40d9SSimon J. GerratyAlso known as 1864fde40d9SSimon J. Gerraty.Dq loud 1874fde40d9SSimon J. Gerratybehavior. 1884fde40d9SSimon J. Gerraty.It Cm M 1894fde40d9SSimon J. GerratyPrint debugging information about 1904fde40d9SSimon J. Gerraty.Dq meta 1914fde40d9SSimon J. Gerratymode decisions about targets. 1924fde40d9SSimon J. Gerraty.It Cm m 1933955d011SMarcel MoolenaarPrint debugging information about making targets, including modification 1943955d011SMarcel Moolenaardates. 1954fde40d9SSimon J. Gerraty.It Cm n 1963955d011SMarcel MoolenaarDon't delete the temporary command scripts created when running commands. 1973955d011SMarcel MoolenaarThese temporary scripts are created in the directory 1983955d011SMarcel Moolenaarreferred to by the 1993955d011SMarcel Moolenaar.Ev TMPDIR 2003955d011SMarcel Moolenaarenvironment variable, or in 2013955d011SMarcel Moolenaar.Pa /tmp 2023955d011SMarcel Moolenaarif 2033955d011SMarcel Moolenaar.Ev TMPDIR 2043955d011SMarcel Moolenaaris unset or set to the empty string. 2053955d011SMarcel MoolenaarThe temporary scripts are created by 2063955d011SMarcel Moolenaar.Xr mkstemp 3 , 2073955d011SMarcel Moolenaarand have names of the form 2083955d011SMarcel Moolenaar.Pa makeXXXXXX . 2093955d011SMarcel Moolenaar.Em NOTE : 2103955d011SMarcel MoolenaarThis can create many files in 2113955d011SMarcel Moolenaar.Ev TMPDIR 2123955d011SMarcel Moolenaaror 2133955d011SMarcel Moolenaar.Pa /tmp , 2143955d011SMarcel Moolenaarso use with care. 2154fde40d9SSimon J. Gerraty.It Cm p 2163955d011SMarcel MoolenaarPrint debugging information about makefile parsing. 2174fde40d9SSimon J. Gerraty.It Cm s 2183955d011SMarcel MoolenaarPrint debugging information about suffix-transformation rules. 2194fde40d9SSimon J. Gerraty.It Cm t 2203955d011SMarcel MoolenaarPrint debugging information about target list maintenance. 2214fde40d9SSimon J. Gerraty.It Cm V 2223955d011SMarcel MoolenaarForce the 2233955d011SMarcel Moolenaar.Fl V 2244fde40d9SSimon J. Gerratyoption to print raw values of variables, 2254fde40d9SSimon J. Gerratyoverriding the default behavior set via 2268695518cSSimon J. Gerraty.Va .MAKE.EXPAND_VARIABLES . 2274fde40d9SSimon J. Gerraty.It Cm v 2284fde40d9SSimon J. GerratyPrint debugging information about variable assignment and expansion. 2294fde40d9SSimon J. Gerraty.It Cm x 2303955d011SMarcel MoolenaarRun shell commands with 2313955d011SMarcel Moolenaar.Fl x 2323955d011SMarcel Moolenaarso the actual commands are printed as they are executed. 2333955d011SMarcel Moolenaar.El 2343955d011SMarcel Moolenaar.It Fl e 2354fde40d9SSimon J. GerratyLet environment variables override global variables within makefiles. 2363955d011SMarcel Moolenaar.It Fl f Ar makefile 237*6a7405f5SSimon J. GerratySpecify a makefile to read instead of one of the defaults listed in 238*6a7405f5SSimon J. Gerraty.Va .MAKE.MAKEFILE_PREFERENCE . 2393955d011SMarcel MoolenaarIf 2403955d011SMarcel Moolenaar.Ar makefile 2413955d011SMarcel Moolenaaris 2424fde40d9SSimon J. Gerraty.Ql \&- , 2433955d011SMarcel Moolenaarstandard input is read. 244*6a7405f5SSimon J. GerratyIf 245*6a7405f5SSimon J. Gerraty.Ar makefile 246*6a7405f5SSimon J. Gerratystarts with the string 247*6a7405f5SSimon J. Gerraty.Ql \&.../ , 248*6a7405f5SSimon J. Gerraty.Nm 249*6a7405f5SSimon J. Gerratysearches for the specified path in the rest of the argument 250*6a7405f5SSimon J. Gerratyin the current directory and its parents. 2513955d011SMarcel MoolenaarMultiple makefiles may be specified, and are read in the order specified. 2523955d011SMarcel Moolenaar.It Fl I Ar directory 2533955d011SMarcel MoolenaarSpecify a directory in which to search for makefiles and included makefiles. 2543955d011SMarcel MoolenaarThe system makefile directory (or directories, see the 2553955d011SMarcel Moolenaar.Fl m 2563955d011SMarcel Moolenaaroption) is automatically included as part of this list. 2573955d011SMarcel Moolenaar.It Fl i 2583955d011SMarcel MoolenaarIgnore non-zero exit of shell commands in the makefile. 2593955d011SMarcel MoolenaarEquivalent to specifying 2604fde40d9SSimon J. Gerraty.Ql \&- 2613955d011SMarcel Moolenaarbefore each command line in the makefile. 2623955d011SMarcel Moolenaar.It Fl J Ar private 2633955d011SMarcel MoolenaarThis option should 2643955d011SMarcel Moolenaar.Em not 2653955d011SMarcel Moolenaarbe specified by the user. 2663955d011SMarcel Moolenaar.Pp 2673955d011SMarcel MoolenaarWhen the 268954401e6SSimon J. Gerraty.Fl j 2693955d011SMarcel Moolenaaroption is in use in a recursive build, this option is passed by a make 2703955d011SMarcel Moolenaarto child makes to allow all the make processes in the build to 2713955d011SMarcel Moolenaarcooperate to avoid overloading the system. 2723955d011SMarcel Moolenaar.It Fl j Ar max_jobs 2733955d011SMarcel MoolenaarSpecify the maximum number of jobs that 2743955d011SMarcel Moolenaar.Nm 2753955d011SMarcel Moolenaarmay have running at any one time. 27698875883SSimon J. GerratyIf 27798875883SSimon J. Gerraty.Ar max_jobs 27898875883SSimon J. Gerratyis a floating point number, or ends with 27998875883SSimon J. Gerraty.Ql C , 28098875883SSimon J. Gerratythen the value is multiplied by the number of CPUs reported online by 28198875883SSimon J. Gerraty.Xr sysconf 3 . 2828c973ee2SSimon J. GerratyThe value of 2838c973ee2SSimon J. Gerraty.Ar max_jobs 2848c973ee2SSimon J. Gerratyis saved in 2853955d011SMarcel Moolenaar.Va .MAKE.JOBS . 2863955d011SMarcel MoolenaarTurns compatibility mode off, unless the 287954401e6SSimon J. Gerraty.Fl B 288954401e6SSimon J. Gerratyoption is also specified. 2893955d011SMarcel MoolenaarWhen compatibility mode is off, all commands associated with a 2903955d011SMarcel Moolenaartarget are executed in a single shell invocation as opposed to the 2913955d011SMarcel Moolenaartraditional one shell invocation per line. 2923955d011SMarcel MoolenaarThis can break traditional scripts which change directories on each 2933955d011SMarcel Moolenaarcommand invocation and then expect to start with a fresh environment 2943955d011SMarcel Moolenaaron the next line. 2953955d011SMarcel MoolenaarIt is more efficient to correct the scripts rather than turn backwards 2963955d011SMarcel Moolenaarcompatibility on. 2978c973ee2SSimon J. Gerraty.Pp 2988c973ee2SSimon J. GerratyA job token pool with 2998c973ee2SSimon J. Gerraty.Ar max_jobs 3008c973ee2SSimon J. Gerratytokens is used to control the total number of jobs running. 3018c973ee2SSimon J. GerratyEach instance of 3028c973ee2SSimon J. Gerraty.Nm 3038c973ee2SSimon J. Gerratywill wait for a token from the pool before running a new job. 3043955d011SMarcel Moolenaar.It Fl k 3053955d011SMarcel MoolenaarContinue processing after errors are encountered, but only on those targets 3063955d011SMarcel Moolenaarthat do not depend on the target whose creation caused the error. 3073955d011SMarcel Moolenaar.It Fl m Ar directory 3084fde40d9SSimon J. GerratySpecify a directory in which to search for 3094fde40d9SSimon J. Gerraty.Pa sys.mk 3104fde40d9SSimon J. Gerratyand makefiles included via the 31149caa483SSimon J. Gerraty.Li \&< Ns Ar file Ns Li \&> Ns -style 3123955d011SMarcel Moolenaarinclude statement. 3133955d011SMarcel MoolenaarThe 3143955d011SMarcel Moolenaar.Fl m 3153955d011SMarcel Moolenaaroption can be used multiple times to form a search path. 3164fde40d9SSimon J. GerratyThis path overrides the default system include path 3174fde40d9SSimon J. Gerraty.Pa /usr/share/mk . 3184fde40d9SSimon J. GerratyFurthermore, the system include path is appended to the search path used for 31949caa483SSimon J. Gerraty.Li \*q Ns Ar file Ns Li \*q Ns -style 3203955d011SMarcel Moolenaarinclude statements (see the 3213955d011SMarcel Moolenaar.Fl I 3223955d011SMarcel Moolenaaroption). 3234fde40d9SSimon J. GerratyThe system include path can be referenced via the read-only variable 3244fde40d9SSimon J. Gerraty.Va .SYSPATH . 3253955d011SMarcel Moolenaar.Pp 3264fde40d9SSimon J. GerratyIf a directory name in the 3273955d011SMarcel Moolenaar.Fl m 3283955d011SMarcel Moolenaarargument (or the 3293955d011SMarcel Moolenaar.Ev MAKESYSPATH 3303955d011SMarcel Moolenaarenvironment variable) starts with the string 3314fde40d9SSimon J. Gerraty.Ql \&.../ , 3323955d011SMarcel Moolenaar.Nm 3334fde40d9SSimon J. Gerratysearches for the specified file or directory named in the remaining part 3343955d011SMarcel Moolenaarof the argument string. 3354fde40d9SSimon J. GerratyThe search starts with the current directory 3364fde40d9SSimon J. Gerratyand then works upward towards the root of the file system. 3374fde40d9SSimon J. GerratyIf the search is successful, the resulting directory replaces the 3384fde40d9SSimon J. Gerraty.Ql \&.../ 3393955d011SMarcel Moolenaarspecification in the 3403955d011SMarcel Moolenaar.Fl m 3413955d011SMarcel Moolenaarargument. 3424fde40d9SSimon J. GerratyThis feature allows 3433955d011SMarcel Moolenaar.Nm 3444fde40d9SSimon J. Gerratyto easily search in the current source tree for customized 3454fde40d9SSimon J. Gerraty.Pa sys.mk 3464fde40d9SSimon J. Gerratyfiles (e.g., by using 3474fde40d9SSimon J. Gerraty.Ql \&.../mk/sys.mk 3483955d011SMarcel Moolenaaras an argument). 3493955d011SMarcel Moolenaar.It Fl n 3503955d011SMarcel MoolenaarDisplay the commands that would have been executed, but do not 3514fde40d9SSimon J. Gerratyactually execute them unless the target depends on the 3524fde40d9SSimon J. Gerraty.Va .MAKE 3534fde40d9SSimon J. Gerratyspecial source (see below) or the command is prefixed with 3544fde40d9SSimon J. Gerraty.Sq Cm + . 3553955d011SMarcel Moolenaar.It Fl N 3564fde40d9SSimon J. GerratyDisplay the commands that would have been executed, 3574fde40d9SSimon J. Gerratybut do not actually execute any of them; 3584fde40d9SSimon J. Gerratyuseful for debugging top-level makefiles 3593955d011SMarcel Moolenaarwithout descending into subdirectories. 3603955d011SMarcel Moolenaar.It Fl q 3614fde40d9SSimon J. GerratyDo not execute any commands, 3624fde40d9SSimon J. Gerratyinstead exit 0 if the specified targets are up to date, and 1 otherwise. 3633955d011SMarcel Moolenaar.It Fl r 3643955d011SMarcel MoolenaarDo not use the built-in rules specified in the system makefile. 365e2eeea75SSimon J. Gerraty.It Fl S 366e2eeea75SSimon J. GerratyStop processing if an error is encountered. 367e2eeea75SSimon J. GerratyThis is the default behavior and the opposite of 368e2eeea75SSimon J. Gerraty.Fl k . 3693955d011SMarcel Moolenaar.It Fl s 3703955d011SMarcel MoolenaarDo not echo any commands as they are executed. 3713955d011SMarcel MoolenaarEquivalent to specifying 372954401e6SSimon J. Gerraty.Sq Ic @ 3733955d011SMarcel Moolenaarbefore each command line in the makefile. 3743955d011SMarcel Moolenaar.It Fl T Ar tracefile 3753955d011SMarcel MoolenaarWhen used with the 3763955d011SMarcel Moolenaar.Fl j 3773955d011SMarcel Moolenaarflag, 3783955d011SMarcel Moolenaarappend a trace record to 3793955d011SMarcel Moolenaar.Ar tracefile 3803955d011SMarcel Moolenaarfor each job started and completed. 3813955d011SMarcel Moolenaar.It Fl t 3823955d011SMarcel MoolenaarRather than re-building a target as specified in the makefile, create it 3833955d011SMarcel Moolenaaror update its modification time to make it appear up-to-date. 3843955d011SMarcel Moolenaar.It Fl V Ar variable 3858695518cSSimon J. GerratyPrint the value of 3868695518cSSimon J. Gerraty.Ar variable . 3873955d011SMarcel MoolenaarDo not build any targets. 3883955d011SMarcel MoolenaarMultiple instances of this option may be specified; 3894fde40d9SSimon J. Gerratythe variables are printed one per line, 3903955d011SMarcel Moolenaarwith a blank line for each null or undefined variable. 391dba7b0efSSimon J. GerratyThe value printed is extracted from the global scope after all 3928695518cSSimon J. Gerratymakefiles have been read. 3934fde40d9SSimon J. Gerraty.Pp 3948695518cSSimon J. GerratyBy default, the raw variable contents (which may 3958695518cSSimon J. Gerratyinclude additional unexpanded variable references) are shown. 3963955d011SMarcel MoolenaarIf 3973955d011SMarcel Moolenaar.Ar variable 3983955d011SMarcel Moolenaarcontains a 3994fde40d9SSimon J. Gerraty.Ql \&$ , 4004fde40d9SSimon J. Gerratyit is not interpreted as a variable name but rather as an expression. 4014fde40d9SSimon J. GerratyIts value is expanded before printing. 4024fde40d9SSimon J. GerratyThe value is also expanded before printing if 4038695518cSSimon J. Gerraty.Va .MAKE.EXPAND_VARIABLES 4044fde40d9SSimon J. Gerratyis set to true and the 4058695518cSSimon J. Gerraty.Fl dV 4068695518cSSimon J. Gerratyoption has not been used to override it. 4074fde40d9SSimon J. Gerraty.Pp 4088695518cSSimon J. GerratyNote that loop-local and target-local variables, as well as values 4098695518cSSimon J. Gerratytaken temporarily by global variables during makefile processing, are 4108695518cSSimon J. Gerratynot accessible via this option. 4118695518cSSimon J. GerratyThe 4128695518cSSimon J. Gerraty.Fl dv 4138695518cSSimon J. Gerratydebug mode can be used to see these at the cost of generating 4148695518cSSimon J. Gerratysubstantial extraneous output. 4158695518cSSimon J. Gerraty.It Fl v Ar variable 4168695518cSSimon J. GerratyLike 4174fde40d9SSimon J. Gerraty.Fl V , 4184fde40d9SSimon J. Gerratybut all printed variables are always expanded to their complete value. 4194fde40d9SSimon J. GerratyThe last occurrence of 4208695518cSSimon J. Gerraty.Fl V 4214fde40d9SSimon J. Gerratyor 4224fde40d9SSimon J. Gerraty.Fl v 4234fde40d9SSimon J. Gerratydecides whether all variables are expanded or not. 4243955d011SMarcel Moolenaar.It Fl W 4253955d011SMarcel MoolenaarTreat any warnings during makefile parsing as errors. 426db29cad8SSimon J. Gerraty.It Fl w 427db29cad8SSimon J. GerratyPrint entering and leaving directory messages, pre and post processing. 4283955d011SMarcel Moolenaar.It Fl X 4293955d011SMarcel MoolenaarDon't export variables passed on the command line to the environment 4303955d011SMarcel Moolenaarindividually. 4314fde40d9SSimon J. GerratyVariables passed on the command line are still exported via the 4324fde40d9SSimon J. Gerraty.Ev MAKEFLAGS 4333955d011SMarcel Moolenaarenvironment variable. 4343955d011SMarcel MoolenaarThis option may be useful on systems which have a small limit on the 4353955d011SMarcel Moolenaarsize of command arguments. 4364fde40d9SSimon J. Gerraty.It Ar variable\| Ns Cm \&= Ns Ar value 4373955d011SMarcel MoolenaarSet the value of the variable 4383955d011SMarcel Moolenaar.Ar variable 4393955d011SMarcel Moolenaarto 4403955d011SMarcel Moolenaar.Ar value . 4413955d011SMarcel MoolenaarNormally, all values passed on the command line are also exported to 4423955d011SMarcel Moolenaarsub-makes in the environment. 4433955d011SMarcel MoolenaarThe 4443955d011SMarcel Moolenaar.Fl X 4453955d011SMarcel Moolenaarflag disables this behavior. 4463955d011SMarcel MoolenaarVariable assignments should follow options for POSIX compatibility 4473955d011SMarcel Moolenaarbut no ordering is enforced. 4483955d011SMarcel Moolenaar.El 4493955d011SMarcel Moolenaar.Pp 4504fde40d9SSimon J. GerratyThere are several different types of lines in a makefile: dependency 4513955d011SMarcel Moolenaarspecifications, shell commands, variable assignments, include statements, 4524fde40d9SSimon J. Gerratyconditional directives, for loops, other directives, and comments. 4533955d011SMarcel Moolenaar.Pp 4544fde40d9SSimon J. GerratyLines may be continued from one line to the next 4554fde40d9SSimon J. Gerratyby ending them with a backslash 4563955d011SMarcel Moolenaar.Pq Ql \e . 4573955d011SMarcel MoolenaarThe trailing newline character and initial whitespace on the following 4583955d011SMarcel Moolenaarline are compressed into a single space. 4593955d011SMarcel Moolenaar.Sh FILE DEPENDENCY SPECIFICATIONS 4603955d011SMarcel MoolenaarDependency lines consist of one or more targets, an operator, and zero 4613955d011SMarcel Moolenaaror more sources. 4623955d011SMarcel MoolenaarThis creates a relationship where the targets 4633955d011SMarcel Moolenaar.Dq depend 4644fde40d9SSimon J. Gerratyon the sources and are customarily created from them. 4654fde40d9SSimon J. GerratyA target is considered out of date if it does not exist, 4664fde40d9SSimon J. Gerratyor if its modification time is less than that of any of its sources. 4674fde40d9SSimon J. GerratyAn out-of-date target is re-created, but not until all sources 4682c3632d1SSimon J. Gerratyhave been examined and themselves re-created as needed. 4692c3632d1SSimon J. GerratyThree operators may be used: 4703955d011SMarcel Moolenaar.Bl -tag -width flag 4713955d011SMarcel Moolenaar.It Ic \&: 4722c3632d1SSimon J. GerratyMany dependency lines may name this target but only one may have 4732c3632d1SSimon J. Gerratyattached shell commands. 4742c3632d1SSimon J. GerratyAll sources named in all dependency lines are considered together, 4752c3632d1SSimon J. Gerratyand if needed the attached shell commands are run to create or 4762c3632d1SSimon J. Gerratyre-create the target. 4772c3632d1SSimon J. GerratyIf 4783955d011SMarcel Moolenaar.Nm 4792c3632d1SSimon J. Gerratyis interrupted, the target is removed. 4803955d011SMarcel Moolenaar.It Ic \&! 4812c3632d1SSimon J. GerratyThe same, but the target is always re-created whether or not it is out 4822c3632d1SSimon J. Gerratyof date. 4833955d011SMarcel Moolenaar.It Ic \&:: 4842c3632d1SSimon J. GerratyAny dependency line may have attached shell commands, but each one 4852c3632d1SSimon J. Gerratyis handled independently: its sources are considered and the attached 4862c3632d1SSimon J. Gerratyshell commands are run if the target is out of date with respect to 4872c3632d1SSimon J. Gerraty(only) those sources. 4882c3632d1SSimon J. GerratyThus, different groups of the attached shell commands may be run 4892c3632d1SSimon J. Gerratydepending on the circumstances. 4902c3632d1SSimon J. GerratyFurthermore, unlike 4912c3632d1SSimon J. Gerraty.Ic \&: , 4922c3632d1SSimon J. Gerratyfor dependency lines with no sources, the attached shell 4932c3632d1SSimon J. Gerratycommands are always run. 4942c3632d1SSimon J. GerratyAlso unlike 4952c3632d1SSimon J. Gerraty.Ic \&: , 4964fde40d9SSimon J. Gerratythe target is not removed if 4973955d011SMarcel Moolenaar.Nm 4983955d011SMarcel Moolenaaris interrupted. 4993955d011SMarcel Moolenaar.El 5004fde40d9SSimon J. Gerraty.Pp 5012c3632d1SSimon J. GerratyAll dependency lines mentioning a particular target must use the same 5022c3632d1SSimon J. Gerratyoperator. 5033955d011SMarcel Moolenaar.Pp 5043955d011SMarcel MoolenaarTargets and sources may contain the shell wildcard values 5053955d011SMarcel Moolenaar.Ql \&? , 5063955d011SMarcel Moolenaar.Ql * , 5073955d011SMarcel Moolenaar.Ql [] , 5083955d011SMarcel Moolenaarand 5093955d011SMarcel Moolenaar.Ql {} . 5103955d011SMarcel MoolenaarThe values 5113955d011SMarcel Moolenaar.Ql \&? , 5123955d011SMarcel Moolenaar.Ql * , 5133955d011SMarcel Moolenaarand 5143955d011SMarcel Moolenaar.Ql [] 5154fde40d9SSimon J. Gerratymay only be used as part of the final component of the target or source, 5164fde40d9SSimon J. Gerratyand only match existing files. 5173955d011SMarcel MoolenaarThe value 5183955d011SMarcel Moolenaar.Ql {} 5193955d011SMarcel Moolenaarneed not necessarily be used to describe existing files. 5203955d011SMarcel MoolenaarExpansion is in directory order, not alphabetically as done in the shell. 5213955d011SMarcel Moolenaar.Sh SHELL COMMANDS 5224fde40d9SSimon J. GerratyEach target may have associated with it one or more lines of shell commands, 5234fde40d9SSimon J. Gerratynormally used to create the target. 524db29cad8SSimon J. GerratyEach of the lines in this script 5253955d011SMarcel Moolenaar.Em must 5263955d011SMarcel Moolenaarbe preceded by a tab. 527db29cad8SSimon J. Gerraty(For historical reasons, spaces are not accepted.) 5284fde40d9SSimon J. GerratyWhile targets can occur in many dependency lines if desired, 5294fde40d9SSimon J. Gerratyby default only one of these rules may be followed by a creation script. 530db29cad8SSimon J. GerratyIf the 531954401e6SSimon J. Gerraty.Sq Ic \&:: 5324fde40d9SSimon J. Gerratyoperator is used, however, all rules may include scripts, 5334fde40d9SSimon J. Gerratyand the respective scripts are executed in the order found. 5343955d011SMarcel Moolenaar.Pp 5354fde40d9SSimon J. GerratyEach line is treated as a separate shell command, 5364fde40d9SSimon J. Gerratyunless the end of line is escaped with a backslash 5374fde40d9SSimon J. Gerraty.Ql \e , 538db29cad8SSimon J. Gerratyin which case that line and the next are combined. 539db29cad8SSimon J. GerratyIf the first characters of the command are any combination of 540954401e6SSimon J. Gerraty.Sq Ic @ , 541954401e6SSimon J. Gerraty.Sq Ic + , 5423955d011SMarcel Moolenaaror 543954401e6SSimon J. Gerraty.Sq Ic \- , 5443955d011SMarcel Moolenaarthe command is treated specially. 5454fde40d9SSimon J. Gerraty.Bl -tag -offset indent -width indent 5464fde40d9SSimon J. Gerraty.It Ic @ 5473955d011SMarcel Moolenaarcauses the command not to be echoed before it is executed. 5484fde40d9SSimon J. Gerraty.It Ic + 5493955d011SMarcel Moolenaarcauses the command to be executed even when 5503955d011SMarcel Moolenaar.Fl n 5513955d011SMarcel Moolenaaris given. 5524fde40d9SSimon J. GerratyThis is similar to the effect of the 5534fde40d9SSimon J. Gerraty.Va .MAKE 5544fde40d9SSimon J. Gerratyspecial source, 5553955d011SMarcel Moolenaarexcept that the effect can be limited to a single line of a script. 5564fde40d9SSimon J. Gerraty.It Ic \- 557db29cad8SSimon J. Gerratyin compatibility mode 5583955d011SMarcel Moolenaarcauses any non-zero exit status of the command line to be ignored. 5594fde40d9SSimon J. Gerraty.El 5603cbdda60SSimon J. Gerraty.Pp 5613cbdda60SSimon J. GerratyWhen 5623cbdda60SSimon J. Gerraty.Nm 5633cbdda60SSimon J. Gerratyis run in jobs mode with 5643cbdda60SSimon J. Gerraty.Fl j Ar max_jobs , 5654fde40d9SSimon J. Gerratythe entire script for the target is fed to a single instance of the shell. 5663cbdda60SSimon J. GerratyIn compatibility (non-jobs) mode, each command is run in a separate process. 5673cbdda60SSimon J. GerratyIf the command contains any shell meta characters 5684fde40d9SSimon J. Gerraty.Pq Ql #=|^(){};&<>*?[]:$`\e\en , 5694fde40d9SSimon J. Gerratyit is passed to the shell; otherwise 5703cbdda60SSimon J. Gerraty.Nm 5714fde40d9SSimon J. Gerratyattempts direct execution. 572db29cad8SSimon J. GerratyIf a line starts with 573954401e6SSimon J. Gerraty.Sq Ic \- 5744fde40d9SSimon J. Gerratyand the shell has ErrCtl enabled, 5754fde40d9SSimon J. Gerratyfailure of the command line is ignored as in compatibility mode. 576db29cad8SSimon J. GerratyOtherwise 577954401e6SSimon J. Gerraty.Sq Ic \- 578db29cad8SSimon J. Gerratyaffects the entire job; 5794fde40d9SSimon J. Gerratythe script stops at the first command line that fails, 5804fde40d9SSimon J. Gerratybut the target is not deemed to have failed. 581db29cad8SSimon J. Gerraty.Pp 582db29cad8SSimon J. GerratyMakefiles should be written so that the mode of 583db29cad8SSimon J. Gerraty.Nm 584db29cad8SSimon J. Gerratyoperation does not change their behavior. 5854fde40d9SSimon J. GerratyFor example, any command which uses 586db29cad8SSimon J. Gerraty.Dq cd 587db29cad8SSimon J. Gerratyor 588db29cad8SSimon J. Gerraty.Dq chdir 5894fde40d9SSimon J. Gerratywithout the intention of changing the directory for subsequent commands 590db29cad8SSimon J. Gerratyshould be put in parentheses so it executes in a subshell. 5914fde40d9SSimon J. GerratyTo force the use of a single shell, escape the line breaks so as to make 592db29cad8SSimon J. Gerratythe whole script one command. 593db29cad8SSimon J. GerratyFor example: 594db29cad8SSimon J. Gerraty.Bd -literal -offset indent 595db29cad8SSimon J. Gerratyavoid-chdir-side-effects: 5964fde40d9SSimon J. Gerraty @echo "Building $@ in $$(pwd)" 597db29cad8SSimon J. Gerraty @(cd ${.CURDIR} && ${MAKE} $@) 5984fde40d9SSimon J. Gerraty @echo "Back in $$(pwd)" 599db29cad8SSimon J. Gerraty 600db29cad8SSimon J. Gerratyensure-one-shell-regardless-of-mode: 6014fde40d9SSimon J. Gerraty @echo "Building $@ in $$(pwd)"; \e 602db29cad8SSimon J. Gerraty (cd ${.CURDIR} && ${MAKE} $@); \e 6034fde40d9SSimon J. Gerraty echo "Back in $$(pwd)" 604db29cad8SSimon J. Gerraty.Ed 6053cbdda60SSimon J. Gerraty.Pp 6063cbdda60SSimon J. GerratySince 6073cbdda60SSimon J. Gerraty.Nm 6084fde40d9SSimon J. Gerratychanges the current working directory to 609954401e6SSimon J. Gerraty.Sq Va .OBJDIR 6104fde40d9SSimon J. Gerratybefore executing any targets, 6114fde40d9SSimon J. Gerratyeach child process starts with that as its current working directory. 6123955d011SMarcel Moolenaar.Sh VARIABLE ASSIGNMENTS 613954401e6SSimon J. GerratyVariables in make behave much like macros in the C preprocessor. 614954401e6SSimon J. Gerraty.Pp 615954401e6SSimon J. GerratyVariable assignments have the form 616954401e6SSimon J. Gerraty.Sq Ar NAME Ar op Ar value , 617954401e6SSimon J. Gerratywhere: 6184fde40d9SSimon J. Gerraty.Bl -tag -offset Ds -width Ds 619954401e6SSimon J. Gerraty.It Ar NAME 620954401e6SSimon J. Gerratyis a single-word variable name, 621954401e6SSimon J. Gerratyconsisting, by tradition, of all upper-case letters, 622954401e6SSimon J. Gerraty.It Ar op 6234fde40d9SSimon J. Gerratyis one of the variable assignment operators described below, and 624954401e6SSimon J. Gerraty.It Ar value 625954401e6SSimon J. Gerratyis interpreted according to the variable assignment operator. 626954401e6SSimon J. Gerraty.El 627954401e6SSimon J. Gerraty.Pp 628954401e6SSimon J. GerratyWhitespace around 629954401e6SSimon J. Gerraty.Ar NAME , 630954401e6SSimon J. Gerraty.Ar op 631954401e6SSimon J. Gerratyand 632954401e6SSimon J. Gerraty.Ar value 633954401e6SSimon J. Gerratyis discarded. 634954401e6SSimon J. Gerraty.Ss Variable assignment operators 6354fde40d9SSimon J. GerratyThe five operators that assign values to variables are: 6363955d011SMarcel Moolenaar.Bl -tag -width Ds 6373955d011SMarcel Moolenaar.It Ic \&= 6383955d011SMarcel MoolenaarAssign the value to the variable. 639954401e6SSimon J. GerratyAny previous value is overwritten. 6403955d011SMarcel Moolenaar.It Ic \&+= 641954401e6SSimon J. GerratyAppend the value to the current value of the variable, 642954401e6SSimon J. Gerratyseparating them by a single space. 6433955d011SMarcel Moolenaar.It Ic \&?= 6443955d011SMarcel MoolenaarAssign the value to the variable if it is not already defined. 6453955d011SMarcel Moolenaar.It Ic \&:= 6464fde40d9SSimon J. GerratyExpand the value, then assign it to the variable. 647954401e6SSimon J. Gerraty.Pp 6483955d011SMarcel Moolenaar.Em NOTE : 6493955d011SMarcel MoolenaarReferences to undefined variables are 6503955d011SMarcel Moolenaar.Em not 6513955d011SMarcel Moolenaarexpanded. 6523955d011SMarcel MoolenaarThis can cause problems when variable modifiers are used. 6534fde40d9SSimon J. Gerraty.\" See var-op-expand.mk, the section with LATER and INDIRECT. 6543955d011SMarcel Moolenaar.It Ic \&!= 6554fde40d9SSimon J. GerratyExpand the value and pass it to the shell for execution, 6564fde40d9SSimon J. Gerratythen assign the output from the child's standard output to the variable. 6573955d011SMarcel MoolenaarAny newlines in the result are replaced with spaces. 6583955d011SMarcel Moolenaar.El 659954401e6SSimon J. Gerraty.Ss Expansion of variables 6604fde40d9SSimon J. GerratyIn most contexts where variables are expanded, 661954401e6SSimon J. Gerraty.Ql \&$$ 662954401e6SSimon J. Gerratyexpands to a single dollar sign. 6634fde40d9SSimon J. GerratyIn other contexts (most variable modifiers, string literals in conditions), 6644fde40d9SSimon J. Gerraty.Ql \&\e$ 6654fde40d9SSimon J. Gerratyexpands to a single dollar sign. 6664fde40d9SSimon J. Gerraty.Pp 667954401e6SSimon J. GerratyReferences to variables have the form 6684fde40d9SSimon J. Gerraty.Cm \&${ Ns Ar name Ns Oo Ns Cm \&: Ns Ar modifiers Oc Ns Cm \&} 669954401e6SSimon J. Gerratyor 6704fde40d9SSimon J. Gerraty.Cm \&$( Ns Ar name Ns Oo Ns Cm \&: Ns Ar modifiers Oc Ns Cm \&) . 6714fde40d9SSimon J. GerratyIf the variable name consists of only a single character 6724fde40d9SSimon J. Gerratyand the expression contains no modifiers, 673954401e6SSimon J. Gerratythe surrounding curly braces or parentheses are not required. 6743955d011SMarcel MoolenaarThis shorter form is not recommended. 6753955d011SMarcel Moolenaar.Pp 6764fde40d9SSimon J. GerratyIf the variable name contains a dollar, the name itself is expanded first. 6773955d011SMarcel MoolenaarThis allows almost arbitrary variable names, however names containing dollar, 6784fde40d9SSimon J. Gerratybraces, parentheses or whitespace are really best avoided. 6793955d011SMarcel Moolenaar.Pp 6804fde40d9SSimon J. GerratyIf the result of expanding a nested variable expression contains a dollar sign 681954401e6SSimon J. Gerraty.Pq Ql \&$ , 6824fde40d9SSimon J. Gerratythe result is subject to further expansion. 6833955d011SMarcel Moolenaar.Pp 684954401e6SSimon J. GerratyVariable substitution occurs at four distinct times, depending on where 6853955d011SMarcel Moolenaarthe variable is being used. 6863955d011SMarcel Moolenaar.Bl -enum 6873955d011SMarcel Moolenaar.It 6883955d011SMarcel MoolenaarVariables in dependency lines are expanded as the line is read. 6893955d011SMarcel Moolenaar.It 690954401e6SSimon J. GerratyVariables in conditionals are expanded individually, 691954401e6SSimon J. Gerratybut only as far as necessary to determine the result of the conditional. 692954401e6SSimon J. Gerraty.It 6933955d011SMarcel MoolenaarVariables in shell commands are expanded when the shell command is 6943955d011SMarcel Moolenaarexecuted. 6953955d011SMarcel Moolenaar.It 6964fde40d9SSimon J. Gerraty.Ic .for 6973955d011SMarcel Moolenaarloop index variables are expanded on each loop iteration. 698954401e6SSimon J. GerratyNote that other variables are not expanded when composing the body of a loop, 699954401e6SSimon J. Gerratyso the following example code: 7003955d011SMarcel Moolenaar.Bd -literal -offset indent 7014fde40d9SSimon J. Gerraty\&.for i in 1 2 3 7023955d011SMarcel Moolenaara+= ${i} 7033955d011SMarcel Moolenaarj= ${i} 7043955d011SMarcel Moolenaarb+= ${j} 7054fde40d9SSimon J. Gerraty\&.endfor 7063955d011SMarcel Moolenaar 7073955d011SMarcel Moolenaarall: 7083955d011SMarcel Moolenaar @echo ${a} 7093955d011SMarcel Moolenaar @echo ${b} 7103955d011SMarcel Moolenaar.Ed 7114fde40d9SSimon J. Gerraty.Pp 7124fde40d9SSimon J. Gerratyprints: 7133955d011SMarcel Moolenaar.Bd -literal -offset indent 7143955d011SMarcel Moolenaar1 2 3 7153955d011SMarcel Moolenaar3 3 3 7163955d011SMarcel Moolenaar.Ed 7174fde40d9SSimon J. Gerraty.Pp 7184fde40d9SSimon J. GerratyAfter the loop is executed: 7194fde40d9SSimon J. Gerraty.Bl -tag -offset indent -width indent 7204fde40d9SSimon J. Gerraty.It Va a 7213955d011SMarcel Moolenaarcontains 7224fde40d9SSimon J. Gerraty.Ql ${:U1} ${:U2} ${:U3} , 7233955d011SMarcel Moolenaarwhich expands to 7244fde40d9SSimon J. Gerraty.Ql 1 2 3 . 7254fde40d9SSimon J. Gerraty.It Va j 7264fde40d9SSimon J. Gerratycontains 7274fde40d9SSimon J. Gerraty.Ql ${:U3} , 7284fde40d9SSimon J. Gerratywhich expands to 7294fde40d9SSimon J. Gerraty.Ql 3 . 7304fde40d9SSimon J. Gerraty.It Va b 7314fde40d9SSimon J. Gerratycontains 7324fde40d9SSimon J. Gerraty.Ql ${j} ${j} ${j} , 7334fde40d9SSimon J. Gerratywhich expands to 7344fde40d9SSimon J. Gerraty.Ql ${:U3} ${:U3} ${:U3} 7354fde40d9SSimon J. Gerratyand further to 7364fde40d9SSimon J. Gerraty.Ql 3 3 3 . 7374fde40d9SSimon J. Gerraty.El 7383955d011SMarcel Moolenaar.El 7393955d011SMarcel Moolenaar.Ss Variable classes 7403955d011SMarcel MoolenaarThe four different classes of variables (in order of increasing precedence) 7413955d011SMarcel Moolenaarare: 7423955d011SMarcel Moolenaar.Bl -tag -width Ds 7433955d011SMarcel Moolenaar.It Environment variables 7443955d011SMarcel MoolenaarVariables defined as part of 7453955d011SMarcel Moolenaar.Nm Ns 's 7463955d011SMarcel Moolenaarenvironment. 7473955d011SMarcel Moolenaar.It Global variables 7483955d011SMarcel MoolenaarVariables defined in the makefile or in included makefiles. 7493955d011SMarcel Moolenaar.It Command line variables 7503955d011SMarcel MoolenaarVariables defined as part of the command line. 7513955d011SMarcel Moolenaar.It Local variables 7523955d011SMarcel MoolenaarVariables that are defined specific to a certain target. 753db29cad8SSimon J. Gerraty.El 754db29cad8SSimon J. Gerraty.Pp 7554fde40d9SSimon J. GerratyLocal variables can be set on a dependency line, unless 7561d3f2ddcSSimon J. Gerraty.Va .MAKE.TARGET_LOCAL_VARIABLES 7574fde40d9SSimon J. Gerratyis set to 7589f45a3c8SSimon J. Gerraty.Ql false . 7599f45a3c8SSimon J. GerratyThe rest of the line 7604fde40d9SSimon J. Gerraty(which already has had global variables expanded) 7619f45a3c8SSimon J. Gerratyis the variable value. 7629f45a3c8SSimon J. GerratyFor example: 7639f45a3c8SSimon J. Gerraty.Bd -literal -offset indent 7641d3f2ddcSSimon J. GerratyCOMPILER_WRAPPERS= ccache distcc icecc 7659f45a3c8SSimon J. Gerraty 7669f45a3c8SSimon J. Gerraty${OBJS}: .MAKE.META.CMP_FILTER=${COMPILER_WRAPPERS:S,^,N,} 7679f45a3c8SSimon J. Gerraty.Ed 7689f45a3c8SSimon J. Gerraty.Pp 7699f45a3c8SSimon J. GerratyOnly the targets 7709f45a3c8SSimon J. Gerraty.Ql ${OBJS} 7714fde40d9SSimon J. Gerratyare impacted by that filter (in 7724fde40d9SSimon J. Gerraty.Dq meta 7734fde40d9SSimon J. Gerratymode) and 7744fde40d9SSimon J. Gerratysimply enabling/disabling any of the compiler wrappers does not render all 7759f45a3c8SSimon J. Gerratyof those targets out-of-date. 7769f45a3c8SSimon J. Gerraty.Pp 7779f45a3c8SSimon J. Gerraty.Em NOTE : 7781d3f2ddcSSimon J. Gerratytarget-local variable assignments behave differently in that; 7799f45a3c8SSimon J. Gerraty.Bl -tag -width Ds -offset indent 7809f45a3c8SSimon J. Gerraty.It Ic \&+= 7819f45a3c8SSimon J. GerratyOnly appends to a previous local assignment 7829f45a3c8SSimon J. Gerratyfor the same target and variable. 7839f45a3c8SSimon J. Gerraty.It Ic \&:= 7841d3f2ddcSSimon J. GerratyIs redundant with respect to global variables, 7859f45a3c8SSimon J. Gerratywhich have already been expanded. 7869f45a3c8SSimon J. Gerraty.El 7879f45a3c8SSimon J. Gerraty.Pp 7884fde40d9SSimon J. GerratyThe seven built-in local variables are: 7894fde40d9SSimon J. Gerraty.Bl -tag -width ".Va .ARCHIVE" -offset indent 7903955d011SMarcel Moolenaar.It Va .ALLSRC 7913955d011SMarcel MoolenaarThe list of all sources for this target; also known as 792954401e6SSimon J. Gerraty.Sq Va \&> . 7933955d011SMarcel Moolenaar.It Va .ARCHIVE 794db29cad8SSimon J. GerratyThe name of the archive file; also known as 795954401e6SSimon J. Gerraty.Sq Va \&! . 7963955d011SMarcel Moolenaar.It Va .IMPSRC 7973955d011SMarcel MoolenaarIn suffix-transformation rules, the name/path of the source from which the 7983955d011SMarcel Moolenaartarget is to be transformed (the 7993955d011SMarcel Moolenaar.Dq implied 8003955d011SMarcel Moolenaarsource); also known as 801954401e6SSimon J. Gerraty.Sq Va \&< . 8023955d011SMarcel MoolenaarIt is not defined in explicit rules. 8033955d011SMarcel Moolenaar.It Va .MEMBER 804db29cad8SSimon J. GerratyThe name of the archive member; also known as 805954401e6SSimon J. Gerraty.Sq Va % . 8063955d011SMarcel Moolenaar.It Va .OODATE 8073955d011SMarcel MoolenaarThe list of sources for this target that were deemed out-of-date; also 8083955d011SMarcel Moolenaarknown as 809954401e6SSimon J. Gerraty.Sq Va \&? . 8103955d011SMarcel Moolenaar.It Va .PREFIX 811c1d01b5fSSimon J. GerratyThe name of the target with suffix (if declared in 812c1d01b5fSSimon J. Gerraty.Ic .SUFFIXES ) 813c1d01b5fSSimon J. Gerratyremoved; also known as 814954401e6SSimon J. Gerraty.Sq Va * . 8153955d011SMarcel Moolenaar.It Va .TARGET 8163955d011SMarcel MoolenaarThe name of the target; also known as 817954401e6SSimon J. Gerraty.Sq Va @ . 8183bebe729SSimon J. GerratyFor compatibility with other makes this is an alias for 8194fde40d9SSimon J. Gerraty.Va .ARCHIVE 8203bebe729SSimon J. Gerratyin archive member rules. 8213955d011SMarcel Moolenaar.El 8223955d011SMarcel Moolenaar.Pp 8233955d011SMarcel MoolenaarThe shorter forms 8244fde40d9SSimon J. Gerraty.Po 8254fde40d9SSimon J. Gerraty.Sq Va \&> , 826954401e6SSimon J. Gerraty.Sq Va \&! , 8274fde40d9SSimon J. Gerraty.Sq Va \&< , 8284fde40d9SSimon J. Gerraty.Sq Va \&% , 829954401e6SSimon J. Gerraty.Sq Va \&? , 8304fde40d9SSimon J. Gerraty.Sq Va \&* , 8313955d011SMarcel Moolenaarand 8324fde40d9SSimon J. Gerraty.Sq Va \&@ 8334fde40d9SSimon J. Gerraty.Pc 8343955d011SMarcel Moolenaarare permitted for backward 835db29cad8SSimon J. Gerratycompatibility with historical makefiles and legacy POSIX make and are 836db29cad8SSimon J. Gerratynot recommended. 837db29cad8SSimon J. Gerraty.Pp 838db29cad8SSimon J. GerratyVariants of these variables with the punctuation followed immediately by 839db29cad8SSimon J. Gerraty.Ql D 840db29cad8SSimon J. Gerratyor 841db29cad8SSimon J. Gerraty.Ql F , 842954401e6SSimon J. Gerratye.g.\& 8434fde40d9SSimon J. Gerraty.Ql $(@D) , 844db29cad8SSimon J. Gerratyare legacy forms equivalent to using the 845db29cad8SSimon J. Gerraty.Ql :H 8463955d011SMarcel Moolenaarand 847db29cad8SSimon J. Gerraty.Ql :T 848db29cad8SSimon J. Gerratymodifiers. 849db29cad8SSimon J. GerratyThese forms are accepted for compatibility with 8503955d011SMarcel Moolenaar.At V 851db29cad8SSimon J. Gerratymakefiles and POSIX but are not recommended. 8523955d011SMarcel Moolenaar.Pp 8533955d011SMarcel MoolenaarFour of the local variables may be used in sources on dependency lines 8543955d011SMarcel Moolenaarbecause they expand to the proper value for each target on the line. 8553955d011SMarcel MoolenaarThese variables are 856954401e6SSimon J. Gerraty.Sq Va .TARGET , 857954401e6SSimon J. Gerraty.Sq Va .PREFIX , 858954401e6SSimon J. Gerraty.Sq Va .ARCHIVE , 8593955d011SMarcel Moolenaarand 860954401e6SSimon J. Gerraty.Sq Va .MEMBER . 8613955d011SMarcel Moolenaar.Ss Additional built-in variables 8623955d011SMarcel MoolenaarIn addition, 8633955d011SMarcel Moolenaar.Nm 8643955d011SMarcel Moolenaarsets or knows about the following variables: 8654fde40d9SSimon J. Gerraty.Bl -tag 8664fde40d9SSimon J. Gerraty.\" NB: This list is sorted case-insensitive, ignoring punctuation. 8674fde40d9SSimon J. Gerraty.\" NB: To find all built-in variables in make's source code, 8684fde40d9SSimon J. Gerraty.\" NB: search for Var_*, Global_*, SetVarObjdir, GetBooleanExpr, 8694fde40d9SSimon J. Gerraty.\" NB: and the implementation of Var_SetWithFlags. 8704fde40d9SSimon J. Gerraty.\" NB: Last synced on 2023-01-01. 8713955d011SMarcel Moolenaar.It Va .ALLTARGETS 8724fde40d9SSimon J. GerratyThe list of all targets encountered in the makefiles. 8734fde40d9SSimon J. GerratyIf evaluated during makefile parsing, 8744fde40d9SSimon J. Gerratylists only those targets encountered thus far. 8753955d011SMarcel Moolenaar.It Va .CURDIR 8763955d011SMarcel MoolenaarA path to the directory where 8773955d011SMarcel Moolenaar.Nm 8783955d011SMarcel Moolenaarwas executed. 8793955d011SMarcel MoolenaarRefer to the description of 8804fde40d9SSimon J. Gerraty.Sq Va PWD 8813955d011SMarcel Moolenaarfor more details. 8824fde40d9SSimon J. Gerraty.It Va .ERROR_CMD 8834fde40d9SSimon J. GerratyIs used in error handling, see 8844fde40d9SSimon J. Gerraty.Va MAKE_PRINT_VAR_ON_ERROR . 8854fde40d9SSimon J. Gerraty.It Va .ERROR_CWD 8864fde40d9SSimon J. GerratyIs used in error handling, see 8874fde40d9SSimon J. Gerraty.Va MAKE_PRINT_VAR_ON_ERROR . 888c59c3bf3SSimon J. Gerraty.It Va .ERROR_EXIT 889c59c3bf3SSimon J. GerratyIs used in error handling, see 890c59c3bf3SSimon J. Gerraty.Va MAKE_PRINT_VAR_ON_ERROR . 8914fde40d9SSimon J. Gerraty.It Va .ERROR_META_FILE 8924fde40d9SSimon J. GerratyIs used in error handling in 8934fde40d9SSimon J. Gerraty.Dq meta 8944fde40d9SSimon J. Gerratymode, see 8954fde40d9SSimon J. Gerraty.Va MAKE_PRINT_VAR_ON_ERROR . 8964fde40d9SSimon J. Gerraty.It Va .ERROR_TARGET 8974fde40d9SSimon J. GerratyIs used in error handling, see 8984fde40d9SSimon J. Gerraty.Va MAKE_PRINT_VAR_ON_ERROR . 8995bcb7424SSimon J. Gerraty.It Va .INCLUDEDFROMDIR 9004fde40d9SSimon J. GerratyThe directory of the file this makefile was included from. 9015bcb7424SSimon J. Gerraty.It Va .INCLUDEDFROMFILE 9024fde40d9SSimon J. GerratyThe filename of the file this makefile was included from. 9034fde40d9SSimon J. Gerraty.\" .INCLUDES is intentionally undocumented, as it is obsolete. 9044fde40d9SSimon J. Gerraty.\" .LIBS is intentionally undocumented, as it is obsolete. 9054fde40d9SSimon J. Gerraty.It Va MACHINE 9064fde40d9SSimon J. GerratyThe machine hardware name, see 9074fde40d9SSimon J. Gerraty.Xr uname 1 . 9084fde40d9SSimon J. Gerraty.It Va MACHINE_ARCH 9094fde40d9SSimon J. GerratyThe machine processor architecture name, see 9104fde40d9SSimon J. Gerraty.Xr uname 1 . 9114fde40d9SSimon J. Gerraty.It Va MAKE 9123955d011SMarcel MoolenaarThe name that 9133955d011SMarcel Moolenaar.Nm 9143955d011SMarcel Moolenaarwas executed with 9153955d011SMarcel Moolenaar.Pq Va argv[0] . 9164fde40d9SSimon J. Gerraty.It Va .MAKE 9174fde40d9SSimon J. GerratyThe same as 9184fde40d9SSimon J. Gerraty.Va MAKE , 9194fde40d9SSimon J. Gerratyfor compatibility. 9203955d011SMarcel MoolenaarThe preferred variable to use is the environment variable 9213955d011SMarcel Moolenaar.Ev MAKE 9224fde40d9SSimon J. Gerratybecause it is more compatible with other make variants 9233955d011SMarcel Moolenaarand cannot be confused with the special target with the same name. 9249a4bc556SSimon J. Gerraty.It Va .MAKE.ALWAYS_PASS_JOB_QUEUE 9259a4bc556SSimon J. GerratyTells 9269a4bc556SSimon J. Gerraty.Nm 9279a4bc556SSimon J. Gerratywhether to pass the descriptors of the job token queue 9289a4bc556SSimon J. Gerratyeven if the target is not tagged with 9299a4bc556SSimon J. Gerraty.Ic .MAKE 9309a4bc556SSimon J. GerratyThe default is 9319a4bc556SSimon J. Gerraty.Ql Pa yes 9329a4bc556SSimon J. Gerratyfor backwards compatability with 933a0774d09SSimon J. Gerraty.Fx 9.0 9349a4bc556SSimon J. Gerratyand earlier. 9354fde40d9SSimon J. Gerraty.\" '.MAKE.cmd_filtered' is intentionally undocumented, 9364fde40d9SSimon J. Gerraty.\" as it is an internal implementation detail. 9373955d011SMarcel Moolenaar.It Va .MAKE.DEPENDFILE 9383955d011SMarcel MoolenaarNames the makefile (default 939954401e6SSimon J. Gerraty.Sq Pa .depend ) 9403955d011SMarcel Moolenaarfrom which generated dependencies are read. 9414fde40d9SSimon J. Gerraty.It Va .MAKE.DIE_QUIETLY 9424fde40d9SSimon J. GerratyIf set to 9434fde40d9SSimon J. Gerraty.Ql true , 9444fde40d9SSimon J. Gerratydo not print error information at the end. 9453955d011SMarcel Moolenaar.It Va .MAKE.EXPAND_VARIABLES 9463955d011SMarcel MoolenaarA boolean that controls the default behavior of the 9473955d011SMarcel Moolenaar.Fl V 9483955d011SMarcel Moolenaaroption. 9498695518cSSimon J. GerratyIf true, variable values printed with 9508695518cSSimon J. Gerraty.Fl V 9518695518cSSimon J. Gerratyare fully expanded; if false, the raw variable contents (which may 9528695518cSSimon J. Gerratyinclude additional unexpanded variable references) are shown. 9533955d011SMarcel Moolenaar.It Va .MAKE.EXPORTED 9543955d011SMarcel MoolenaarThe list of variables exported by 9553955d011SMarcel Moolenaar.Nm . 9564fde40d9SSimon J. Gerraty.It Va MAKEFILE 9574fde40d9SSimon J. GerratyThe top-level makefile that is currently read, 9584fde40d9SSimon J. Gerratyas given in the command line. 9594fde40d9SSimon J. Gerraty.It Va .MAKEFLAGS 9603955d011SMarcel MoolenaarThe environment variable 961954401e6SSimon J. Gerraty.Sq Ev MAKEFLAGS 9623955d011SMarcel Moolenaarmay contain anything that 9633955d011SMarcel Moolenaarmay be specified on 9643955d011SMarcel Moolenaar.Nm Ns 's 9653955d011SMarcel Moolenaarcommand line. 9663955d011SMarcel MoolenaarAnything specified on 9673955d011SMarcel Moolenaar.Nm Ns 's 9683955d011SMarcel Moolenaarcommand line is appended to the 9694fde40d9SSimon J. Gerraty.Va .MAKEFLAGS 9704fde40d9SSimon J. Gerratyvariable, which is then added to the environment for all programs that 9713955d011SMarcel Moolenaar.Nm 9723955d011SMarcel Moolenaarexecutes. 9734fde40d9SSimon J. Gerraty.It Va .MAKE.GID 9744fde40d9SSimon J. GerratyThe numeric group ID of the user running 9754fde40d9SSimon J. Gerraty.Nm . 9764fde40d9SSimon J. GerratyIt is read-only. 9774fde40d9SSimon J. Gerraty.It Va .MAKE.JOB.PREFIX 9784fde40d9SSimon J. GerratyIf 9794fde40d9SSimon J. Gerraty.Nm 9804fde40d9SSimon J. Gerratyis run with 9814fde40d9SSimon J. Gerraty.Fl j , 9824fde40d9SSimon J. Gerratythe output for each target is prefixed with a token 9834fde40d9SSimon J. Gerraty.Dl --- Ar target Li --- 9844fde40d9SSimon J. Gerratythe first part of which can be controlled via 9854fde40d9SSimon J. Gerraty.Va .MAKE.JOB.PREFIX . 9864fde40d9SSimon J. GerratyIf 9874fde40d9SSimon J. Gerraty.Va .MAKE.JOB.PREFIX 9884fde40d9SSimon J. Gerratyis empty, no token is printed. 9894fde40d9SSimon J. GerratyFor example, setting 9904fde40d9SSimon J. Gerraty.Va .MAKE.JOB.PREFIX 9914fde40d9SSimon J. Gerratyto 9924fde40d9SSimon J. Gerraty.Ql ${.newline}---${.MAKE:T}[${.MAKE.PID}] 9934fde40d9SSimon J. Gerratywould produce tokens like 9944fde40d9SSimon J. Gerraty.Dl ---make[1234] Ar target Li --- 9954fde40d9SSimon J. Gerratymaking it easier to track the degree of parallelism being achieved. 9964fde40d9SSimon J. Gerraty.It Va .MAKE.JOBS 9974fde40d9SSimon J. GerratyThe argument to the 9984fde40d9SSimon J. Gerraty.Fl j 9994fde40d9SSimon J. Gerratyoption. 100098875883SSimon J. Gerraty.It Va .MAKE.JOBS.C 100198875883SSimon J. GerratyA read-only boolean that indicates whether the 100298875883SSimon J. Gerraty.Fl j 100398875883SSimon J. Gerratyoption supports use of 100498875883SSimon J. Gerraty.Ql C . 10053955d011SMarcel Moolenaar.It Va .MAKE.LEVEL 10063955d011SMarcel MoolenaarThe recursion depth of 10073955d011SMarcel Moolenaar.Nm . 10084fde40d9SSimon J. GerratyThe top-level instance of 10093955d011SMarcel Moolenaar.Nm 10104fde40d9SSimon J. Gerratyhas level 0, and each child make has its parent level plus 1. 10113955d011SMarcel MoolenaarThis allows tests like: 10123955d011SMarcel Moolenaar.Li .if ${.MAKE.LEVEL} == 0 10134fde40d9SSimon J. Gerratyto protect things which should only be evaluated in the top-level instance of 10144fde40d9SSimon J. Gerraty.Nm . 10154fde40d9SSimon J. Gerraty.It Va .MAKE.LEVEL.ENV 10164fde40d9SSimon J. GerratyThe name of the environment variable that stores the level of nested calls to 10173955d011SMarcel Moolenaar.Nm . 10183955d011SMarcel Moolenaar.It Va .MAKE.MAKEFILE_PREFERENCE 10193955d011SMarcel MoolenaarThe ordered list of makefile names 10203955d011SMarcel Moolenaar(default 1021954401e6SSimon J. Gerraty.Sq Pa makefile , 1022954401e6SSimon J. Gerraty.Sq Pa Makefile ) 10233955d011SMarcel Moolenaarthat 10243955d011SMarcel Moolenaar.Nm 10254fde40d9SSimon J. Gerratylooks for. 10263955d011SMarcel Moolenaar.It Va .MAKE.MAKEFILES 10273955d011SMarcel MoolenaarThe list of makefiles read by 10283955d011SMarcel Moolenaar.Nm , 10293955d011SMarcel Moolenaarwhich is useful for tracking dependencies. 10303955d011SMarcel MoolenaarEach makefile is recorded only once, regardless of the number of times read. 10313955d011SMarcel Moolenaar.It Va .MAKE.META.BAILIWICK 10324fde40d9SSimon J. GerratyIn 10334fde40d9SSimon J. Gerraty.Dq meta 10344fde40d9SSimon J. Gerratymode, provides a list of prefixes which 10353955d011SMarcel Moolenaarmatch the directories controlled by 10363955d011SMarcel Moolenaar.Nm . 10373955d011SMarcel MoolenaarIf a file that was generated outside of 10383955d011SMarcel Moolenaar.Va .OBJDIR 10393955d011SMarcel Moolenaarbut within said bailiwick is missing, 10403955d011SMarcel Moolenaarthe current target is considered out-of-date. 10419f45a3c8SSimon J. Gerraty.It Va .MAKE.META.CMP_FILTER 10424fde40d9SSimon J. GerratyIn 10434fde40d9SSimon J. Gerraty.Dq meta 10444fde40d9SSimon J. Gerratymode, it can (very rarely!) be useful to filter command 10459f45a3c8SSimon J. Gerratylines before comparison. 10464fde40d9SSimon J. GerratyThis variable can be set to a set of modifiers that are applied to 10479f45a3c8SSimon J. Gerratyeach line of the old and new command that differ, if the filtered 10489f45a3c8SSimon J. Gerratycommands still differ, the target is considered out-of-date. 10493955d011SMarcel Moolenaar.It Va .MAKE.META.CREATED 10504fde40d9SSimon J. GerratyIn 10514fde40d9SSimon J. Gerraty.Dq meta 10524fde40d9SSimon J. Gerratymode, this variable contains a list of all the meta files 10533955d011SMarcel Moolenaarupdated. 10543955d011SMarcel MoolenaarIf not empty, it can be used to trigger processing of 10553955d011SMarcel Moolenaar.Va .MAKE.META.FILES . 10563955d011SMarcel Moolenaar.It Va .MAKE.META.FILES 10574fde40d9SSimon J. GerratyIn 10584fde40d9SSimon J. Gerraty.Dq meta 10594fde40d9SSimon J. Gerratymode, this variable contains a list of all the meta files 10603955d011SMarcel Moolenaarused (updated or not). 10613955d011SMarcel MoolenaarThis list can be used to process the meta files to extract dependency 10623955d011SMarcel Moolenaarinformation. 10634fde40d9SSimon J. Gerraty.It Va .MAKE.META.IGNORE_FILTER 10644fde40d9SSimon J. GerratyProvides a list of variable modifiers to apply to each pathname. 10654fde40d9SSimon J. GerratyIgnore if the expansion is an empty string. 106651ee2c1cSSimon J. Gerraty.It Va .MAKE.META.IGNORE_PATHS 106751ee2c1cSSimon J. GerratyProvides a list of path prefixes that should be ignored; 106851ee2c1cSSimon J. Gerratybecause the contents are expected to change over time. 106951ee2c1cSSimon J. GerratyThe default list includes: 1070954401e6SSimon J. Gerraty.Sq Pa /dev /etc /proc /tmp /var/run /var/tmp 1071e48f47ddSSimon J. Gerraty.It Va .MAKE.META.IGNORE_PATTERNS 1072e48f47ddSSimon J. GerratyProvides a list of patterns to match against pathnames. 1073e48f47ddSSimon J. GerratyIgnore any that match. 10743955d011SMarcel Moolenaar.It Va .MAKE.META.PREFIX 10754fde40d9SSimon J. GerratyDefines the message printed for each meta file updated in 10764fde40d9SSimon J. Gerraty.Dq meta verbose 10774fde40d9SSimon J. Gerratymode. 10783955d011SMarcel MoolenaarThe default value is: 10793955d011SMarcel Moolenaar.Dl Building ${.TARGET:H:tA}/${.TARGET:T} 10804fde40d9SSimon J. Gerraty.It Va .MAKE.MODE 10814fde40d9SSimon J. GerratyProcessed after reading all makefiles. 10824fde40d9SSimon J. GerratyAffects the mode that 10834fde40d9SSimon J. Gerraty.Nm 10844fde40d9SSimon J. Gerratyruns in. 10854fde40d9SSimon J. GerratyIt can contain these keywords: 10864fde40d9SSimon J. Gerraty.Bl -tag -width indent 10874fde40d9SSimon J. Gerraty.It Cm compat 10884fde40d9SSimon J. GerratyLike 10894fde40d9SSimon J. Gerraty.Fl B , 10904fde40d9SSimon J. Gerratyputs 10914fde40d9SSimon J. Gerraty.Nm 10924fde40d9SSimon J. Gerratyinto 10934fde40d9SSimon J. Gerraty.Dq compat 10944fde40d9SSimon J. Gerratymode. 10954fde40d9SSimon J. Gerraty.It Cm meta 10964fde40d9SSimon J. GerratyPuts 10974fde40d9SSimon J. Gerraty.Nm 10984fde40d9SSimon J. Gerratyinto 10994fde40d9SSimon J. Gerraty.Dq meta 11004fde40d9SSimon J. Gerratymode, where meta files are created for each target 11014fde40d9SSimon J. Gerratyto capture the command run, the output generated, and if 11024fde40d9SSimon J. Gerraty.Xr filemon 4 11034fde40d9SSimon J. Gerratyis available, the system calls which are of interest to 11044fde40d9SSimon J. Gerraty.Nm . 11054fde40d9SSimon J. GerratyThe captured output can be useful when diagnosing errors. 11064fde40d9SSimon J. Gerraty.It Cm curdirOk= Ns Ar bf 11074fde40d9SSimon J. GerratyBy default, 11084fde40d9SSimon J. Gerraty.Nm 11094fde40d9SSimon J. Gerratydoes not create 11104fde40d9SSimon J. Gerraty.Pa .meta 11114fde40d9SSimon J. Gerratyfiles in 11124fde40d9SSimon J. Gerraty.Sq Va .CURDIR . 11134fde40d9SSimon J. GerratyThis can be overridden by setting 11144fde40d9SSimon J. Gerraty.Ar bf 11154fde40d9SSimon J. Gerratyto a value which represents true. 11164fde40d9SSimon J. Gerraty.It Cm missing-meta= Ns Ar bf 11174fde40d9SSimon J. GerratyIf 11184fde40d9SSimon J. Gerraty.Ar bf 11194fde40d9SSimon J. Gerratyis true, a missing 11204fde40d9SSimon J. Gerraty.Pa .meta 11214fde40d9SSimon J. Gerratyfile makes the target out-of-date. 11224fde40d9SSimon J. Gerraty.It Cm missing-filemon= Ns Ar bf 11234fde40d9SSimon J. GerratyIf 11244fde40d9SSimon J. Gerraty.Ar bf 11254fde40d9SSimon J. Gerratyis true, missing filemon data makes the target out-of-date. 11264fde40d9SSimon J. Gerraty.It Cm nofilemon 11274fde40d9SSimon J. GerratyDo not use 11284fde40d9SSimon J. Gerraty.Xr filemon 4 . 11294fde40d9SSimon J. Gerraty.It Cm env 11304fde40d9SSimon J. GerratyFor debugging, it can be useful to include the environment 11314fde40d9SSimon J. Gerratyin the 11324fde40d9SSimon J. Gerraty.Pa .meta 11334fde40d9SSimon J. Gerratyfile. 11344fde40d9SSimon J. Gerraty.It Cm verbose 11354fde40d9SSimon J. GerratyIf in 11364fde40d9SSimon J. Gerraty.Dq meta 11374fde40d9SSimon J. Gerratymode, print a clue about the target being built. 11384fde40d9SSimon J. GerratyThis is useful if the build is otherwise running silently. 11394fde40d9SSimon J. GerratyThe message printed is the expanded value of 11404fde40d9SSimon J. Gerraty.Va .MAKE.META.PREFIX . 11414fde40d9SSimon J. Gerraty.It Cm ignore-cmd 11424fde40d9SSimon J. GerratySome makefiles have commands which are simply not stable. 11434fde40d9SSimon J. GerratyThis keyword causes them to be ignored for 11444fde40d9SSimon J. Gerratydetermining whether a target is out of date in 11454fde40d9SSimon J. Gerraty.Dq meta 11464fde40d9SSimon J. Gerratymode. 11474fde40d9SSimon J. GerratySee also 11484fde40d9SSimon J. Gerraty.Ic .NOMETA_CMP . 11494fde40d9SSimon J. Gerraty.It Cm silent= Ns Ar bf 11504fde40d9SSimon J. GerratyIf 11514fde40d9SSimon J. Gerraty.Ar bf 11524fde40d9SSimon J. Gerratyis true, when a .meta file is created, mark the target 11534fde40d9SSimon J. Gerraty.Ic .SILENT . 11544fde40d9SSimon J. Gerraty.It Cm randomize-targets 11554fde40d9SSimon J. GerratyIn both compat and parallel mode, do not make the targets in the usual order, 11564fde40d9SSimon J. Gerratybut instead randomize their order. 11574fde40d9SSimon J. GerratyThis mode can be used to detect undeclared dependencies between files. 11584fde40d9SSimon J. Gerraty.El 11594fde40d9SSimon J. Gerraty.It Va MAKEOBJDIR 11604fde40d9SSimon J. GerratyUsed to create files in a separate directory, see 11614fde40d9SSimon J. Gerraty.Va .OBJDIR . 11624fde40d9SSimon J. Gerraty.It Va MAKE_OBJDIR_CHECK_WRITABLE 11638d5c8e21SSimon J. GerratyWhen true, 11648d5c8e21SSimon J. Gerraty.Nm 11658d5c8e21SSimon J. Gerratywill check that 11668d5c8e21SSimon J. Gerraty.Va .OBJDIR 11678d5c8e21SSimon J. Gerratyis writable, and issue a warning if not. 11688d5c8e21SSimon J. Gerraty.It Va MAKE_DEBUG_OBJDIR_CHECK_WRITABLE 11698d5c8e21SSimon J. GerratyWhen true and 11708d5c8e21SSimon J. Gerraty.Nm 11718d5c8e21SSimon J. Gerratyis warning about an unwritable 11728d5c8e21SSimon J. Gerraty.Va .OBJDIR , 11738d5c8e21SSimon J. Gerratyreport the variables listed in 11748d5c8e21SSimon J. Gerraty.Va MAKE_PRINT_VAR_ON_ERROR 11758d5c8e21SSimon J. Gerratyto help debug. 11764fde40d9SSimon J. Gerraty.It Va MAKEOBJDIRPREFIX 11774fde40d9SSimon J. GerratyUsed to create files in a separate directory, see 11784fde40d9SSimon J. Gerraty.Va .OBJDIR . 1179*6a7405f5SSimon J. GerratyIt should be an absolute path. 11804fde40d9SSimon J. Gerraty.It Va .MAKE.OS 11814fde40d9SSimon J. GerratyThe name of the operating system, see 11824fde40d9SSimon J. Gerraty.Xr uname 1 . 11834fde40d9SSimon J. GerratyIt is read-only. 11843955d011SMarcel Moolenaar.It Va .MAKEOVERRIDES 11853955d011SMarcel MoolenaarThis variable is used to record the names of variables assigned to 11863955d011SMarcel Moolenaaron the command line, so that they may be exported as part of 1187954401e6SSimon J. Gerraty.Sq Ev MAKEFLAGS . 1188be19d90bSSimon J. GerratyThis behavior can be disabled by assigning an empty value to 1189954401e6SSimon J. Gerraty.Sq Va .MAKEOVERRIDES 11903955d011SMarcel Moolenaarwithin a makefile. 11913955d011SMarcel MoolenaarExtra variables can be exported from a makefile 11923955d011SMarcel Moolenaarby appending their names to 1193954401e6SSimon J. Gerraty.Sq Va .MAKEOVERRIDES . 1194954401e6SSimon J. Gerraty.Sq Ev MAKEFLAGS 11953955d011SMarcel Moolenaaris re-exported whenever 1196954401e6SSimon J. Gerraty.Sq Va .MAKEOVERRIDES 11973955d011SMarcel Moolenaaris modified. 11981748de26SSimon J. Gerraty.It Va .MAKE.PATH_FILEMON 11991748de26SSimon J. GerratyIf 12001748de26SSimon J. Gerraty.Nm 12011748de26SSimon J. Gerratywas built with 12021748de26SSimon J. Gerraty.Xr filemon 4 12031748de26SSimon J. Gerratysupport, this is set to the path of the device node. 12041748de26SSimon J. GerratyThis allows makefiles to test for this support. 12053955d011SMarcel Moolenaar.It Va .MAKE.PID 12064fde40d9SSimon J. GerratyThe process ID of 12073955d011SMarcel Moolenaar.Nm . 12084fde40d9SSimon J. GerratyIt is read-only. 12093955d011SMarcel Moolenaar.It Va .MAKE.PPID 12104fde40d9SSimon J. GerratyThe parent process ID of 12113955d011SMarcel Moolenaar.Nm . 12124fde40d9SSimon J. GerratyIt is read-only. 12134fde40d9SSimon J. Gerraty.It Va MAKE_PRINT_VAR_ON_ERROR 12144fde40d9SSimon J. GerratyWhen 12154fde40d9SSimon J. Gerraty.Nm 12164fde40d9SSimon J. Gerratystops due to an error, it sets 12174fde40d9SSimon J. Gerraty.Sq Va .ERROR_TARGET 12184fde40d9SSimon J. Gerratyto the name of the target that failed, 1219c59c3bf3SSimon J. Gerraty.Sq Va .ERROR_EXIT 1220c59c3bf3SSimon J. Gerratyto the exit status of the failed target, 12214fde40d9SSimon J. Gerraty.Sq Va .ERROR_CMD 12224fde40d9SSimon J. Gerratyto the commands of the failed target, 12234fde40d9SSimon J. Gerratyand in 12244fde40d9SSimon J. Gerraty.Dq meta 12254fde40d9SSimon J. Gerratymode, it also sets 12264fde40d9SSimon J. Gerraty.Sq Va .ERROR_CWD 12274fde40d9SSimon J. Gerratyto the 12284fde40d9SSimon J. Gerraty.Xr getcwd 3 , 12294fde40d9SSimon J. Gerratyand 12304fde40d9SSimon J. Gerraty.Sq Va .ERROR_META_FILE 12314fde40d9SSimon J. Gerratyto the path of the meta file (if any) describing the failed target. 12324fde40d9SSimon J. GerratyIt then prints its name and the value of 12334fde40d9SSimon J. Gerraty.Sq Va .CURDIR 12344fde40d9SSimon J. Gerratyas well as the value of any variables named in 12354fde40d9SSimon J. Gerraty.Sq Va MAKE_PRINT_VAR_ON_ERROR . 1236be19d90bSSimon J. Gerraty.It Va .MAKE.SAVE_DOLLARS 12374fde40d9SSimon J. GerratyIf true, 1238be19d90bSSimon J. Gerraty.Ql $$ 1239be19d90bSSimon J. Gerratyare preserved when doing 1240be19d90bSSimon J. Gerraty.Ql := 1241be19d90bSSimon J. Gerratyassignments. 1242be19d90bSSimon J. GerratyThe default is false, for backwards compatibility. 1243be19d90bSSimon J. GerratySet to true for compatability with other makes. 1244be19d90bSSimon J. GerratyIf set to false, 1245be19d90bSSimon J. Gerraty.Ql $$ 1246be19d90bSSimon J. Gerratybecomes 1247be19d90bSSimon J. Gerraty.Ql $ 1248be19d90bSSimon J. Gerratyper normal evaluation rules. 12494fde40d9SSimon J. Gerraty.It Va .MAKE.TARGET_LOCAL_VARIABLES 12504fde40d9SSimon J. GerratyIf set to 12514fde40d9SSimon J. Gerraty.Ql false , 12524fde40d9SSimon J. Gerratyapparent variable assignments in dependency lines are 12534fde40d9SSimon J. Gerratytreated as normal sources. 125406b9b3e0SSimon J. Gerraty.It Va .MAKE.UID 12554fde40d9SSimon J. GerratyThe numeric ID of the user running 125606b9b3e0SSimon J. Gerraty.Nm . 12574fde40d9SSimon J. GerratyIt is read-only. 12584fde40d9SSimon J. Gerraty.\" 'MAKE_VERSION' is intentionally undocumented 12594fde40d9SSimon J. Gerraty.\" since it is only defined in the bmake distribution, 12604fde40d9SSimon J. Gerraty.\" but not in NetBSD's native make. 12614fde40d9SSimon J. Gerraty.\" '.meta.%d.lcwd' is intentionally undocumented 12624fde40d9SSimon J. Gerraty.\" since it is an internal implementation detail. 12634fde40d9SSimon J. Gerraty.\" '.meta.%d.ldir' is intentionally undocumented 12644fde40d9SSimon J. Gerraty.\" since it is an internal implementation detail. 12654fde40d9SSimon J. Gerraty.\" 'MFLAGS' is intentionally undocumented 12664fde40d9SSimon J. Gerraty.\" since it is obsolete. 12673955d011SMarcel Moolenaar.It Va .newline 12683955d011SMarcel MoolenaarThis variable is simply assigned a newline character as its value. 12694fde40d9SSimon J. GerratyIt is read-only. 12703955d011SMarcel MoolenaarThis allows expansions using the 12713955d011SMarcel Moolenaar.Cm \&:@ 12723955d011SMarcel Moolenaarmodifier to put a newline between 12733955d011SMarcel Moolenaariterations of the loop rather than a space. 12744fde40d9SSimon J. GerratyFor example, in case of an error, 12754fde40d9SSimon J. Gerraty.Nm 12764fde40d9SSimon J. Gerratyprints the variable names and their values using: 12774fde40d9SSimon J. Gerraty.Dl ${MAKE_PRINT_VAR_ON_ERROR:@v@$v='${$v}'${.newline}@} 12783955d011SMarcel Moolenaar.It Va .OBJDIR 12793955d011SMarcel MoolenaarA path to the directory where the targets are built. 12803955d011SMarcel MoolenaarIts value is determined by trying to 12813955d011SMarcel Moolenaar.Xr chdir 2 12823955d011SMarcel Moolenaarto the following directories in order and using the first match: 12833955d011SMarcel Moolenaar.Bl -enum 12843955d011SMarcel Moolenaar.It 12854fde40d9SSimon J. Gerraty.Cm ${MAKEOBJDIRPREFIX} Ns Cm ${.CURDIR} 12863955d011SMarcel Moolenaar.Pp 12873955d011SMarcel Moolenaar(Only if 1288954401e6SSimon J. Gerraty.Sq Ev MAKEOBJDIRPREFIX 12893955d011SMarcel Moolenaaris set in the environment or on the command line.) 12903955d011SMarcel Moolenaar.It 12914fde40d9SSimon J. Gerraty.Cm ${MAKEOBJDIR} 12923955d011SMarcel Moolenaar.Pp 12933955d011SMarcel Moolenaar(Only if 1294954401e6SSimon J. Gerraty.Sq Ev MAKEOBJDIR 12953955d011SMarcel Moolenaaris set in the environment or on the command line.) 12963955d011SMarcel Moolenaar.It 12974fde40d9SSimon J. Gerraty.Cm ${.CURDIR} Ns Pa /obj. Ns Cm ${MACHINE} 12983955d011SMarcel Moolenaar.It 12994fde40d9SSimon J. Gerraty.Cm ${.CURDIR} Ns Pa /obj 13003955d011SMarcel Moolenaar.It 13014fde40d9SSimon J. Gerraty.Pa /usr/obj/ Ns Cm ${.CURDIR} 13023955d011SMarcel Moolenaar.It 13034fde40d9SSimon J. Gerraty.Cm ${.CURDIR} 13043955d011SMarcel Moolenaar.El 13053955d011SMarcel Moolenaar.Pp 13064fde40d9SSimon J. GerratyVariable expansion is performed on the value before it is used, 13073955d011SMarcel Moolenaarso expressions such as 13084fde40d9SSimon J. Gerraty.Cm ${.CURDIR:S,^/usr/src,/var/obj,} 13093955d011SMarcel Moolenaarmay be used. 13103955d011SMarcel MoolenaarThis is especially useful with 1311954401e6SSimon J. Gerraty.Sq Ev MAKEOBJDIR . 13123955d011SMarcel Moolenaar.Pp 1313954401e6SSimon J. Gerraty.Sq Va .OBJDIR 1314128a4105SSimon J. Gerratymay be modified in the makefile via the special target 1315954401e6SSimon J. Gerraty.Sq Ic .OBJDIR . 13163955d011SMarcel MoolenaarIn all cases, 13173955d011SMarcel Moolenaar.Nm 13184fde40d9SSimon J. Gerratychanges to the specified directory if it exists, and sets 1319954401e6SSimon J. Gerraty.Sq Va .OBJDIR 1320128a4105SSimon J. Gerratyand 13214fde40d9SSimon J. Gerraty.Sq Va PWD 13223955d011SMarcel Moolenaarto that directory before executing any targets. 1323e2eeea75SSimon J. Gerraty.Pp 1324e2eeea75SSimon J. GerratyExcept in the case of an explicit 1325954401e6SSimon J. Gerraty.Sq Ic .OBJDIR 1326e2eeea75SSimon J. Gerratytarget, 1327e2eeea75SSimon J. Gerraty.Nm 13284fde40d9SSimon J. Gerratychecks that the specified directory is writable and ignores it if not. 1329e2eeea75SSimon J. GerratyThis check can be skipped by setting the environment variable 1330954401e6SSimon J. Gerraty.Sq Ev MAKE_OBJDIR_CHECK_WRITABLE 13314fde40d9SSimon J. Gerratyto 13324fde40d9SSimon J. Gerraty.Dq no . 13333955d011SMarcel Moolenaar.It Va .PARSEDIR 13344fde40d9SSimon J. GerratyThe directory name of the current makefile being parsed. 13353955d011SMarcel Moolenaar.It Va .PARSEFILE 13364fde40d9SSimon J. GerratyThe basename of the current makefile being parsed. 13373955d011SMarcel MoolenaarThis variable and 1338954401e6SSimon J. Gerraty.Sq Va .PARSEDIR 13394fde40d9SSimon J. Gerratyare both set only while the makefiles are being parsed. 13404fde40d9SSimon J. GerratyTo retain their current values, 13414fde40d9SSimon J. Gerratyassign them to a variable using assignment with expansion 1342954401e6SSimon J. Gerraty.Sq Cm \&:= . 13433955d011SMarcel Moolenaar.It Va .PATH 13444fde40d9SSimon J. GerratyThe space-separated list of directories that 13453955d011SMarcel Moolenaar.Nm 13464fde40d9SSimon J. Gerratysearches for files. 13474fde40d9SSimon J. GerratyTo update this search list, use the special target 13484fde40d9SSimon J. Gerraty.Sq Ic .PATH 13494fde40d9SSimon J. Gerratyrather than modifying the variable directly. 13504fde40d9SSimon J. Gerraty.It Va %POSIX 13514fde40d9SSimon J. GerratyIs set in POSIX mode, see the special 13524fde40d9SSimon J. Gerraty.Ql Va .POSIX 13534fde40d9SSimon J. Gerratytarget. 13544fde40d9SSimon J. Gerraty.\" XXX: There is no make variable named 'PWD', 13554fde40d9SSimon J. Gerraty.\" XXX: make only reads and writes the environment variable 'PWD'. 13564fde40d9SSimon J. Gerraty.It Va PWD 13573955d011SMarcel MoolenaarAlternate path to the current directory. 13583955d011SMarcel Moolenaar.Nm 13593955d011SMarcel Moolenaarnormally sets 1360954401e6SSimon J. Gerraty.Sq Va .CURDIR 13613955d011SMarcel Moolenaarto the canonical path given by 13623955d011SMarcel Moolenaar.Xr getcwd 3 . 13633955d011SMarcel MoolenaarHowever, if the environment variable 1364954401e6SSimon J. Gerraty.Sq Ev PWD 13654fde40d9SSimon J. Gerratyis set and gives a path to the current directory, 13663955d011SMarcel Moolenaar.Nm 13673955d011SMarcel Moolenaarsets 1368954401e6SSimon J. Gerraty.Sq Va .CURDIR 13693955d011SMarcel Moolenaarto the value of 1370954401e6SSimon J. Gerraty.Sq Ev PWD 13713955d011SMarcel Moolenaarinstead. 1372be19d90bSSimon J. GerratyThis behavior is disabled if 1373954401e6SSimon J. Gerraty.Sq Ev MAKEOBJDIRPREFIX 13743955d011SMarcel Moolenaaris set or 1375954401e6SSimon J. Gerraty.Sq Ev MAKEOBJDIR 13763955d011SMarcel Moolenaarcontains a variable transform. 13774fde40d9SSimon J. Gerraty.Sq Va PWD 13783955d011SMarcel Moolenaaris set to the value of 1379954401e6SSimon J. Gerraty.Sq Va .OBJDIR 13803955d011SMarcel Moolenaarfor all programs which 13813955d011SMarcel Moolenaar.Nm 13823955d011SMarcel Moolenaarexecutes. 13834fde40d9SSimon J. Gerraty.It Va .SHELL 13842c3632d1SSimon J. GerratyThe pathname of the shell used to run target scripts. 13852c3632d1SSimon J. GerratyIt is read-only. 13864fde40d9SSimon J. Gerraty.It Va .SUFFIXES 138712904384SSimon J. GerratyThe list of known suffixes. 138812904384SSimon J. GerratyIt is read-only. 13894fde40d9SSimon J. Gerraty.It Va .SYSPATH 13904fde40d9SSimon J. GerratyThe space-separated list of directories that 13913955d011SMarcel Moolenaar.Nm 13924fde40d9SSimon J. Gerratysearches for makefiles, referred to as the system include path. 13934fde40d9SSimon J. GerratyTo update this search list, use the special target 13944fde40d9SSimon J. Gerraty.Sq Ic .SYSPATH 13954fde40d9SSimon J. Gerratyrather than modifying the variable which is read-only. 13964fde40d9SSimon J. Gerraty.It Va .TARGETS 13974fde40d9SSimon J. GerratyThe list of targets explicitly specified on the command line, if any. 13984fde40d9SSimon J. Gerraty.It Va VPATH 13994fde40d9SSimon J. GerratyThe colon-separated 14004fde40d9SSimon J. Gerraty.Pq Dq \&: 14014fde40d9SSimon J. Gerratylist of directories that 14024fde40d9SSimon J. Gerraty.Nm 14034fde40d9SSimon J. Gerratysearches for files. 14044fde40d9SSimon J. GerratyThis variable is supported for compatibility with old make programs only, use 1405954401e6SSimon J. Gerraty.Sq Va .PATH 14063955d011SMarcel Moolenaarinstead. 14073955d011SMarcel Moolenaar.El 14083955d011SMarcel Moolenaar.Ss Variable modifiers 14094fde40d9SSimon J. GerratyThe general format of a variable expansion is: 14103955d011SMarcel Moolenaar.Pp 14114fde40d9SSimon J. Gerraty.Sm off 14124fde40d9SSimon J. Gerraty.D1 Ic \&${ Ar variable\| Oo Ic \&: Ar modifier\| Oo Ic \&: No ... Oc Oc Ic \&} 14134fde40d9SSimon J. Gerraty.Sm on 14143955d011SMarcel Moolenaar.Pp 14154fde40d9SSimon J. GerratyEach modifier begins with a colon. 14164fde40d9SSimon J. GerratyTo escape a colon, precede it with a backslash 14174fde40d9SSimon J. Gerraty.Ql \e . 14183955d011SMarcel Moolenaar.Pp 14194fde40d9SSimon J. GerratyA list of indirect modifiers can be specified via a variable, as follows: 14203955d011SMarcel Moolenaar.Pp 14214fde40d9SSimon J. Gerraty.Bd -literal -offset indent 14224fde40d9SSimon J. Gerraty.Ar modifier_variable\^ Li \&= Ar modifier Ns Oo Ic \&: Ns No ... Oc 14234fde40d9SSimon J. Gerraty 14244fde40d9SSimon J. Gerraty.Sm off 14254fde40d9SSimon J. Gerraty.Ic \&${ Ar variable Ic \&:${ Ar modifier_variable Ic \&} Oo Ic \&: No ... Oc Ic \&} 14264fde40d9SSimon J. Gerraty.Sm on 14274fde40d9SSimon J. Gerraty.Ed 14283955d011SMarcel Moolenaar.Pp 14294fde40d9SSimon J. GerratyIn this case, the first modifier in the 14304fde40d9SSimon J. Gerraty.Ar modifier_variable 14314fde40d9SSimon J. Gerratydoes not start with a colon, 14324fde40d9SSimon J. Gerratysince that colon already occurs in the referencing variable. 14334fde40d9SSimon J. GerratyIf any of the modifiers in the 14344fde40d9SSimon J. Gerraty.Ar modifier_variable 14354fde40d9SSimon J. Gerratycontains a dollar sign 14363955d011SMarcel Moolenaar.Pq Ql $ , 14373955d011SMarcel Moolenaarthese must be doubled to avoid early expansion. 14383955d011SMarcel Moolenaar.Pp 14394fde40d9SSimon J. GerratySome modifiers interpret the expression value as a single string, 14404fde40d9SSimon J. Gerratyothers treat the expression value as a whitespace-separated list of words. 14414fde40d9SSimon J. GerratyWhen splitting a string into words, 14424fde40d9SSimon J. Gerratywhitespace can be escaped using double quotes, single quotes and backslashes, 14434fde40d9SSimon J. Gerratylike in the shell. 14444fde40d9SSimon J. GerratyThe quotes and backslashes are retained in the words. 14454fde40d9SSimon J. Gerraty.Pp 14463955d011SMarcel MoolenaarThe supported modifiers are: 14473955d011SMarcel Moolenaar.Bl -tag -width EEE 14483955d011SMarcel Moolenaar.It Cm \&:E 14494fde40d9SSimon J. GerratyReplaces each word with its suffix. 14503955d011SMarcel Moolenaar.It Cm \&:H 14514fde40d9SSimon J. GerratyReplaces each word with its dirname. 1452954401e6SSimon J. Gerraty.It Cm \&:M\| Ns Ar pattern 14532c3632d1SSimon J. GerratySelects only those words that match 14543955d011SMarcel Moolenaar.Ar pattern . 14553955d011SMarcel MoolenaarThe standard shell wildcard characters 14563955d011SMarcel Moolenaar.Pf ( Ql * , 14573955d011SMarcel Moolenaar.Ql \&? , 14583955d011SMarcel Moolenaarand 1459954401e6SSimon J. Gerraty.Ql \&[] ) 14603955d011SMarcel Moolenaarmay 14613955d011SMarcel Moolenaarbe used. 14623955d011SMarcel MoolenaarThe wildcard characters may be escaped with a backslash 14633955d011SMarcel Moolenaar.Pq Ql \e . 14640dede8b0SSimon J. GerratyAs a consequence of the way values are split into words, matched, 14654fde40d9SSimon J. Gerratyand then joined, the construct 14664fde40d9SSimon J. Gerraty.Ql ${VAR:M*} 14674fde40d9SSimon J. Gerratyremoves all leading and trailing whitespace 14684fde40d9SSimon J. Gerratyand normalizes the inter-word spacing to a single space. 1469954401e6SSimon J. Gerraty.It Cm \&:N\| Ns Ar pattern 14704fde40d9SSimon J. GerratyThis is the opposite of 1471954401e6SSimon J. Gerraty.Sq Cm \&:M , 14724fde40d9SSimon J. Gerratyselecting all words which do 14734fde40d9SSimon J. Gerraty.Em not 14744fde40d9SSimon J. Gerratymatch 14753955d011SMarcel Moolenaar.Ar pattern . 14763955d011SMarcel Moolenaar.It Cm \&:O 14774fde40d9SSimon J. GerratyOrders the words lexicographically. 147812904384SSimon J. Gerraty.It Cm \&:On 14794fde40d9SSimon J. GerratyOrders the words numerically. 148012904384SSimon J. GerratyA number followed by one of 148112904384SSimon J. Gerraty.Ql k , 148212904384SSimon J. Gerraty.Ql M 148312904384SSimon J. Gerratyor 148412904384SSimon J. Gerraty.Ql G 14854fde40d9SSimon J. Gerratyis multiplied by the appropriate factor, which is 1024 for 14864fde40d9SSimon J. Gerraty.Ql k , 14874fde40d9SSimon J. Gerraty1048576 for 14884fde40d9SSimon J. Gerraty.Ql M , 14894fde40d9SSimon J. Gerratyor 1073741824 for 14904fde40d9SSimon J. Gerraty.Ql G . 149112904384SSimon J. GerratyBoth upper- and lower-case letters are accepted. 1492ef0b2538SSimon J. Gerraty.It Cm \&:Or 14934fde40d9SSimon J. GerratyOrders the words in reverse lexicographical order. 149412904384SSimon J. Gerraty.It Cm \&:Orn 14954fde40d9SSimon J. GerratyOrders the words in reverse numerical order. 14963955d011SMarcel Moolenaar.It Cm \&:Ox 14974fde40d9SSimon J. GerratyShuffles the words. 14984fde40d9SSimon J. GerratyThe results are different each time you are referring to the 14993955d011SMarcel Moolenaarmodified variable; use the assignment with expansion 1500954401e6SSimon J. Gerraty.Sq Cm \&:= 1501be19d90bSSimon J. Gerratyto prevent such behavior. 15023955d011SMarcel MoolenaarFor example, 15033955d011SMarcel Moolenaar.Bd -literal -offset indent 15043955d011SMarcel MoolenaarLIST= uno due tre quattro 15053955d011SMarcel MoolenaarRANDOM_LIST= ${LIST:Ox} 15063955d011SMarcel MoolenaarSTATIC_RANDOM_LIST:= ${LIST:Ox} 15073955d011SMarcel Moolenaar 15083955d011SMarcel Moolenaarall: 15093955d011SMarcel Moolenaar @echo "${RANDOM_LIST}" 15103955d011SMarcel Moolenaar @echo "${RANDOM_LIST}" 15113955d011SMarcel Moolenaar @echo "${STATIC_RANDOM_LIST}" 15123955d011SMarcel Moolenaar @echo "${STATIC_RANDOM_LIST}" 15133955d011SMarcel Moolenaar.Ed 15143955d011SMarcel Moolenaarmay produce output similar to: 15153955d011SMarcel Moolenaar.Bd -literal -offset indent 15163955d011SMarcel Moolenaarquattro due tre uno 15173955d011SMarcel Moolenaartre due quattro uno 15183955d011SMarcel Moolenaardue uno quattro tre 15193955d011SMarcel Moolenaardue uno quattro tre 15203955d011SMarcel Moolenaar.Ed 15213955d011SMarcel Moolenaar.It Cm \&:Q 15224fde40d9SSimon J. GerratyQuotes every shell meta-character in the value, so that it can be passed 15232eae894cSSimon J. Gerratysafely to the shell. 15242eae894cSSimon J. Gerraty.It Cm \&:q 15254fde40d9SSimon J. GerratyQuotes every shell meta-character in the value, and also doubles 15262eae894cSSimon J. Gerraty.Sq $ 15272eae894cSSimon J. Gerratycharacters so that it can be passed 15283955d011SMarcel Moolenaarsafely through recursive invocations of 15293955d011SMarcel Moolenaar.Nm . 15304fde40d9SSimon J. GerratyThis is equivalent to 15314fde40d9SSimon J. Gerraty.Sq Cm \&:S/\e\&$/&&/g:Q . 15323955d011SMarcel Moolenaar.It Cm \&:R 15334fde40d9SSimon J. GerratyReplaces each word with everything but its suffix. 15344fde40d9SSimon J. Gerraty.It Cm \&:range Ns Oo Cm = Ns Ar count Oc 15351ce939a7SSimon J. GerratyThe value is an integer sequence representing the words of the original 15361ce939a7SSimon J. Gerratyvalue, or the supplied 15374fde40d9SSimon J. Gerraty.Ar count . 15384fde40d9SSimon J. Gerraty.It Cm \&:gmtime Ns Oo Cm = Ns Ar timestamp Oc 15394fde40d9SSimon J. GerratyThe value is interpreted as a format string for 15403955d011SMarcel Moolenaar.Xr strftime 3 , 15411ce939a7SSimon J. Gerratyusing 15424fde40d9SSimon J. Gerraty.Xr gmtime 3 , 15434fde40d9SSimon J. Gerratyproducing the formatted timestamp. 154498875883SSimon J. GerratyNote: the 154598875883SSimon J. Gerraty.Ql %s 154698875883SSimon J. Gerratyformat should only be used with 154798875883SSimon J. Gerraty.Sq Cm \&:localtime . 15481ce939a7SSimon J. GerratyIf a 15494fde40d9SSimon J. Gerraty.Ar timestamp 15501ce939a7SSimon J. Gerratyvalue is not provided or is 0, the current time is used. 15513955d011SMarcel Moolenaar.It Cm \&:hash 15524fde40d9SSimon J. GerratyComputes a 32-bit hash of the value and encodes it as 8 hex digits. 15534fde40d9SSimon J. Gerraty.It Cm \&:localtime Ns Oo Cm = Ns Ar timestamp Oc 15544fde40d9SSimon J. GerratyThe value is interpreted as a format string for 15553955d011SMarcel Moolenaar.Xr strftime 3 , 15561ce939a7SSimon J. Gerratyusing 15574fde40d9SSimon J. Gerraty.Xr localtime 3 , 15584fde40d9SSimon J. Gerratyproducing the formatted timestamp. 15591ce939a7SSimon J. GerratyIf a 15604fde40d9SSimon J. Gerraty.Ar timestamp 15611ce939a7SSimon J. Gerratyvalue is not provided or is 0, the current time is used. 1562c1d01b5fSSimon J. Gerraty.It Cm \&:mtime Ns Oo Cm = Ns Ar timestamp Oc 1563c1d01b5fSSimon J. GerratyCall 1564c1d01b5fSSimon J. Gerraty.Xr stat 2 1565c1d01b5fSSimon J. Gerratywith each word as pathname; 1566c1d01b5fSSimon J. Gerratyuse 1567c1d01b5fSSimon J. Gerraty.Ql st_mtime 1568c1d01b5fSSimon J. Gerratyas the new value. 1569c1d01b5fSSimon J. GerratyIf 1570c1d01b5fSSimon J. Gerraty.Xr stat 2 1571c1d01b5fSSimon J. Gerratyfails; use 1572c1d01b5fSSimon J. Gerraty.Ar timestamp 1573c1d01b5fSSimon J. Gerratyor current time. 1574c1d01b5fSSimon J. GerratyIf 1575c1d01b5fSSimon J. Gerraty.Ar timestamp 1576c1d01b5fSSimon J. Gerratyis set to 1577c1d01b5fSSimon J. Gerraty.Ql error , 1578c1d01b5fSSimon J. Gerratythen 1579c1d01b5fSSimon J. Gerraty.Xr stat 2 1580c1d01b5fSSimon J. Gerratyfailure will cause an error. 15813955d011SMarcel Moolenaar.It Cm \&:tA 15824fde40d9SSimon J. GerratyAttempts to convert the value to an absolute path using 15834fde40d9SSimon J. Gerraty.Xr realpath 3 . 15844fde40d9SSimon J. GerratyIf that fails, the value is unchanged. 15853955d011SMarcel Moolenaar.It Cm \&:tl 15864fde40d9SSimon J. GerratyConverts the value to lower-case letters. 15873955d011SMarcel Moolenaar.It Cm \&:ts Ns Ar c 15884fde40d9SSimon J. GerratyWhen joining the words after a modifier that treats the value as words, 15894fde40d9SSimon J. Gerratythe words are normally separated by a space. 15904fde40d9SSimon J. GerratyThis modifier changes the separator to the character 15913955d011SMarcel Moolenaar.Ar c . 15923955d011SMarcel MoolenaarIf 15933955d011SMarcel Moolenaar.Ar c 15944fde40d9SSimon J. Gerratyis omitted, no separator is used. 15952c3632d1SSimon J. GerratyThe common escapes (including octal numeric codes) work as expected. 159622619282SSimon J. Gerraty.It Cm \&:tt 159722619282SSimon J. GerratyConverts the first character of each word to upper-case, 159822619282SSimon J. Gerratyand the rest to lower-case letters. 15993955d011SMarcel Moolenaar.It Cm \&:tu 16004fde40d9SSimon J. GerratyConverts the value to upper-case letters. 16013955d011SMarcel Moolenaar.It Cm \&:tW 16024fde40d9SSimon J. GerratyCauses subsequent modifiers to treat the value as a single word 16033955d011SMarcel Moolenaar(possibly containing embedded whitespace). 16043955d011SMarcel MoolenaarSee also 1605954401e6SSimon J. Gerraty.Sq Cm \&:[*] . 16063955d011SMarcel Moolenaar.It Cm \&:tw 16074fde40d9SSimon J. GerratyCauses the value to be treated as a list of words. 16083955d011SMarcel MoolenaarSee also 1609954401e6SSimon J. Gerraty.Sq Cm \&:[@] . 16103955d011SMarcel Moolenaar.Sm off 1611954401e6SSimon J. Gerraty.It Cm \&:S\| No \&/ Ar old_string\| No \&/ Ar new_string\| No \&/ Op Cm 1gW 16123955d011SMarcel Moolenaar.Sm on 16132c3632d1SSimon J. GerratyModifies the first occurrence of 16143955d011SMarcel Moolenaar.Ar old_string 16154fde40d9SSimon J. Gerratyin each word of the value, replacing it with 16163955d011SMarcel Moolenaar.Ar new_string . 16173955d011SMarcel MoolenaarIf a 16183955d011SMarcel Moolenaar.Ql g 16194fde40d9SSimon J. Gerratyis appended to the last delimiter of the pattern, 16204fde40d9SSimon J. Gerratyall occurrences in each word are replaced. 16213955d011SMarcel MoolenaarIf a 16223955d011SMarcel Moolenaar.Ql 1 16234fde40d9SSimon J. Gerratyis appended to the last delimiter of the pattern, 16244fde40d9SSimon J. Gerratyonly the first occurrence is affected. 16253955d011SMarcel MoolenaarIf a 16263955d011SMarcel Moolenaar.Ql W 16272c3632d1SSimon J. Gerratyis appended to the last delimiter of the pattern, 16284fde40d9SSimon J. Gerratythe value is treated as a single word. 16293955d011SMarcel MoolenaarIf 16303955d011SMarcel Moolenaar.Ar old_string 16313955d011SMarcel Moolenaarbegins with a caret 16323955d011SMarcel Moolenaar.Pq Ql ^ , 16333955d011SMarcel Moolenaar.Ar old_string 16343955d011SMarcel Moolenaaris anchored at the beginning of each word. 16353955d011SMarcel MoolenaarIf 16363955d011SMarcel Moolenaar.Ar old_string 16373955d011SMarcel Moolenaarends with a dollar sign 16383955d011SMarcel Moolenaar.Pq Ql \&$ , 16393955d011SMarcel Moolenaarit is anchored at the end of each word. 16403955d011SMarcel MoolenaarInside 16413955d011SMarcel Moolenaar.Ar new_string , 16423955d011SMarcel Moolenaaran ampersand 16438695518cSSimon J. Gerraty.Pq Ql & 16443955d011SMarcel Moolenaaris replaced by 16453955d011SMarcel Moolenaar.Ar old_string 16464fde40d9SSimon J. Gerraty(without the anchoring 16473955d011SMarcel Moolenaar.Ql ^ 16483955d011SMarcel Moolenaaror 16493955d011SMarcel Moolenaar.Ql \&$ ) . 16504fde40d9SSimon J. GerratyAny character may be used as the delimiter for the parts of the modifier 16513955d011SMarcel Moolenaarstring. 16524fde40d9SSimon J. GerratyThe anchoring, ampersand and delimiter characters can be escaped with a 16533955d011SMarcel Moolenaarbackslash 16543955d011SMarcel Moolenaar.Pq Ql \e . 16553955d011SMarcel Moolenaar.Pp 16564fde40d9SSimon J. GerratyBoth 16573955d011SMarcel Moolenaar.Ar old_string 16583955d011SMarcel Moolenaarand 16593955d011SMarcel Moolenaar.Ar new_string 16604fde40d9SSimon J. Gerratymay contain nested expressions. 16614fde40d9SSimon J. GerratyTo prevent a dollar sign from starting a nested expression, 16624fde40d9SSimon J. Gerratyescape it with a backslash. 16633955d011SMarcel Moolenaar.Sm off 1664954401e6SSimon J. Gerraty.It Cm \&:C\| No \&/ Ar pattern\| No \&/ Ar replacement\| No \&/ Op Cm 1gW 16653955d011SMarcel Moolenaar.Sm on 16663955d011SMarcel MoolenaarThe 16673955d011SMarcel Moolenaar.Cm \&:C 16684fde40d9SSimon J. Gerratymodifier works like the 16693955d011SMarcel Moolenaar.Cm \&:S 16703955d011SMarcel Moolenaarmodifier except that the old and new strings, instead of being 16714fde40d9SSimon J. Gerratysimple strings, are an extended regular expression 16723955d011SMarcel Moolenaar.Ar pattern 16734fde40d9SSimon J. Gerraty(see 16744fde40d9SSimon J. Gerraty.Xr regex 3 ) 16753955d011SMarcel Moolenaarand an 16763955d011SMarcel Moolenaar.Xr ed 1 Ns \-style 16773955d011SMarcel Moolenaar.Ar replacement . 16783955d011SMarcel MoolenaarNormally, the first occurrence of the pattern 16793955d011SMarcel Moolenaar.Ar pattern 16803955d011SMarcel Moolenaarin each word of the value is substituted with 16813955d011SMarcel Moolenaar.Ar replacement . 16823955d011SMarcel MoolenaarThe 16833955d011SMarcel Moolenaar.Ql 1 16843955d011SMarcel Moolenaarmodifier causes the substitution to apply to at most one word; the 16853955d011SMarcel Moolenaar.Ql g 16863955d011SMarcel Moolenaarmodifier causes the substitution to apply to as many instances of the 16873955d011SMarcel Moolenaarsearch pattern 16883955d011SMarcel Moolenaar.Ar pattern 16893955d011SMarcel Moolenaaras occur in the word or words it is found in; the 16903955d011SMarcel Moolenaar.Ql W 16913955d011SMarcel Moolenaarmodifier causes the value to be treated as a single word 16923955d011SMarcel Moolenaar(possibly containing embedded whitespace). 16935bcb7424SSimon J. Gerraty.Pp 16945bcb7424SSimon J. GerratyAs for the 16955bcb7424SSimon J. Gerraty.Cm \&:S 16965bcb7424SSimon J. Gerratymodifier, the 16975bcb7424SSimon J. Gerraty.Ar pattern 16985bcb7424SSimon J. Gerratyand 16995bcb7424SSimon J. Gerraty.Ar replacement 17005bcb7424SSimon J. Gerratyare subjected to variable expansion before being parsed as 17015bcb7424SSimon J. Gerratyregular expressions. 17023955d011SMarcel Moolenaar.It Cm \&:T 17034fde40d9SSimon J. GerratyReplaces each word with its last path component (basename). 17043955d011SMarcel Moolenaar.It Cm \&:u 17052c3632d1SSimon J. GerratyRemoves adjacent duplicate words (like 17063955d011SMarcel Moolenaar.Xr uniq 1 ) . 17073955d011SMarcel Moolenaar.Sm off 1708954401e6SSimon J. Gerraty.It Cm \&:\&?\| Ar true_string\| Cm \&: Ar false_string 17093955d011SMarcel Moolenaar.Sm on 17104fde40d9SSimon J. GerratyIf the variable name (not its value), when parsed as a 17114fde40d9SSimon J. Gerraty.Cm .if 17124fde40d9SSimon J. Gerratyconditional expression, evaluates to true, return as its value the 17133955d011SMarcel Moolenaar.Ar true_string , 17143955d011SMarcel Moolenaarotherwise return the 17153955d011SMarcel Moolenaar.Ar false_string . 17164fde40d9SSimon J. GerratySince the variable name is used as the expression, 17174fde40d9SSimon J. Gerraty\&:\&? must be the first modifier after the variable name 17184fde40d9SSimon J. Gerraty.No itself Ns \^\(em\^ Ns 17194fde40d9SSimon J. Gerratywhich, of course, usually contains variable expansions. 17203955d011SMarcel MoolenaarA common error is trying to use expressions like 17213955d011SMarcel Moolenaar.Dl ${NUMBERS:M42:?match:no} 17224fde40d9SSimon J. Gerratywhich actually tests defined(NUMBERS). 17234fde40d9SSimon J. GerratyTo determine if any words match 17244fde40d9SSimon J. Gerraty.Dq 42 , 17254fde40d9SSimon J. Gerratyyou need to use something like: 17263955d011SMarcel Moolenaar.Dl ${"${NUMBERS:M42}" != \&"\&":?match:no} . 1727954401e6SSimon J. Gerraty.It Cm :\| Ns Ar old_string\| Ns Cm = Ns Ar new_string 17283955d011SMarcel MoolenaarThis is the 17293955d011SMarcel Moolenaar.At V 17304fde40d9SSimon J. Gerratystyle substitution. 17314fde40d9SSimon J. GerratyIt can only be the last modifier specified, 17324fde40d9SSimon J. Gerratyas a 17334fde40d9SSimon J. Gerraty.Ql \&: 17344fde40d9SSimon J. Gerratyin either 17354fde40d9SSimon J. Gerraty.Ar old_string 17364fde40d9SSimon J. Gerratyor 17374fde40d9SSimon J. Gerraty.Ar new_string 17384fde40d9SSimon J. Gerratyis treated as a regular character, not as the end of the modifier. 17394fde40d9SSimon J. Gerraty.Pp 17403955d011SMarcel MoolenaarIf 17413955d011SMarcel Moolenaar.Ar old_string 17424fde40d9SSimon J. Gerratydoes not contain the pattern matching character 17434fde40d9SSimon J. Gerraty.Ql % , 17444fde40d9SSimon J. Gerratyand the word ends with 17453955d011SMarcel Moolenaar.Ar old_string 17464fde40d9SSimon J. Gerratyor equals it, 17474fde40d9SSimon J. Gerratythat suffix is replaced with 17483955d011SMarcel Moolenaar.Ar new_string . 17493955d011SMarcel Moolenaar.Pp 17504fde40d9SSimon J. GerratyOtherwise, the first 17514fde40d9SSimon J. Gerraty.Ql % 17524fde40d9SSimon J. Gerratyin 17534fde40d9SSimon J. Gerraty.Ar old_string 17544fde40d9SSimon J. Gerratymatches a possibly empty substring of arbitrary characters, 17554fde40d9SSimon J. Gerratyand if the whole pattern is found in the word, 17564fde40d9SSimon J. Gerratythe matching part is replaced with 17574fde40d9SSimon J. Gerraty.Ar new_string , 17584fde40d9SSimon J. Gerratyand the first occurrence of 17594fde40d9SSimon J. Gerraty.Ql % 17604fde40d9SSimon J. Gerratyin 17614fde40d9SSimon J. Gerraty.Ar new_string 17624fde40d9SSimon J. Gerraty(if any) is replaced with the substring matched by the 17634fde40d9SSimon J. Gerraty.Ql % . 17644fde40d9SSimon J. Gerraty.Pp 17654fde40d9SSimon J. GerratyBoth 17663955d011SMarcel Moolenaar.Ar old_string 17673955d011SMarcel Moolenaarand 17683955d011SMarcel Moolenaar.Ar new_string 17694fde40d9SSimon J. Gerratymay contain nested expressions. 17704fde40d9SSimon J. GerratyTo prevent a dollar sign from starting a nested expression, 17714fde40d9SSimon J. Gerratyescape it with a backslash. 17723955d011SMarcel Moolenaar.Sm off 17734fde40d9SSimon J. Gerraty.It Cm \&:@ Ar varname\| Cm @ Ar string\| Cm @ 17743955d011SMarcel Moolenaar.Sm on 17753955d011SMarcel MoolenaarThis is the loop expansion mechanism from the OSF Development 17763955d011SMarcel MoolenaarEnvironment (ODE) make. 17773955d011SMarcel MoolenaarUnlike 17783955d011SMarcel Moolenaar.Cm \&.for 17792c3632d1SSimon J. Gerratyloops, expansion occurs at the time of reference. 17804fde40d9SSimon J. GerratyFor each word in the value, assign the word to the variable named 17814fde40d9SSimon J. Gerraty.Ar varname 17824fde40d9SSimon J. Gerratyand evaluate 17833955d011SMarcel Moolenaar.Ar string . 17843955d011SMarcel MoolenaarThe ODE convention is that 17854fde40d9SSimon J. Gerraty.Ar varname 17864fde40d9SSimon J. Gerratyshould start and end with a period, for example: 17873955d011SMarcel Moolenaar.Dl ${LINKS:@.LINK.@${LN} ${TARGET} ${.LINK.}@} 17883955d011SMarcel Moolenaar.Pp 17894fde40d9SSimon J. GerratyHowever, a single-letter variable is often more readable: 17903955d011SMarcel Moolenaar.Dl ${MAKE_PRINT_VAR_ON_ERROR:@v@$v='${$v}'${.newline}@} 1791954401e6SSimon J. Gerraty.It Cm \&:_ Ns Oo Cm = Ns Ar var Oc 17922c3632d1SSimon J. GerratySaves the current variable value in 17931ce939a7SSimon J. Gerraty.Ql $_ 17941ce939a7SSimon J. Gerratyor the named 17954fde40d9SSimon J. Gerraty.Ar var 17961ce939a7SSimon J. Gerratyfor later reference. 17971ce939a7SSimon J. GerratyExample usage: 17981ce939a7SSimon J. Gerraty.Bd -literal -offset indent 17991ce939a7SSimon J. GerratyM_cmpv.units = 1 1000 1000000 18001ce939a7SSimon J. GerratyM_cmpv = S,., ,g:_:range:@i@+ $${_:[-$$i]} \&\\ 18011ce939a7SSimon J. Gerraty\\* $${M_cmpv.units:[$$i]}@:S,^,expr 0 ,1:sh 18021ce939a7SSimon J. Gerraty 18031ce939a7SSimon J. Gerraty.Dv .if ${VERSION:${M_cmpv}} < ${3.1.12:L:${M_cmpv}} 18041ce939a7SSimon J. Gerraty 18051ce939a7SSimon J. Gerraty.Ed 18061ce939a7SSimon J. GerratyHere 18071ce939a7SSimon J. Gerraty.Ql $_ 18081ce939a7SSimon J. Gerratyis used to save the result of the 18091ce939a7SSimon J. Gerraty.Ql :S 18101ce939a7SSimon J. Gerratymodifier which is later referenced using the index values from 18111ce939a7SSimon J. Gerraty.Ql :range . 1812954401e6SSimon J. Gerraty.It Cm \&:U\| Ns Ar newval 18132c3632d1SSimon J. GerratyIf the variable is undefined, 1814c59c3bf3SSimon J. Gerratythe optional 18153955d011SMarcel Moolenaar.Ar newval 1816c59c3bf3SSimon J. Gerraty(which may be empty) is the value. 18173955d011SMarcel MoolenaarIf the variable is defined, the existing value is returned. 18183955d011SMarcel MoolenaarThis is another ODE make feature. 18193955d011SMarcel MoolenaarIt is handy for setting per-target CFLAGS for instance: 18203955d011SMarcel Moolenaar.Dl ${_${.TARGET:T}_CFLAGS:U${DEF_CFLAGS}} 18213955d011SMarcel MoolenaarIf a value is only required if the variable is undefined, use: 18223955d011SMarcel Moolenaar.Dl ${VAR:D:Unewval} 1823954401e6SSimon J. Gerraty.It Cm \&:D\| Ns Ar newval 18242c3632d1SSimon J. GerratyIf the variable is defined, 18253955d011SMarcel Moolenaar.Ar newval 1826c59c3bf3SSimon J. Gerraty(which may be empty) is the value. 18273955d011SMarcel Moolenaar.It Cm \&:L 18283955d011SMarcel MoolenaarThe name of the variable is the value. 18293955d011SMarcel Moolenaar.It Cm \&:P 18304fde40d9SSimon J. GerratyThe path of the node which has the same name as the variable is the value. 18314fde40d9SSimon J. GerratyIf no such node exists or its path is null, the name of the variable is used. 18323955d011SMarcel MoolenaarIn order for this modifier to work, the name (node) must at least have 18334fde40d9SSimon J. Gerratyappeared on the right-hand side of a dependency. 18343955d011SMarcel Moolenaar.Sm off 1835954401e6SSimon J. Gerraty.It Cm \&:\&! Ar cmd\| Cm \&! 18363955d011SMarcel Moolenaar.Sm on 18373955d011SMarcel MoolenaarThe output of running 18383955d011SMarcel Moolenaar.Ar cmd 18393955d011SMarcel Moolenaaris the value. 18403955d011SMarcel Moolenaar.It Cm \&:sh 18414fde40d9SSimon J. GerratyThe value is run as a command, and the output becomes the new value. 18423955d011SMarcel Moolenaar.It Cm \&::= Ns Ar str 18433955d011SMarcel MoolenaarThe variable is assigned the value 18443955d011SMarcel Moolenaar.Ar str 18453955d011SMarcel Moolenaarafter substitution. 18464fde40d9SSimon J. GerratyThis modifier and its variations are useful in obscure situations 18474fde40d9SSimon J. Gerratysuch as wanting to set a variable 18484fde40d9SSimon J. Gerratyat a point where a target's shell commands are being parsed. 18494fde40d9SSimon J. GerratyThese assignment modifiers always expand to nothing. 18503955d011SMarcel Moolenaar.Pp 18513955d011SMarcel MoolenaarThe 1852954401e6SSimon J. Gerraty.Sq Cm \&:: 18533955d011SMarcel Moolenaarhelps avoid false matches with the 18543955d011SMarcel Moolenaar.At V 18553955d011SMarcel Moolenaarstyle 18564fde40d9SSimon J. Gerraty.Ql \&:= 18574fde40d9SSimon J. Gerratymodifier and since substitution always occurs, the 18584fde40d9SSimon J. Gerraty.Ql \&::= 18593955d011SMarcel Moolenaarform is vaguely appropriate. 18603955d011SMarcel Moolenaar.It Cm \&::?= Ns Ar str 18613955d011SMarcel MoolenaarAs for 18623955d011SMarcel Moolenaar.Cm \&::= 18633955d011SMarcel Moolenaarbut only if the variable does not already have a value. 18643955d011SMarcel Moolenaar.It Cm \&::+= Ns Ar str 18653955d011SMarcel MoolenaarAppend 18663955d011SMarcel Moolenaar.Ar str 18673955d011SMarcel Moolenaarto the variable. 18683955d011SMarcel Moolenaar.It Cm \&::!= Ns Ar cmd 18693955d011SMarcel MoolenaarAssign the output of 18703955d011SMarcel Moolenaar.Ar cmd 18713955d011SMarcel Moolenaarto the variable. 18723955d011SMarcel Moolenaar.It Cm \&:\&[ Ns Ar range Ns Cm \&] 18733955d011SMarcel MoolenaarSelects one or more words from the value, 18743955d011SMarcel Moolenaaror performs other operations related to the way in which the 18754fde40d9SSimon J. Gerratyvalue is split into words. 18763955d011SMarcel Moolenaar.Pp 18773955d011SMarcel MoolenaarAn empty value, or a value that consists entirely of white-space, 18783955d011SMarcel Moolenaaris treated as a single word. 18793955d011SMarcel MoolenaarFor the purposes of the 1880954401e6SSimon J. Gerraty.Sq Cm \&:[] 18813955d011SMarcel Moolenaarmodifier, the words are indexed both forwards using positive integers 18823955d011SMarcel Moolenaar(where index 1 represents the first word), 18833955d011SMarcel Moolenaarand backwards using negative integers 18843955d011SMarcel Moolenaar(where index \-1 represents the last word). 18853955d011SMarcel Moolenaar.Pp 18863955d011SMarcel MoolenaarThe 18873955d011SMarcel Moolenaar.Ar range 18883955d011SMarcel Moolenaaris subjected to variable expansion, and the expanded result is 18893955d011SMarcel Moolenaarthen interpreted as follows: 18903955d011SMarcel Moolenaar.Bl -tag -width index 18913955d011SMarcel Moolenaar.\" :[n] 18923955d011SMarcel Moolenaar.It Ar index 18933955d011SMarcel MoolenaarSelects a single word from the value. 18943955d011SMarcel Moolenaar.\" :[start..end] 18953955d011SMarcel Moolenaar.It Ar start Ns Cm \&.. Ns Ar end 18963955d011SMarcel MoolenaarSelects all words from 18973955d011SMarcel Moolenaar.Ar start 18983955d011SMarcel Moolenaarto 18993955d011SMarcel Moolenaar.Ar end , 19003955d011SMarcel Moolenaarinclusive. 19013955d011SMarcel MoolenaarFor example, 1902954401e6SSimon J. Gerraty.Sq Cm \&:[2..-1] 19033955d011SMarcel Moolenaarselects all words from the second word to the last word. 19043955d011SMarcel MoolenaarIf 19053955d011SMarcel Moolenaar.Ar start 19063955d011SMarcel Moolenaaris greater than 19073955d011SMarcel Moolenaar.Ar end , 19084fde40d9SSimon J. Gerratythe words are output in reverse order. 19093955d011SMarcel MoolenaarFor example, 1910954401e6SSimon J. Gerraty.Sq Cm \&:[-1..1] 19113955d011SMarcel Moolenaarselects all the words from last to first. 19124fde40d9SSimon J. GerratyIf the list is already ordered, 19134fde40d9SSimon J. Gerratythis effectively reverses the list, 19144fde40d9SSimon J. Gerratybut it is more efficient to use 1915954401e6SSimon J. Gerraty.Sq Cm \&:Or 1916ef0b2538SSimon J. Gerratyinstead of 1917954401e6SSimon J. Gerraty.Sq Cm \&:O:[-1..1] . 19183955d011SMarcel Moolenaar.\" :[*] 19193955d011SMarcel Moolenaar.It Cm \&* 19203955d011SMarcel MoolenaarCauses subsequent modifiers to treat the value as a single word 19213955d011SMarcel Moolenaar(possibly containing embedded whitespace). 19223955d011SMarcel MoolenaarAnalogous to the effect of 19234fde40d9SSimon J. Gerraty.Li \&$* 19243955d011SMarcel Moolenaarin Bourne shell. 19253955d011SMarcel Moolenaar.\" :[0] 19263955d011SMarcel Moolenaar.It 0 19273955d011SMarcel MoolenaarMeans the same as 1928954401e6SSimon J. Gerraty.Sq Cm \&:[*] . 19293955d011SMarcel Moolenaar.\" :[*] 19303955d011SMarcel Moolenaar.It Cm \&@ 19313955d011SMarcel MoolenaarCauses subsequent modifiers to treat the value as a sequence of words 19323955d011SMarcel Moolenaardelimited by whitespace. 19333955d011SMarcel MoolenaarAnalogous to the effect of 19344fde40d9SSimon J. Gerraty.Li \&$@ 19353955d011SMarcel Moolenaarin Bourne shell. 19363955d011SMarcel Moolenaar.\" :[#] 19373955d011SMarcel Moolenaar.It Cm \&# 19383955d011SMarcel MoolenaarReturns the number of words in the value. 19393955d011SMarcel Moolenaar.El \" :[range] 19403955d011SMarcel Moolenaar.El 19414fde40d9SSimon J. Gerraty.Sh DIRECTIVES 19424fde40d9SSimon J. Gerraty.Nm 19434fde40d9SSimon J. Gerratyoffers directives for including makefiles, conditionals and for loops. 19444fde40d9SSimon J. GerratyAll these directives are identified by a line beginning with a single dot 19453955d011SMarcel Moolenaar.Pq Ql \&. 19464fde40d9SSimon J. Gerratycharacter, followed by the keyword of the directive, such as 19474fde40d9SSimon J. Gerraty.Cm include 19484fde40d9SSimon J. Gerratyor 19494fde40d9SSimon J. Gerraty.Cm if . 19504fde40d9SSimon J. Gerraty.Ss File inclusion 19513955d011SMarcel MoolenaarFiles are included with either 195249caa483SSimon J. Gerraty.Cm \&.include \&< Ns Ar file Ns Cm \&> 19533955d011SMarcel Moolenaaror 195449caa483SSimon J. Gerraty.Cm \&.include \&\*q Ns Ar file Ns Cm \&\*q . 19553955d011SMarcel MoolenaarVariables between the angle brackets or double quotes are expanded 19563955d011SMarcel Moolenaarto form the file name. 19573955d011SMarcel MoolenaarIf angle brackets are used, the included makefile is expected to be in 19583955d011SMarcel Moolenaarthe system makefile directory. 19593955d011SMarcel MoolenaarIf double quotes are used, the including makefile's directory and any 19603955d011SMarcel Moolenaardirectories specified using the 19613955d011SMarcel Moolenaar.Fl I 19624fde40d9SSimon J. Gerratyoption are searched before the system makefile directory. 19634fde40d9SSimon J. Gerraty.Pp 19644fde40d9SSimon J. GerratyFor compatibility with other make variants, 19654fde40d9SSimon J. Gerraty.Sq Cm include Ar file No ... 19664fde40d9SSimon J. Gerraty(without leading dot) 19673955d011SMarcel Moolenaaris also accepted. 1968be19d90bSSimon J. Gerraty.Pp 19693955d011SMarcel MoolenaarIf the include statement is written as 19703955d011SMarcel Moolenaar.Cm .-include 19713955d011SMarcel Moolenaaror as 19724fde40d9SSimon J. Gerraty.Cm .sinclude , 19734fde40d9SSimon J. Gerratyerrors locating and/or opening include files are ignored. 19743955d011SMarcel Moolenaar.Pp 1975be19d90bSSimon J. GerratyIf the include statement is written as 19764fde40d9SSimon J. Gerraty.Cm .dinclude , 1977be19d90bSSimon J. Gerratynot only are errors locating and/or opening include files ignored, 19784fde40d9SSimon J. Gerratybut stale dependencies within the included file are ignored just like in 1979be19d90bSSimon J. Gerraty.Va .MAKE.DEPENDFILE . 19804fde40d9SSimon J. Gerraty.Ss Exporting variables 19814fde40d9SSimon J. GerratyThe directives for exporting and unexporting variables are: 19823955d011SMarcel Moolenaar.Bl -tag -width Ds 19834fde40d9SSimon J. Gerraty.It Ic .export Ar variable No ... 19843955d011SMarcel MoolenaarExport the specified global variable. 19858d5c8e21SSimon J. Gerraty.Pp 19864fde40d9SSimon J. GerratyFor compatibility with other make programs, 19874fde40d9SSimon J. Gerraty.Cm export Ar variable\| Ns Cm \&= Ns Ar value 19884fde40d9SSimon J. Gerraty(without leading dot) is also accepted. 19893955d011SMarcel Moolenaar.Pp 19903955d011SMarcel MoolenaarAppending a variable name to 19913955d011SMarcel Moolenaar.Va .MAKE.EXPORTED 19923955d011SMarcel Moolenaaris equivalent to exporting a variable. 19938d5c8e21SSimon J. Gerraty.It Ic .export-all 19948d5c8e21SSimon J. GerratyExport all globals except for internal variables (those that start with 19958d5c8e21SSimon J. Gerraty.Ql \&. ) . 19968d5c8e21SSimon J. GerratyThis is not affected by the 19978d5c8e21SSimon J. Gerraty.Fl X 19988d5c8e21SSimon J. Gerratyflag, so should be used with caution. 19994fde40d9SSimon J. Gerraty.It Ic .export-env Ar variable No ... 20003955d011SMarcel MoolenaarThe same as 20013955d011SMarcel Moolenaar.Ql .export , 20023955d011SMarcel Moolenaarexcept that the variable is not appended to 20033955d011SMarcel Moolenaar.Va .MAKE.EXPORTED . 20043955d011SMarcel MoolenaarThis allows exporting a value to the environment which is different from that 20053955d011SMarcel Moolenaarused by 20063955d011SMarcel Moolenaar.Nm 20073955d011SMarcel Moolenaarinternally. 20084fde40d9SSimon J. Gerraty.It Ic .export-literal Ar variable No ... 2009be19d90bSSimon J. GerratyThe same as 2010be19d90bSSimon J. Gerraty.Ql .export-env , 2011be19d90bSSimon J. Gerratyexcept that variables in the value are not expanded. 20124fde40d9SSimon J. Gerraty.It Ic .unexport Ar variable No ... 20133955d011SMarcel MoolenaarThe opposite of 20143955d011SMarcel Moolenaar.Ql .export . 20153955d011SMarcel MoolenaarThe specified global 20164fde40d9SSimon J. Gerraty.Ar variable 20174fde40d9SSimon J. Gerratyis removed from 20183955d011SMarcel Moolenaar.Va .MAKE.EXPORTED . 20193955d011SMarcel MoolenaarIf no variable list is provided, all globals are unexported, 20203955d011SMarcel Moolenaarand 20213955d011SMarcel Moolenaar.Va .MAKE.EXPORTED 20223955d011SMarcel Moolenaardeleted. 20233955d011SMarcel Moolenaar.It Ic .unexport-env 20243955d011SMarcel MoolenaarUnexport all globals previously exported and 20253955d011SMarcel Moolenaarclear the environment inherited from the parent. 20264fde40d9SSimon J. GerratyThis operation causes a memory leak of the original environment, 20273955d011SMarcel Moolenaarso should be used sparingly. 20283955d011SMarcel MoolenaarTesting for 20293955d011SMarcel Moolenaar.Va .MAKE.LEVEL 20304fde40d9SSimon J. Gerratybeing 0 would make sense. 20313955d011SMarcel MoolenaarAlso note that any variables which originated in the parent environment 20323955d011SMarcel Moolenaarshould be explicitly preserved if desired. 20333955d011SMarcel MoolenaarFor example: 20343955d011SMarcel Moolenaar.Bd -literal -offset indent 20353955d011SMarcel Moolenaar.Li .if ${.MAKE.LEVEL} == 0 20363955d011SMarcel MoolenaarPATH := ${PATH} 20373955d011SMarcel Moolenaar.Li .unexport-env 20383955d011SMarcel Moolenaar.Li .export PATH 20393955d011SMarcel Moolenaar.Li .endif 20403955d011SMarcel Moolenaar.Pp 20413955d011SMarcel Moolenaar.Ed 20423955d011SMarcel MoolenaarWould result in an environment containing only 2043954401e6SSimon J. Gerraty.Sq Ev PATH , 20443955d011SMarcel Moolenaarwhich is the minimal useful environment. 20454fde40d9SSimon J. Gerraty.\" TODO: Check the below sentence, environment variables don't start with '.'. 20463955d011SMarcel MoolenaarActually 20474fde40d9SSimon J. Gerraty.Sq Va .MAKE.LEVEL 20484fde40d9SSimon J. Gerratyis also pushed into the new environment. 20494fde40d9SSimon J. Gerraty.El 20504fde40d9SSimon J. Gerraty.Ss Messages 20514fde40d9SSimon J. GerratyThe directives for printing messages to the output are: 20524fde40d9SSimon J. Gerraty.Bl -tag -width Ds 20534fde40d9SSimon J. Gerraty.It Ic .info Ar message 20544fde40d9SSimon J. GerratyThe message is printed along with the name of the makefile and line number. 20553955d011SMarcel Moolenaar.It Ic .warning Ar message 20563955d011SMarcel MoolenaarThe message prefixed by 20574fde40d9SSimon J. Gerraty.Sq Li warning: 20583955d011SMarcel Moolenaaris printed along with the name of the makefile and line number. 20594fde40d9SSimon J. Gerraty.It Ic .error Ar message 20604fde40d9SSimon J. GerratyThe message is printed along with the name of the makefile and line number, 20614fde40d9SSimon J. Gerraty.Nm 20624fde40d9SSimon J. Gerratyexits immediately. 20634fde40d9SSimon J. Gerraty.El 20644fde40d9SSimon J. Gerraty.Ss Conditionals 20654fde40d9SSimon J. GerratyThe directives for conditionals are: 20664fde40d9SSimon J. Gerraty.ds maybenot Oo Ic \&! Oc Ns 20674fde40d9SSimon J. Gerraty.Bl -tag 20684fde40d9SSimon J. Gerraty.It Ic .if \*[maybenot] Ar expression Op Ar operator expression No ... 20693955d011SMarcel MoolenaarTest the value of an expression. 20704fde40d9SSimon J. Gerraty.It Ic .ifdef \*[maybenot] Ar variable Op Ar operator variable No ... 20714fde40d9SSimon J. GerratyTest whether a variable is defined. 20724fde40d9SSimon J. Gerraty.It Ic .ifndef \*[maybenot] Ar variable Op Ar operator variable No ... 20734fde40d9SSimon J. GerratyTest whether a variable is not defined. 20744fde40d9SSimon J. Gerraty.It Ic .ifmake \*[maybenot] Ar target Op Ar operator target No ... 20754fde40d9SSimon J. GerratyTest the target being requested. 20764fde40d9SSimon J. Gerraty.It Ic .ifnmake \*[maybenot] Ar target Op Ar operator target No ... 20774fde40d9SSimon J. GerratyTest the target being requested. 20783955d011SMarcel Moolenaar.It Ic .else 20793955d011SMarcel MoolenaarReverse the sense of the last conditional. 20804fde40d9SSimon J. Gerraty.It Ic .elif \*[maybenot] Ar expression Op Ar operator expression No ... 20813955d011SMarcel MoolenaarA combination of 2082954401e6SSimon J. Gerraty.Sq Ic .else 20833955d011SMarcel Moolenaarfollowed by 2084954401e6SSimon J. Gerraty.Sq Ic .if . 20854fde40d9SSimon J. Gerraty.It Ic .elifdef \*[maybenot] Ar variable Op Ar operator variable No ... 20863955d011SMarcel MoolenaarA combination of 2087954401e6SSimon J. Gerraty.Sq Ic .else 20883955d011SMarcel Moolenaarfollowed by 2089954401e6SSimon J. Gerraty.Sq Ic .ifdef . 20904fde40d9SSimon J. Gerraty.It Ic .elifndef \*[maybenot] Ar variable Op Ar operator variable No ... 20913955d011SMarcel MoolenaarA combination of 2092954401e6SSimon J. Gerraty.Sq Ic .else 20933955d011SMarcel Moolenaarfollowed by 2094954401e6SSimon J. Gerraty.Sq Ic .ifndef . 20954fde40d9SSimon J. Gerraty.It Ic .elifmake \*[maybenot] Ar target Op Ar operator target No ... 20963955d011SMarcel MoolenaarA combination of 2097954401e6SSimon J. Gerraty.Sq Ic .else 20983955d011SMarcel Moolenaarfollowed by 2099954401e6SSimon J. Gerraty.Sq Ic .ifmake . 21004fde40d9SSimon J. Gerraty.It Ic .elifnmake \*[maybenot] Ar target Op Ar operator target No ... 21013955d011SMarcel MoolenaarA combination of 2102954401e6SSimon J. Gerraty.Sq Ic .else 21033955d011SMarcel Moolenaarfollowed by 2104954401e6SSimon J. Gerraty.Sq Ic .ifnmake . 21053955d011SMarcel Moolenaar.It Ic .endif 21063955d011SMarcel MoolenaarEnd the body of the conditional. 21073955d011SMarcel Moolenaar.El 21083955d011SMarcel Moolenaar.Pp 21093955d011SMarcel MoolenaarThe 21103955d011SMarcel Moolenaar.Ar operator 21113955d011SMarcel Moolenaarmay be any one of the following: 21124fde40d9SSimon J. Gerraty.Bl -tag 21134fde40d9SSimon J. Gerraty.It Ic \&|\&| 21143955d011SMarcel MoolenaarLogical OR. 21154fde40d9SSimon J. Gerraty.It Ic \&&& 21164fde40d9SSimon J. GerratyLogical AND; of higher precedence than 21174fde40d9SSimon J. Gerraty.Sq Ic \&|\&| . 21183955d011SMarcel Moolenaar.El 21193955d011SMarcel Moolenaar.Pp 21203955d011SMarcel Moolenaar.Nm 21214fde40d9SSimon J. Gerratyonly evaluates a conditional as far as is necessary to determine its value. 21224fde40d9SSimon J. GerratyParentheses can be used to override the operator precedence. 21233955d011SMarcel MoolenaarThe boolean operator 2124954401e6SSimon J. Gerraty.Sq Ic \&! 212598875883SSimon J. Gerratymay be used to logically negate an expression, typically a function call. 21263955d011SMarcel MoolenaarIt is of higher precedence than 2127954401e6SSimon J. Gerraty.Sq Ic \&&& . 21283955d011SMarcel Moolenaar.Pp 21293955d011SMarcel MoolenaarThe value of 21303955d011SMarcel Moolenaar.Ar expression 21314fde40d9SSimon J. Gerratymay be any of the following function call expressions: 21324fde40d9SSimon J. Gerraty.Bl -tag 21334fde40d9SSimon J. Gerraty.Sm off 21344fde40d9SSimon J. Gerraty.It Ic defined Li \&( Ar varname Li \&) 21354fde40d9SSimon J. Gerraty.Sm on 21364fde40d9SSimon J. GerratyEvaluates to true if the variable 21374fde40d9SSimon J. Gerraty.Ar varname 21383955d011SMarcel Moolenaarhas been defined. 21394fde40d9SSimon J. Gerraty.Sm off 21404fde40d9SSimon J. Gerraty.It Ic make Li \&( Ar target Li \&) 21414fde40d9SSimon J. Gerraty.Sm on 21424fde40d9SSimon J. GerratyEvaluates to true if the target was specified as part of 21433955d011SMarcel Moolenaar.Nm Ns 's 21443955d011SMarcel Moolenaarcommand line or was declared the default target (either implicitly or 21453955d011SMarcel Moolenaarexplicitly, see 21463955d011SMarcel Moolenaar.Va .MAIN ) 21473955d011SMarcel Moolenaarbefore the line containing the conditional. 21484fde40d9SSimon J. Gerraty.Sm off 21494fde40d9SSimon J. Gerraty.It Ic empty Li \&( Ar varname Oo Li : Ar modifiers Oc Li \&) 21504fde40d9SSimon J. Gerraty.Sm on 21514fde40d9SSimon J. GerratyEvaluates to true if the expansion of the variable, 21524fde40d9SSimon J. Gerratyafter applying the modifiers, results in an empty string. 21534fde40d9SSimon J. Gerraty.Sm off 21544fde40d9SSimon J. Gerraty.It Ic exists Li \&( Ar pathname Li \&) 21554fde40d9SSimon J. Gerraty.Sm on 21564fde40d9SSimon J. GerratyEvaluates to true if the given pathname exists. 21574fde40d9SSimon J. GerratyIf relative, the pathname is searched for on the system search path (see 21583955d011SMarcel Moolenaar.Va .PATH ) . 21594fde40d9SSimon J. Gerraty.Sm off 21604fde40d9SSimon J. Gerraty.It Ic target Li \&( Ar target Li \&) 21614fde40d9SSimon J. Gerraty.Sm on 21624fde40d9SSimon J. GerratyEvaluates to true if the target has been defined. 21634fde40d9SSimon J. Gerraty.Sm off 21644fde40d9SSimon J. Gerraty.It Ic commands Li \&( Ar target Li \&) 21654fde40d9SSimon J. Gerraty.Sm on 21664fde40d9SSimon J. GerratyEvaluates to true if the target has been defined 21674fde40d9SSimon J. Gerratyand has commands associated with it. 21683955d011SMarcel Moolenaar.El 21693955d011SMarcel Moolenaar.Pp 21703955d011SMarcel Moolenaar.Ar Expression 21713955d011SMarcel Moolenaarmay also be an arithmetic or string comparison. 21724fde40d9SSimon J. GerratyVariable expansion is performed on both sides of the comparison. 21734fde40d9SSimon J. GerratyIf both sides are numeric and neither is enclosed in quotes, 21744fde40d9SSimon J. Gerratythe comparison is done numerically, otherwise lexicographically. 217598875883SSimon J. GerratyA string is interpreted as a hexadecimal integer if it is preceded by 21764fde40d9SSimon J. Gerraty.Li 0x , 217798875883SSimon J. Gerratyotherwise it is interpreted as a decimal floating-point number; 21784fde40d9SSimon J. Gerratyoctal numbers are not supported. 21794fde40d9SSimon J. Gerraty.Pp 21804fde40d9SSimon J. GerratyAll comparisons may use the operators 21814fde40d9SSimon J. Gerraty.Sq Ic \&== 21824fde40d9SSimon J. Gerratyand 21834fde40d9SSimon J. Gerraty.Sq Ic \&!= . 21844fde40d9SSimon J. GerratyNumeric comparisons may also use the operators 21854fde40d9SSimon J. Gerraty.Sq Ic \&< , 21864fde40d9SSimon J. Gerraty.Sq Ic \&<= , 21874fde40d9SSimon J. Gerraty.Sq Ic \&> 21884fde40d9SSimon J. Gerratyand 21894fde40d9SSimon J. Gerraty.Sq Ic \&>= . 21904fde40d9SSimon J. Gerraty.Pp 21914fde40d9SSimon J. GerratyIf the comparison has neither a comparison operator nor a right side, 21924fde40d9SSimon J. Gerratythe expression evaluates to true if it is nonempty 21934fde40d9SSimon J. Gerratyand its numeric value (if any) is not zero. 21943955d011SMarcel Moolenaar.Pp 21953955d011SMarcel MoolenaarWhen 21963955d011SMarcel Moolenaar.Nm 21973955d011SMarcel Moolenaaris evaluating one of these conditional expressions, and it encounters 219898875883SSimon J. Gerratya (whitespace-separated) word it doesn't recognize, either the 21993955d011SMarcel Moolenaar.Dq make 22003955d011SMarcel Moolenaaror 22013955d011SMarcel Moolenaar.Dq defined 22024fde40d9SSimon J. Gerratyfunction is applied to it, depending on the form of the conditional. 22033955d011SMarcel MoolenaarIf the form is 2204954401e6SSimon J. Gerraty.Sq Ic .ifdef , 22054fde40d9SSimon J. Gerraty.Sq Ic .ifndef 22063955d011SMarcel Moolenaaror 22074fde40d9SSimon J. Gerraty.Sq Ic .if , 22083955d011SMarcel Moolenaarthe 22093955d011SMarcel Moolenaar.Dq defined 22104fde40d9SSimon J. Gerratyfunction is applied. 22113955d011SMarcel MoolenaarSimilarly, if the form is 2212954401e6SSimon J. Gerraty.Sq Ic .ifmake 22133955d011SMarcel Moolenaaror 2214954401e6SSimon J. Gerraty.Sq Ic .ifnmake , 2215494f7191SSimon J. Gerratythe 22163955d011SMarcel Moolenaar.Dq make 22174fde40d9SSimon J. Gerratyfunction is applied. 22183955d011SMarcel Moolenaar.Pp 22194fde40d9SSimon J. GerratyIf the conditional evaluates to true, 22204fde40d9SSimon J. Gerratyparsing of the makefile continues as before. 222198875883SSimon J. GerratyIf it evaluates to false, the following lines until the corresponding 222298875883SSimon J. Gerraty.Sq Ic .elif 222398875883SSimon J. Gerratyvariant, 2224954401e6SSimon J. Gerraty.Sq Ic .else 22253955d011SMarcel Moolenaaror 2226954401e6SSimon J. Gerraty.Sq Ic .endif 222798875883SSimon J. Gerratyare skipped. 22284fde40d9SSimon J. Gerraty.Ss For loops 22293955d011SMarcel MoolenaarFor loops are typically used to apply a set of rules to a list of files. 22303955d011SMarcel MoolenaarThe syntax of a for loop is: 22313955d011SMarcel Moolenaar.Pp 22323955d011SMarcel Moolenaar.Bl -tag -compact -width Ds 22334fde40d9SSimon J. Gerraty.It Ic \&.for Ar variable Oo Ar variable No ... Oc Ic in Ar expression 22344fde40d9SSimon J. Gerraty.It Aq Ar make-lines 22353955d011SMarcel Moolenaar.It Ic \&.endfor 22363955d011SMarcel Moolenaar.El 22373955d011SMarcel Moolenaar.Pp 22384fde40d9SSimon J. GerratyThe 22394fde40d9SSimon J. Gerraty.Ar expression 22404fde40d9SSimon J. Gerratyis expanded and then split into words. 22413955d011SMarcel MoolenaarOn each iteration of the loop, one word is taken and assigned to each 22424fde40d9SSimon J. Gerraty.Ar variable , 22433955d011SMarcel Moolenaarin order, and these 22444fde40d9SSimon J. Gerraty.Ar variables 22453955d011SMarcel Moolenaarare substituted into the 22464fde40d9SSimon J. Gerraty.Ar make-lines 22473955d011SMarcel Moolenaarinside the body of the for loop. 22483955d011SMarcel MoolenaarThe number of words must come out even; that is, if there are three 22493955d011SMarcel Moolenaariteration variables, the number of words provided must be a multiple 22503955d011SMarcel Moolenaarof three. 22514fde40d9SSimon J. Gerraty.Pp 22524fde40d9SSimon J. GerratyIf 22534fde40d9SSimon J. Gerraty.Sq Ic .break 22544fde40d9SSimon J. Gerratyis encountered within a 22554fde40d9SSimon J. Gerraty.Cm \&.for 22564fde40d9SSimon J. Gerratyloop, it causes early termination of the loop, otherwise a parse error. 22574fde40d9SSimon J. Gerraty.\" TODO: Describe limitations with defined/empty. 22584fde40d9SSimon J. Gerraty.Ss Other directives 22594fde40d9SSimon J. Gerraty.Bl -tag -width Ds 22604fde40d9SSimon J. Gerraty.It Ic .undef Ar variable No ... 22614fde40d9SSimon J. GerratyUn-define the specified global variables. 22624fde40d9SSimon J. GerratyOnly global variables can be un-defined. 22634fde40d9SSimon J. Gerraty.El 22643955d011SMarcel Moolenaar.Sh COMMENTS 22653955d011SMarcel MoolenaarComments begin with a hash 22663955d011SMarcel Moolenaar.Pq Ql \&# 22673955d011SMarcel Moolenaarcharacter, anywhere but in a shell 22683955d011SMarcel Moolenaarcommand line, and continue to the end of an unescaped new line. 22693955d011SMarcel Moolenaar.Sh SPECIAL SOURCES (ATTRIBUTES) 22703955d011SMarcel Moolenaar.Bl -tag -width .IGNOREx 22713955d011SMarcel Moolenaar.It Ic .EXEC 22723955d011SMarcel MoolenaarTarget is never out of date, but always execute commands anyway. 22733955d011SMarcel Moolenaar.It Ic .IGNORE 22743955d011SMarcel MoolenaarIgnore any errors from the commands associated with this target, exactly 22753955d011SMarcel Moolenaaras if they all were preceded by a dash 22763955d011SMarcel Moolenaar.Pq Ql \- . 22773955d011SMarcel Moolenaar.\" .It Ic .INVISIBLE 22783955d011SMarcel Moolenaar.\" XXX 22793955d011SMarcel Moolenaar.\" .It Ic .JOIN 22803955d011SMarcel Moolenaar.\" XXX 22813955d011SMarcel Moolenaar.It Ic .MADE 22824fde40d9SSimon J. GerratyMark all sources of this target as being up to date. 22833955d011SMarcel Moolenaar.It Ic .MAKE 22843955d011SMarcel MoolenaarExecute the commands associated with this target even if the 22853955d011SMarcel Moolenaar.Fl n 22863955d011SMarcel Moolenaaror 22873955d011SMarcel Moolenaar.Fl t 22883955d011SMarcel Moolenaaroptions were specified. 22893955d011SMarcel MoolenaarNormally used to mark recursive 22900dede8b0SSimon J. Gerraty.Nm Ns s . 22913955d011SMarcel Moolenaar.It Ic .META 22923955d011SMarcel MoolenaarCreate a meta file for the target, even if it is flagged as 22933955d011SMarcel Moolenaar.Ic .PHONY , 22943955d011SMarcel Moolenaar.Ic .MAKE , 22953955d011SMarcel Moolenaaror 22963955d011SMarcel Moolenaar.Ic .SPECIAL . 22973955d011SMarcel MoolenaarUsage in conjunction with 22983955d011SMarcel Moolenaar.Ic .MAKE 22993955d011SMarcel Moolenaaris the most likely case. 23004fde40d9SSimon J. GerratyIn 23014fde40d9SSimon J. Gerraty.Dq meta 23024fde40d9SSimon J. Gerratymode, the target is out-of-date if the meta file is missing. 23033955d011SMarcel Moolenaar.It Ic .NOMETA 23043955d011SMarcel MoolenaarDo not create a meta file for the target. 23053955d011SMarcel MoolenaarMeta files are also not created for 23063955d011SMarcel Moolenaar.Ic .PHONY , 23073955d011SMarcel Moolenaar.Ic .MAKE , 23083955d011SMarcel Moolenaaror 23093955d011SMarcel Moolenaar.Ic .SPECIAL 23103955d011SMarcel Moolenaartargets. 23113955d011SMarcel Moolenaar.It Ic .NOMETA_CMP 23123955d011SMarcel MoolenaarIgnore differences in commands when deciding if target is out of date. 23133955d011SMarcel MoolenaarThis is useful if the command contains a value which always changes. 23144fde40d9SSimon J. GerratyIf the number of commands change, though, 23154fde40d9SSimon J. Gerratythe target is still considered out of date. 23161748de26SSimon J. GerratyThe same effect applies to any command line that uses the variable 23171748de26SSimon J. Gerraty.Va .OODATE , 23181748de26SSimon J. Gerratywhich can be used for that purpose even when not otherwise needed or desired: 23191748de26SSimon J. Gerraty.Bd -literal -offset indent 23201748de26SSimon J. Gerraty 23211748de26SSimon J. Gerratyskip-compare-for-some: 23224fde40d9SSimon J. Gerraty @echo this is compared 23234fde40d9SSimon J. Gerraty @echo this is not ${.OODATE:M.NOMETA_CMP} 23244fde40d9SSimon J. Gerraty @echo this is also compared 23251748de26SSimon J. Gerraty 23261748de26SSimon J. Gerraty.Ed 23271748de26SSimon J. GerratyThe 23281748de26SSimon J. Gerraty.Cm \&:M 23291748de26SSimon J. Gerratypattern suppresses any expansion of the unwanted variable. 23303955d011SMarcel Moolenaar.It Ic .NOPATH 23313955d011SMarcel MoolenaarDo not search for the target in the directories specified by 23324fde40d9SSimon J. Gerraty.Va .PATH . 23333955d011SMarcel Moolenaar.It Ic .NOTMAIN 23343955d011SMarcel MoolenaarNormally 23353955d011SMarcel Moolenaar.Nm 23363955d011SMarcel Moolenaarselects the first target it encounters as the default target to be built 23373955d011SMarcel Moolenaarif no target was specified. 23383955d011SMarcel MoolenaarThis source prevents this target from being selected. 23393955d011SMarcel Moolenaar.It Ic .OPTIONAL 23403955d011SMarcel MoolenaarIf a target is marked with this attribute and 23413955d011SMarcel Moolenaar.Nm 23424fde40d9SSimon J. Gerratycan't figure out how to create it, it ignores this fact and assumes 23433955d011SMarcel Moolenaarthe file isn't needed or already exists. 23443955d011SMarcel Moolenaar.It Ic .PHONY 23454fde40d9SSimon J. GerratyThe target does not correspond to an actual file; 23464fde40d9SSimon J. Gerratyit is always considered to be out of date, 23474fde40d9SSimon J. Gerratyand is not created with the 23483955d011SMarcel Moolenaar.Fl t 23493955d011SMarcel Moolenaaroption. 23503955d011SMarcel MoolenaarSuffix-transformation rules are not applied to 23513955d011SMarcel Moolenaar.Ic .PHONY 23523955d011SMarcel Moolenaartargets. 23533955d011SMarcel Moolenaar.It Ic .PRECIOUS 23543955d011SMarcel MoolenaarWhen 23553955d011SMarcel Moolenaar.Nm 23563955d011SMarcel Moolenaaris interrupted, it normally removes any partially made targets. 23573955d011SMarcel MoolenaarThis source prevents the target from being removed. 23583955d011SMarcel Moolenaar.It Ic .RECURSIVE 23593955d011SMarcel MoolenaarSynonym for 23603955d011SMarcel Moolenaar.Ic .MAKE . 23613955d011SMarcel Moolenaar.It Ic .SILENT 23623955d011SMarcel MoolenaarDo not echo any of the commands associated with this target, exactly 23633955d011SMarcel Moolenaaras if they all were preceded by an at sign 23643955d011SMarcel Moolenaar.Pq Ql @ . 23653955d011SMarcel Moolenaar.It Ic .USE 23663955d011SMarcel MoolenaarTurn the target into 23673955d011SMarcel Moolenaar.Nm Ns 's 23683955d011SMarcel Moolenaarversion of a macro. 23693955d011SMarcel MoolenaarWhen the target is used as a source for another target, the other target 23703955d011SMarcel Moolenaaracquires the commands, sources, and attributes (except for 23713955d011SMarcel Moolenaar.Ic .USE ) 23723955d011SMarcel Moolenaarof the 23733955d011SMarcel Moolenaarsource. 23743955d011SMarcel MoolenaarIf the target already has commands, the 23753955d011SMarcel Moolenaar.Ic .USE 23763955d011SMarcel Moolenaartarget's commands are appended 23773955d011SMarcel Moolenaarto them. 23783955d011SMarcel Moolenaar.It Ic .USEBEFORE 23794fde40d9SSimon J. GerratyLike 23803955d011SMarcel Moolenaar.Ic .USE , 23814fde40d9SSimon J. Gerratybut instead of appending, prepend the 23823955d011SMarcel Moolenaar.Ic .USEBEFORE 23833955d011SMarcel Moolenaartarget commands to the target. 23843955d011SMarcel Moolenaar.It Ic .WAIT 23853955d011SMarcel MoolenaarIf 23863955d011SMarcel Moolenaar.Ic .WAIT 23873955d011SMarcel Moolenaarappears in a dependency line, the sources that precede it are 23883955d011SMarcel Moolenaarmade before the sources that succeed it in the line. 23893955d011SMarcel MoolenaarSince the dependents of files are not made until the file itself 23903955d011SMarcel Moolenaarcould be made, this also stops the dependents being built unless they 23913955d011SMarcel Moolenaarare needed for another branch of the dependency tree. 23923955d011SMarcel MoolenaarSo given: 23933955d011SMarcel Moolenaar.Bd -literal 23943955d011SMarcel Moolenaarx: a .WAIT b 23953955d011SMarcel Moolenaar echo x 23963955d011SMarcel Moolenaara: 23973955d011SMarcel Moolenaar echo a 23983955d011SMarcel Moolenaarb: b1 23993955d011SMarcel Moolenaar echo b 24003955d011SMarcel Moolenaarb1: 24013955d011SMarcel Moolenaar echo b1 24023955d011SMarcel Moolenaar 24033955d011SMarcel Moolenaar.Ed 24043955d011SMarcel Moolenaarthe output is always 24053955d011SMarcel Moolenaar.Ql a , 24063955d011SMarcel Moolenaar.Ql b1 , 24073955d011SMarcel Moolenaar.Ql b , 24083955d011SMarcel Moolenaar.Ql x . 24094fde40d9SSimon J. Gerraty.Pp 24103955d011SMarcel MoolenaarThe ordering imposed by 24113955d011SMarcel Moolenaar.Ic .WAIT 24123955d011SMarcel Moolenaaris only relevant for parallel makes. 24133955d011SMarcel Moolenaar.El 24143955d011SMarcel Moolenaar.Sh SPECIAL TARGETS 24153955d011SMarcel MoolenaarSpecial targets may not be included with other targets, i.e. they must be 24163955d011SMarcel Moolenaarthe only target specified. 24173955d011SMarcel Moolenaar.Bl -tag -width .BEGINx 24183955d011SMarcel Moolenaar.It Ic .BEGIN 24193955d011SMarcel MoolenaarAny command lines attached to this target are executed before anything 24203955d011SMarcel Moolenaarelse is done. 24213955d011SMarcel Moolenaar.It Ic .DEFAULT 24223955d011SMarcel MoolenaarThis is sort of a 24233955d011SMarcel Moolenaar.Ic .USE 24244fde40d9SSimon J. Gerratyrule for any target (that was used only as a source) that 24253955d011SMarcel Moolenaar.Nm 24263955d011SMarcel Moolenaarcan't figure out any other way to create. 24273955d011SMarcel MoolenaarOnly the shell script is used. 24283955d011SMarcel MoolenaarThe 24294fde40d9SSimon J. Gerraty.Va .IMPSRC 24303955d011SMarcel Moolenaarvariable of a target that inherits 24313955d011SMarcel Moolenaar.Ic .DEFAULT Ns 's 24324fde40d9SSimon J. Gerratycommands is set to the target's own name. 243345447996SSimon J. Gerraty.It Ic .DELETE_ON_ERROR 243445447996SSimon J. GerratyIf this target is present in the makefile, it globally causes make to 243545447996SSimon J. Gerratydelete targets whose commands fail. 243645447996SSimon J. Gerraty(By default, only targets whose commands are interrupted during 243745447996SSimon J. Gerratyexecution are deleted. 243845447996SSimon J. GerratyThis is the historical behavior.) 243945447996SSimon J. GerratyThis setting can be used to help prevent half-finished or malformed 244045447996SSimon J. Gerratytargets from being left around and corrupting future rebuilds. 24413955d011SMarcel Moolenaar.It Ic .END 24423955d011SMarcel MoolenaarAny command lines attached to this target are executed after everything 24434fde40d9SSimon J. Gerratyelse is done successfully. 24443955d011SMarcel Moolenaar.It Ic .ERROR 24453955d011SMarcel MoolenaarAny command lines attached to this target are executed when another target fails. 2446c59c3bf3SSimon J. GerratySee 2447c59c3bf3SSimon J. Gerraty.Va MAKE_PRINT_VAR_ON_ERROR 2448c59c3bf3SSimon J. Gerratyfor the variables that will be set. 24493955d011SMarcel Moolenaar.It Ic .IGNORE 24503955d011SMarcel MoolenaarMark each of the sources with the 24513955d011SMarcel Moolenaar.Ic .IGNORE 24523955d011SMarcel Moolenaarattribute. 24533955d011SMarcel MoolenaarIf no sources are specified, this is the equivalent of specifying the 24543955d011SMarcel Moolenaar.Fl i 24553955d011SMarcel Moolenaaroption. 24563955d011SMarcel Moolenaar.It Ic .INTERRUPT 24573955d011SMarcel MoolenaarIf 24583955d011SMarcel Moolenaar.Nm 24594fde40d9SSimon J. Gerratyis interrupted, the commands for this target are executed. 24603955d011SMarcel Moolenaar.It Ic .MAIN 24613955d011SMarcel MoolenaarIf no target is specified when 24623955d011SMarcel Moolenaar.Nm 24634fde40d9SSimon J. Gerratyis invoked, this target is built. 24643955d011SMarcel Moolenaar.It Ic .MAKEFLAGS 24653955d011SMarcel MoolenaarThis target provides a way to specify flags for 24663955d011SMarcel Moolenaar.Nm 24674fde40d9SSimon J. Gerratyat the time when the makefiles are read. 24683955d011SMarcel MoolenaarThe flags are as if typed to the shell, though the 24693955d011SMarcel Moolenaar.Fl f 24704fde40d9SSimon J. Gerratyoption has 24713955d011SMarcel Moolenaarno effect. 24723955d011SMarcel Moolenaar.\" XXX: NOT YET!!!! 24733955d011SMarcel Moolenaar.\" .It Ic .NOTPARALLEL 24743955d011SMarcel Moolenaar.\" The named targets are executed in non parallel mode. 24753955d011SMarcel Moolenaar.\" If no targets are 24764fde40d9SSimon J. Gerraty.\" specified, all targets are executed in non parallel mode. 24773955d011SMarcel Moolenaar.It Ic .NOPATH 24783955d011SMarcel MoolenaarApply the 24793955d011SMarcel Moolenaar.Ic .NOPATH 24803955d011SMarcel Moolenaarattribute to any specified sources. 24813955d011SMarcel Moolenaar.It Ic .NOTPARALLEL 24823955d011SMarcel MoolenaarDisable parallel mode. 24833955d011SMarcel Moolenaar.It Ic .NO_PARALLEL 24843955d011SMarcel MoolenaarSynonym for 24853955d011SMarcel Moolenaar.Ic .NOTPARALLEL , 24863955d011SMarcel Moolenaarfor compatibility with other pmake variants. 24874fde40d9SSimon J. Gerraty.It Ic .NOREADONLY 24884fde40d9SSimon J. Gerratyclear the read-only attribute from the global variables specified as sources. 2489128a4105SSimon J. Gerraty.It Ic .OBJDIR 2490128a4105SSimon J. GerratyThe source is a new value for 2491954401e6SSimon J. Gerraty.Sq Va .OBJDIR . 2492128a4105SSimon J. GerratyIf it exists, 2493128a4105SSimon J. Gerraty.Nm 24944fde40d9SSimon J. Gerratychanges the current working directory to it and updates the value of 2495954401e6SSimon J. Gerraty.Sq Va .OBJDIR . 24963955d011SMarcel Moolenaar.It Ic .ORDER 2497954401e6SSimon J. GerratyIn parallel mode, the named targets are made in sequence. 24983955d011SMarcel MoolenaarThis ordering does not add targets to the list of targets to be made. 2499954401e6SSimon J. Gerraty.Pp 25003955d011SMarcel MoolenaarSince the dependents of a target do not get built until the target itself 25013955d011SMarcel Moolenaarcould be built, unless 25023955d011SMarcel Moolenaar.Ql a 25033955d011SMarcel Moolenaaris built by another part of the dependency graph, 25043955d011SMarcel Moolenaarthe following is a dependency loop: 25053955d011SMarcel Moolenaar.Bd -literal 25063955d011SMarcel Moolenaar\&.ORDER: b a 25073955d011SMarcel Moolenaarb: a 25083955d011SMarcel Moolenaar.Ed 25093955d011SMarcel Moolenaar.Pp 25103955d011SMarcel Moolenaar.\" XXX: NOT YET!!!! 25113955d011SMarcel Moolenaar.\" .It Ic .PARALLEL 25123955d011SMarcel Moolenaar.\" The named targets are executed in parallel mode. 25133955d011SMarcel Moolenaar.\" If no targets are 25144fde40d9SSimon J. Gerraty.\" specified, all targets are executed in parallel mode. 25153955d011SMarcel Moolenaar.It Ic .PATH 25163955d011SMarcel MoolenaarThe sources are directories which are to be searched for files not 25173955d011SMarcel Moolenaarfound in the current directory. 25184fde40d9SSimon J. GerratyIf no sources are specified, 25194fde40d9SSimon J. Gerratyany previously specified directories are removed from the search path. 25203955d011SMarcel MoolenaarIf the source is the special 25213955d011SMarcel Moolenaar.Ic .DOTLAST 25224fde40d9SSimon J. Gerratytarget, the current working directory is searched last. 25234fde40d9SSimon J. Gerraty.It Ic .PATH. Ns Ar suffix 25241bbe5942SSimon J. GerratyLike 25251bbe5942SSimon J. Gerraty.Ic .PATH 25261bbe5942SSimon J. Gerratybut applies only to files with a particular suffix. 25271bbe5942SSimon J. GerratyThe suffix must have been previously declared with 25281bbe5942SSimon J. Gerraty.Ic .SUFFIXES . 25293955d011SMarcel Moolenaar.It Ic .PHONY 25303955d011SMarcel MoolenaarApply the 25313955d011SMarcel Moolenaar.Ic .PHONY 25323955d011SMarcel Moolenaarattribute to any specified sources. 25331d3f2ddcSSimon J. Gerraty.It Ic .POSIX 25342f2a5ecdSSimon J. GerratyIf this is the first non-comment line in the main makefile, 25352f2a5ecdSSimon J. Gerratythe variable 25361d3f2ddcSSimon J. Gerraty.Va %POSIX 25372f2a5ecdSSimon J. Gerratyis set to the value 25382f2a5ecdSSimon J. Gerraty.Ql 1003.2 25392f2a5ecdSSimon J. Gerratyand the makefile 25402f2a5ecdSSimon J. Gerraty.Ql <posix.mk> 25412f2a5ecdSSimon J. Gerratyis included if it exists, 25422f2a5ecdSSimon J. Gerratyto provide POSIX-compatible default rules. 25431d3f2ddcSSimon J. GerratyIf 25441d3f2ddcSSimon J. Gerraty.Nm 25451d3f2ddcSSimon J. Gerratyis run with the 25461d3f2ddcSSimon J. Gerraty.Fl r 25474fde40d9SSimon J. Gerratyflag, only 25481d3f2ddcSSimon J. Gerraty.Ql posix.mk 25494fde40d9SSimon J. Gerratycontributes to the default rules. 25503955d011SMarcel Moolenaar.It Ic .PRECIOUS 25513955d011SMarcel MoolenaarApply the 25523955d011SMarcel Moolenaar.Ic .PRECIOUS 25533955d011SMarcel Moolenaarattribute to any specified sources. 25543955d011SMarcel MoolenaarIf no sources are specified, the 25553955d011SMarcel Moolenaar.Ic .PRECIOUS 25564fde40d9SSimon J. Gerratyattribute is applied to every target in the file. 25574fde40d9SSimon J. Gerraty.It Ic .READONLY 25584fde40d9SSimon J. Gerratyset the read-only attribute on the global variables specified as sources. 25593955d011SMarcel Moolenaar.It Ic .SHELL 25603955d011SMarcel MoolenaarSets the shell that 25613955d011SMarcel Moolenaar.Nm 2562d5e0a182SSimon J. Gerratyuses to execute commands. 25633955d011SMarcel MoolenaarThe sources are a set of 25644fde40d9SSimon J. Gerraty.Ar field\| Ns Cm \&= Ns Ar value 25653955d011SMarcel Moolenaarpairs. 25664fde40d9SSimon J. Gerraty.Bl -tag -width ".Li hasErrCtls" 25674fde40d9SSimon J. Gerraty.It Li name 2568be19d90bSSimon J. GerratyThis is the minimal specification, used to select one of the built-in 25693955d011SMarcel Moolenaarshell specs; 25704fde40d9SSimon J. Gerraty.Li sh , 25714fde40d9SSimon J. Gerraty.Li ksh , 25723955d011SMarcel Moolenaarand 25734fde40d9SSimon J. Gerraty.Li csh . 25744fde40d9SSimon J. Gerraty.It Li path 25754fde40d9SSimon J. GerratySpecifies the absolute path to the shell. 25764fde40d9SSimon J. Gerraty.It Li hasErrCtl 25773955d011SMarcel MoolenaarIndicates whether the shell supports exit on error. 25784fde40d9SSimon J. Gerraty.It Li check 25793955d011SMarcel MoolenaarThe command to turn on error checking. 25804fde40d9SSimon J. Gerraty.It Li ignore 25813955d011SMarcel MoolenaarThe command to disable error checking. 25824fde40d9SSimon J. Gerraty.It Li echo 25833955d011SMarcel MoolenaarThe command to turn on echoing of commands executed. 25844fde40d9SSimon J. Gerraty.It Li quiet 25853955d011SMarcel MoolenaarThe command to turn off echoing of commands executed. 25864fde40d9SSimon J. Gerraty.It Li filter 25873955d011SMarcel MoolenaarThe output to filter after issuing the 25884fde40d9SSimon J. Gerraty.Li quiet 25893955d011SMarcel Moolenaarcommand. 25903955d011SMarcel MoolenaarIt is typically identical to 25914fde40d9SSimon J. Gerraty.Li quiet . 25924fde40d9SSimon J. Gerraty.It Li errFlag 25933955d011SMarcel MoolenaarThe flag to pass the shell to enable error checking. 25944fde40d9SSimon J. Gerraty.It Li echoFlag 25953955d011SMarcel MoolenaarThe flag to pass the shell to enable command echoing. 25964fde40d9SSimon J. Gerraty.It Li newline 25973955d011SMarcel MoolenaarThe string literal to pass the shell that results in a single newline 25983955d011SMarcel Moolenaarcharacter when used outside of any quoting characters. 25993955d011SMarcel Moolenaar.El 26003955d011SMarcel MoolenaarExample: 26013955d011SMarcel Moolenaar.Bd -literal 26023955d011SMarcel Moolenaar\&.SHELL: name=ksh path=/bin/ksh hasErrCtl=true \e 26033955d011SMarcel Moolenaar check="set \-e" ignore="set +e" \e 26043955d011SMarcel Moolenaar echo="set \-v" quiet="set +v" filter="set +v" \e 26053955d011SMarcel Moolenaar echoFlag=v errFlag=e newline="'\en'" 26063955d011SMarcel Moolenaar.Ed 26073955d011SMarcel Moolenaar.It Ic .SILENT 26083955d011SMarcel MoolenaarApply the 26093955d011SMarcel Moolenaar.Ic .SILENT 26103955d011SMarcel Moolenaarattribute to any specified sources. 26113955d011SMarcel MoolenaarIf no sources are specified, the 26123955d011SMarcel Moolenaar.Ic .SILENT 26133955d011SMarcel Moolenaarattribute is applied to every 26143955d011SMarcel Moolenaarcommand in the file. 26151748de26SSimon J. Gerraty.It Ic .STALE 26161748de26SSimon J. GerratyThis target gets run when a dependency file contains stale entries, having 26171748de26SSimon J. Gerraty.Va .ALLSRC 26181748de26SSimon J. Gerratyset to the name of that dependency file. 26193955d011SMarcel Moolenaar.It Ic .SUFFIXES 26203955d011SMarcel MoolenaarEach source specifies a suffix to 26213955d011SMarcel Moolenaar.Nm . 26223955d011SMarcel MoolenaarIf no sources are specified, any previously specified suffixes are deleted. 26233955d011SMarcel MoolenaarIt allows the creation of suffix-transformation rules. 26243955d011SMarcel Moolenaar.Pp 26253955d011SMarcel MoolenaarExample: 26263955d011SMarcel Moolenaar.Bd -literal 26274fde40d9SSimon J. Gerraty\&.SUFFIXES: .c .o 26283955d011SMarcel Moolenaar\&.c.o: 26293955d011SMarcel Moolenaar cc \-o ${.TARGET} \-c ${.IMPSRC} 26303955d011SMarcel Moolenaar.Ed 26314fde40d9SSimon J. Gerraty.It Ic .SYSPATH 26324fde40d9SSimon J. GerratyThe sources are directories which are to be added to the system 26334fde40d9SSimon J. Gerratyinclude path which 26344fde40d9SSimon J. Gerraty.Nm 26354fde40d9SSimon J. Gerratysearches for makefiles. 26364fde40d9SSimon J. GerratyIf no sources are specified, 26374fde40d9SSimon J. Gerratyany previously specified directories are removed from the system 26384fde40d9SSimon J. Gerratyinclude path. 26393955d011SMarcel Moolenaar.El 26403955d011SMarcel Moolenaar.Sh ENVIRONMENT 26413955d011SMarcel Moolenaar.Nm 26423955d011SMarcel Moolenaaruses the following environment variables, if they exist: 26433955d011SMarcel Moolenaar.Ev MACHINE , 26443955d011SMarcel Moolenaar.Ev MACHINE_ARCH , 26453955d011SMarcel Moolenaar.Ev MAKE , 26463955d011SMarcel Moolenaar.Ev MAKEFLAGS , 26473955d011SMarcel Moolenaar.Ev MAKEOBJDIR , 26483955d011SMarcel Moolenaar.Ev MAKEOBJDIRPREFIX , 26493955d011SMarcel Moolenaar.Ev MAKESYSPATH , 26503955d011SMarcel Moolenaar.Ev PWD , 26513955d011SMarcel Moolenaarand 26523955d011SMarcel Moolenaar.Ev TMPDIR . 26533955d011SMarcel Moolenaar.Pp 26543955d011SMarcel Moolenaar.Ev MAKEOBJDIRPREFIX 26553955d011SMarcel Moolenaarand 26563955d011SMarcel Moolenaar.Ev MAKEOBJDIR 2657*6a7405f5SSimon J. Gerratyshould be set in the environment or on the command line to 26583955d011SMarcel Moolenaar.Nm 26593955d011SMarcel Moolenaarand not as makefile variables; 26603955d011SMarcel Moolenaarsee the description of 2661954401e6SSimon J. Gerraty.Sq Va .OBJDIR 26623955d011SMarcel Moolenaarfor more details. 2663*6a7405f5SSimon J. GerratyIt is possible to set these via makefile variables but unless done 2664*6a7405f5SSimon J. Gerratyvery early and the 2665*6a7405f5SSimon J. Gerraty.Sq Ic .OBJDIR 2666*6a7405f5SSimon J. Gerratytarget is used to reset 2667*6a7405f5SSimon J. Gerraty.Sq Va .OBJDIR , 2668*6a7405f5SSimon J. Gerratythere may be unexpected side effects. 26693955d011SMarcel Moolenaar.Sh FILES 26703955d011SMarcel Moolenaar.Bl -tag -width /usr/share/mk -compact 26713955d011SMarcel Moolenaar.It .depend 26723955d011SMarcel Moolenaarlist of dependencies 26733955d011SMarcel Moolenaar.It makefile 26744fde40d9SSimon J. Gerratyfirst default makefile if no makefile is specified on the command line 26754fde40d9SSimon J. Gerraty.It Makefile 26764fde40d9SSimon J. Gerratysecond default makefile if no makefile is specified on the command line 26773955d011SMarcel Moolenaar.It sys.mk 26783955d011SMarcel Moolenaarsystem makefile 26793955d011SMarcel Moolenaar.It /usr/share/mk 26803955d011SMarcel Moolenaarsystem makefile directory 26813955d011SMarcel Moolenaar.El 26823955d011SMarcel Moolenaar.Sh COMPATIBILITY 26834fde40d9SSimon J. GerratyThe basic make syntax is compatible between different make variants; 26843955d011SMarcel Moolenaarhowever the special variables, variable modifiers and conditionals are not. 2685db29cad8SSimon J. Gerraty.Ss Older versions 2686db29cad8SSimon J. GerratyAn incomplete list of changes in older versions of 2687db29cad8SSimon J. Gerraty.Nm : 26883955d011SMarcel Moolenaar.Pp 26893955d011SMarcel MoolenaarThe way that .for loop variables are substituted changed after 26903955d011SMarcel Moolenaar.Nx 5.0 26913955d011SMarcel Moolenaarso that they still appear to be variable expansions. 26923955d011SMarcel MoolenaarIn particular this stops them being treated as syntax, and removes some 26933955d011SMarcel Moolenaarobscure problems using them in .if statements. 2694db29cad8SSimon J. Gerraty.Pp 2695db29cad8SSimon J. GerratyThe way that parallel makes are scheduled changed in 2696db29cad8SSimon J. Gerraty.Nx 4.0 2697db29cad8SSimon J. Gerratyso that .ORDER and .WAIT apply recursively to the dependent nodes. 2698db29cad8SSimon J. GerratyThe algorithms used may change again in the future. 2699db29cad8SSimon J. Gerraty.Ss Other make dialects 2700db29cad8SSimon J. GerratyOther make dialects (GNU make, SVR4 make, POSIX make, etc.) do not 2701db29cad8SSimon J. Gerratysupport most of the features of 2702db29cad8SSimon J. Gerraty.Nm 2703db29cad8SSimon J. Gerratyas described in this manual. 2704db29cad8SSimon J. GerratyMost notably: 2705db29cad8SSimon J. Gerraty.Bl -bullet -offset indent 2706db29cad8SSimon J. Gerraty.It 2707db29cad8SSimon J. GerratyThe 2708db29cad8SSimon J. Gerraty.Ic .WAIT 2709db29cad8SSimon J. Gerratyand 2710db29cad8SSimon J. Gerraty.Ic .ORDER 2711db29cad8SSimon J. Gerratydeclarations and most functionality pertaining to parallelization. 27124fde40d9SSimon J. Gerraty(GNU make supports parallelization but lacks the features needed to 2713db29cad8SSimon J. Gerratycontrol it effectively.) 2714db29cad8SSimon J. Gerraty.It 2715db29cad8SSimon J. GerratyDirectives, including for loops and conditionals and most of the 2716db29cad8SSimon J. Gerratyforms of include files. 2717db29cad8SSimon J. Gerraty(GNU make has its own incompatible and less powerful syntax for 2718db29cad8SSimon J. Gerratyconditionals.) 27194fde40d9SSimon J. Gerraty.\" The "less powerful" above means that GNU make does not have the 27204fde40d9SSimon J. Gerraty.\" make(target), target(target) and commands(target) functions. 2721db29cad8SSimon J. Gerraty.It 2722db29cad8SSimon J. GerratyAll built-in variables that begin with a dot. 2723db29cad8SSimon J. Gerraty.It 2724db29cad8SSimon J. GerratyMost of the special sources and targets that begin with a dot, 2725db29cad8SSimon J. Gerratywith the notable exception of 2726db29cad8SSimon J. Gerraty.Ic .PHONY , 2727db29cad8SSimon J. Gerraty.Ic .PRECIOUS , 2728db29cad8SSimon J. Gerratyand 2729db29cad8SSimon J. Gerraty.Ic .SUFFIXES . 2730db29cad8SSimon J. Gerraty.It 2731db29cad8SSimon J. GerratyVariable modifiers, except for the 27324fde40d9SSimon J. Gerraty.Ql :old=new 2733db29cad8SSimon J. Gerratystring substitution, which does not portably support globbing with 2734db29cad8SSimon J. Gerraty.Ql % 2735db29cad8SSimon J. Gerratyand historically only works on declared suffixes. 2736db29cad8SSimon J. Gerraty.It 2737db29cad8SSimon J. GerratyThe 2738db29cad8SSimon J. Gerraty.Ic $> 2739db29cad8SSimon J. Gerratyvariable even in its short form; most makes support this functionality 2740db29cad8SSimon J. Gerratybut its name varies. 2741db29cad8SSimon J. Gerraty.El 2742db29cad8SSimon J. Gerraty.Pp 2743db29cad8SSimon J. GerratySome features are somewhat more portable, such as assignment with 2744db29cad8SSimon J. Gerraty.Ic += , 2745db29cad8SSimon J. Gerraty.Ic ?= , 2746db29cad8SSimon J. Gerratyand 2747db29cad8SSimon J. Gerraty.Ic != . 2748db29cad8SSimon J. GerratyThe 27494fde40d9SSimon J. Gerraty.Va .PATH 2750db29cad8SSimon J. Gerratyfunctionality is based on an older feature 2751db29cad8SSimon J. Gerraty.Ic VPATH 2752db29cad8SSimon J. Gerratyfound in GNU make and many versions of SVR4 make; however, 2753db29cad8SSimon J. Gerratyhistorically its behavior is too ill-defined (and too buggy) to rely 2754db29cad8SSimon J. Gerratyupon. 2755db29cad8SSimon J. Gerraty.Pp 2756db29cad8SSimon J. GerratyThe 2757db29cad8SSimon J. Gerraty.Ic $@ 2758db29cad8SSimon J. Gerratyand 2759db29cad8SSimon J. Gerraty.Ic $< 2760db29cad8SSimon J. Gerratyvariables are more or less universally portable, as is the 2761db29cad8SSimon J. Gerraty.Ic $(MAKE) 2762db29cad8SSimon J. Gerratyvariable. 2763db29cad8SSimon J. GerratyBasic use of suffix rules (for files only in the current directory, 2764db29cad8SSimon J. Gerratynot trying to chain transformations together, etc.) is also reasonably 2765db29cad8SSimon J. Gerratyportable. 27663955d011SMarcel Moolenaar.Sh SEE ALSO 27673d31df21SMateusz Piotrowski.Xr mkdep 1 , 27683d31df21SMateusz Piotrowski.Xr style.Makefile 5 27693955d011SMarcel Moolenaar.Sh HISTORY 27703955d011SMarcel MoolenaarA 27713955d011SMarcel Moolenaar.Nm 27723955d011SMarcel Moolenaarcommand appeared in 27733955d011SMarcel Moolenaar.At v7 . 27743955d011SMarcel MoolenaarThis 27753955d011SMarcel Moolenaar.Nm 27764fde40d9SSimon J. Gerratyimplementation is based on Adam de Boor's pmake program, 27774fde40d9SSimon J. Gerratywhich was written for Sprite at Berkeley. 27783955d011SMarcel MoolenaarIt was designed to be a parallel distributed make running jobs on different 27793955d011SMarcel Moolenaarmachines using a daemon called 27803955d011SMarcel Moolenaar.Dq customs . 278174d2e02bSSimon J. Gerraty.Pp 278274d2e02bSSimon J. GerratyHistorically the target/dependency 27834fde40d9SSimon J. Gerraty.Ic FRC 278474d2e02bSSimon J. Gerratyhas been used to FoRCe rebuilding (since the target/dependency 278574d2e02bSSimon J. Gerratydoes not exist ... unless someone creates an 27864fde40d9SSimon J. Gerraty.Pa FRC 278774d2e02bSSimon J. Gerratyfile). 27883955d011SMarcel Moolenaar.Sh BUGS 27893955d011SMarcel MoolenaarThe 27903955d011SMarcel Moolenaar.Nm 27914fde40d9SSimon J. Gerratysyntax is difficult to parse. 279249caa483SSimon J. GerratyFor instance, finding the end of a variable's use should involve scanning 279349caa483SSimon J. Gerratyeach of the modifiers, using the correct terminator for each field. 27943955d011SMarcel MoolenaarIn many places 27953955d011SMarcel Moolenaar.Nm 27963955d011SMarcel Moolenaarjust counts {} and () in order to find the end of a variable expansion. 27973955d011SMarcel Moolenaar.Pp 27983955d011SMarcel MoolenaarThere is no way of escaping a space character in a filename. 27998c973ee2SSimon J. Gerraty.Pp 28008c973ee2SSimon J. GerratyIn jobs mode, when a target fails; 28018c973ee2SSimon J. Gerraty.Nm 28028c973ee2SSimon J. Gerratywill put an error token into the job token pool. 28038c973ee2SSimon J. GerratyThis will cause all other instances of 28048c973ee2SSimon J. Gerraty.Nm 28058c973ee2SSimon J. Gerratyusing that token pool to abort the build and exit with error code 6. 28068c973ee2SSimon J. GerratySometimes the attempt to suppress a cascade of unnecessary errors, 28078c973ee2SSimon J. Gerratycan result in a seemingly unexplained 28088c973ee2SSimon J. Gerraty.Ql *** Error code 6 2809