⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 make.1

📁 早期freebsd实现
💻 1
📖 第 1 页 / 共 2 页
字号:
.\" Copyright (c) 1990, 1993.\"	The Regents of the University of California.  All rights reserved..\".\" Redistribution and use in source and binary forms, with or without.\" modification, are permitted provided that the following conditions.\" are met:.\" 1. Redistributions of source code must retain the above copyright.\"    notice, this list of conditions and the following disclaimer..\" 2. Redistributions in binary form must reproduce the above copyright.\"    notice, this list of conditions and the following disclaimer in the.\"    documentation and/or other materials provided with the distribution..\" 3. All advertising materials mentioning features or use of this software.\"    must display the following acknowledgement:.\"	This product includes software developed by the University of.\"	California, Berkeley and its contributors..\" 4. Neither the name of the University nor the names of its contributors.\"    may be used to endorse or promote products derived from this software.\"    without specific prior written permission..\".\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION).\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF.\" SUCH DAMAGE..\".\"	@(#)make.1	8.4 (Berkeley) 3/19/94.\".Dd March 19, 1994.Dt MAKE 1.Os.Sh NAME.Nm make.Nd maintain program dependencies.Sh SYNOPSIS.Nm make.Op Fl eiknqrstv.Op Fl D Ar variable.Op Fl d Ar flags.Op Fl f Ar makefile.Op Fl I Ar directory.Bk -words.Op Fl j Ar max_jobs.Ek.Op Ar variable=value.Op Ar target ....Sh DESCRIPTION.Nm Makeis a program designed to simplify the maintenance of other programs.Its input is a list of specifications as to the files upon which programsand other files depend.If the file.Ql Pa makefileexists, it is read for this list of specifications.If it does not exist, the file.Ql Pa Makefileis read.If the file.Ql Pa .dependexists, it is read (see.Xr mkdep 1) ..PpThis manual page is intended as a reference document only.For a more thorough description of.Nm makeand makefiles, please refer to.%T "Make \- A Tutorial" ..PpThe options are as follows:.Bl -tag -width Ds.It Fl D Ar variableDefine Ar variableto be 1, in the global context..It Fl d Ar flagsTurn on debugging, and specify which portions of.Nm makeare to print debugging information..Ar Flagsis one or more of the following:.Bl -tag -width Ds.It Ar APrint all possible debugging information;equivalent to specifying all of the debugging flags..It Ar aPrint debugging information about archive searching and caching..It Ar cPrint debugging information about conditional evaluation..It Ar dPrint debugging information about directory searching and caching..It Ar "g1"Print the input graph before making anything..It Ar "g2"Print the input graph after making everything, or before exitingon error..It Ar jPrint debugging information about running multiple shells..It Ar mPrint debugging information about making targets, including modificationdates..It Ar sPrint debugging information about suffix-transformation rules..It Ar tPrint debugging information about target list maintenance..It Ar vPrint debugging information about variable assignment..El.It Fl eSpecify that environmental variables override macro assignments withinmakefiles..It Fl f Ar makefileSpecify a makefile to read instead of the default.Ql Pa makefileand.Ql Pa Makefile .If.Ar makefileis.Ql Fl ,standard input is read.Multiple makefile's may be specified, and are read in the order specified..It Fl I Ar directorySpecify a directory in which to search for makefiles and included makefiles.The system makefile directory is automatically included as part of thislist..It Fl iIgnore non-zero exit of shell commands in the makefile.Equivalent to specifying.Ql Flbefore each command line in the makefile..It Fl j Ar max_jobsSpecify the maximum number of jobs that.Nm makemay have running at any one time..It Fl kContinue processing after errors are encountered, but only on those targetsthat do not depend on the target whose creation caused the error..It Fl nDisplay the commands that would have been executed, but do not actuallyexecute them..It Fl qDo not execute any commands, but exit 0 if the specified targets areup-to-date and 1, otherwise..It Fl rDo not use the built-in rules specified in the system makefile..It Fl sDo not echo any commands as they are executed.Equivalent to specifying.Ql Ic @before each command line in the makefile..It Fl tRather than re-building a target as specified in the makefile, create itor update its modification time to make it appear up-to-date..It Ar variable=valueSet the value of the variable.Ar variableto.Ar value ..El.PpThere are seven different types of lines in a makefile: file dependencyspecifications, shell commands, variable assignments, include statements,conditional directives, for loops, and comments..PpIn general, lines may be continued from one line to the next by endingthem with a backslash.Pq Ql \e .The trailing newline character and initial whitespace on the followingline are compressed into a single space..Sh FILE DEPENDENCY SPECIFICATIONSDependency lines consist of one or more targets, an operator, and zeroor more sources.This creates a relationship where the targets ``depend'' on the sourcesand are usually created from them.The exact relationship between the target and the source is determinedby the operator that separates them.The three operators are as follows:.Bl -tag -width flag.It Ic \&:A target is considered out-of-date if its modification time is less thanthose of any of its sources.Sources for a target accumulate over dependency lines when this operatoris used.The target is removed if.Nm makeis interrupted..It Ic \&!Targets are always re-created, but not until all sources have beenexamined and re-created as necessary.Sources for a target accumulate over dependency lines when this operatoris used.The target is removed if.Nm makeis interrupted..It Ic \&::If no sources are specified, the target is always re-created.Otherwise, a target is considered out-of-date if any of its sources hasbeen modified more recently than the target.Sources for a target do not accumulate over dependency lines when thisoperator is used.The target will not be removed if.Nm makeis interrupted..El.PpTargets and sources may contain the shell wildcard values.Ql ? ,.Ql * ,.Ql []and.Ql {} .The values.Ql ? ,.Ql *and.Ql []may only be used as part of the finalcomponent of the target or source, and must be used to describe existingfiles.The value.Ql {}need not necessarily be used to describe existing files.Expansion is in directory order, not alphabetically as done in the shell..Sh SHELL COMMANDSEach target may have associated with it a series of shell commands, normallyused to create the target.Each of the commands in this script.Em mustbe preceded by a tab.While any target may appear on a dependency line, only one of thesedependencies may be followed by a creation script, unless the.Ql Ic ::operator is used..PpIf the first or first two characters of the command line are.Ql Ic @and/or.Ql Ic \- ,the command is treated specially.A.Ql Ic @causes the command not to be echoed before it is executed.A.Ql Ic \-causes any non-zero exit status of the command line to be ignored..Sh VARIABLE ASSIGNMENTSVariables in make are much like variables in the shell, and, by tradition,consist of all upper-case letters.The five operators that can be used to assign values to variables are asfollows:.Bl -tag -width Ds.It Ic \&=Assign the value to the variable.Any previous value is overridden..It Ic \&+=Append the value to the current value of the variable..It Ic \&?=Assign the value to the variable if it is not already defined..It Ic \&:=Assign with expansion, i.e. expand the value before assigning itto the variable.Normally, expansion is not done until the variable is referenced..It Ic \&!=Expand the value and pass it to the shell for execution and assignthe result to the variable.Any newlines in the result are replaced with spaces..El.PpAny white-space before the assigned.Ar valueis removed; if the value is being appended, a single space is insertedbetween the previous contents of the variable and the appended value..PpVariables are expanded by surrounding the variable name with eithercurly braces.Pq Ql {}or parenthesis.Pq Ql ()and preceding it witha dollar sign.Pq Ql \&$ .If the variable name contains only a single letter, the surroundingbraces or parenthesis are not required.This shorter form is not recommended..PpVariable substitution occurs at two distinct times, depending on wherethe variable is being used.Variables in dependency lines are expanded as the line is read.Variables in shell commands are expanded when the shell command isexecuted..PpThe four different classes of variables (in order of increasing precedence)are:.Bl -tag -width Ds.It Environment variablesVariables defined as part of.Nm make Ns 'senvironment..It Global variablesVariables defined in the makefile or in included makefiles..It Command line variablesVariables defined as part of the command line..It Local variablesVariables that are defined specific to a certain target.The seven local variables are as follows:.Bl -tag -width ".ARCHIVE".It Va .ALLSRCThe list of all sources for this target; also known as.Ql Va \&> ..It Va .ARCHIVEThe name of the archive file..It Va .IMPSRCThe name/path of the source from which the target is to be transformed(the ``implied'' source); also known as.Ql Va \&< ..It Va .MEMBERThe name of the archive member..It Va .OODATEThe list of sources for this target that were deemed out-of-date; alsoknown as.Ql Va \&? ..It Va .PREFIXThe file prefix of the file, containing only the file portion, no suffixor preceding directory components; also known as.Ql Va * ..It Va .TARGETThe name of the target; also known as.Ql Va @ ..El.PpThe shorter forms.Ql Va @ ,.Ql Va ? ,.Ql Va \&>and.Ql Va *are permitted for backwardcompatibility with historical makefiles and are not recommended.The six variables.Ql Va "@F" ,.Ql Va "@D" ,.Ql Va "<F" ,.Ql Va "<D" ,.Ql Va "*F"and.Ql Va "*D"arepermitted for compatibility with.At Vmakefiles and are not recommended..PpFour of the local variables may be used in sources on dependency linesbecause they expand to the proper value for each target on the line.These variables are.Ql Va .TARGET ,.Ql Va .PREFIX ,.Ql Va .ARCHIVE ,and.Ql Va .MEMBER ..PpIn addition,.Nm makesets or knows about the following variables:.Bl -tag -width MAKEFLAGS.It Va \&$A single dollar sign.Ql \&$ ,i.e..Ql \&$$expands to a single dollarsign..It Va .MAKEThe name that.Nm makewas executed with.Pq Va argv Op 0.It Va .CURDIRA path to the directory where.Nm makewas executed..It Va .OBJDIRA path to the directory where the targets are built..It Ev MAKEFLAGSThe environment variable.Ql Ev MAKEFLAGSmay contain anything thatmay be specified on.Nm make Ns 'scommand line.Anything specified on.Nm make Ns 'scommand line is appended to the.Ql Ev MAKEFLAGSvariable which is thenentered into the environment for all programs which.Nm makeexecutes..El.PpVariable expansion may be modified to select or modify each word of thevariable (where a ``word'' is white-space delimited sequence of characters).The general format of a variable expansion is as follows:.Pp.Dl {variable[:modifier[:...]]}.PpEach modifier begins with a colon and one of the followingspecial characters.The colon may be escaped with a backslash.Pq Ql \e ..Bl -tag -width Cm E\&.It Cm EReplaces each word in the variable with its suffix..It Cm HReplaces each word in the variable with everything but the last component..It Cm M Ns Ar patternSelect only those words that match the rest of the modifier.The standard shell wildcard characters.Pf ( Ql * ,.Ql ? ,and.Ql Op )maybe used.The wildcard characters may be escaped with a backslash.Pq Ql \e ..It Cm N Ns Ar patternThis is identical to.Ql Cm M ,but selects all words which do not matchthe rest of the modifier..It Cm RReplaces each word in the variable with everything but its suffix..Sm off.It Cm S No \&/ Ar old_pattern Xo.No \&/ Ar new_pattern.No \&/ Op Cm g.Xc.Sm on

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -