mirror of
https://git.savannah.gnu.org/git/make.git
synced 2025-01-24 16:33:40 +00:00
Convert all "`'" quotes to "''" per new GNU Coding Standard guidelines.
Fixes Savannah bug #34530.
This commit is contained in:
parent
405c89ba1e
commit
23c2b99e9d
89 changed files with 634 additions and 631 deletions
|
@ -1,5 +1,8 @@
|
||||||
2012-03-03 Paul Smith <psmith@gnu.org>
|
2012-03-03 Paul Smith <psmith@gnu.org>
|
||||||
|
|
||||||
|
Convert uses of `foo' for quoting to 'foo' to reflect changes in
|
||||||
|
the GNU Coding Standards. Fixes Savannah bug #34530.
|
||||||
|
|
||||||
* job.c (construct_command_argv_internal): In oneshell we need to
|
* job.c (construct_command_argv_internal): In oneshell we need to
|
||||||
break the SHELLFLAGS up for argv. Fixes Savannah bug #35397.
|
break the SHELLFLAGS up for argv. Fixes Savannah bug #35397.
|
||||||
|
|
||||||
|
|
|
@ -107,8 +107,8 @@ localedir = $(datadir)/locale
|
||||||
#
|
#
|
||||||
|
|
||||||
# Whether or not make needs to be installed setgid.
|
# Whether or not make needs to be installed setgid.
|
||||||
# The value should be either `true' or `false'.
|
# The value should be either 'true' or 'false'.
|
||||||
# On many systems, the getloadavg function (used to implement the `-l'
|
# On many systems, the getloadavg function (used to implement the '-l'
|
||||||
# switch) will not work unless make is installed setgid kmem.
|
# switch) will not work unless make is installed setgid kmem.
|
||||||
#
|
#
|
||||||
inst_setgid = @NEED_SETGID@
|
inst_setgid = @NEED_SETGID@
|
||||||
|
@ -124,7 +124,7 @@ install-exec-local:
|
||||||
echo "chgrp $(inst_group) $$app && chmod g+s $$app"; \
|
echo "chgrp $(inst_group) $$app && chmod g+s $$app"; \
|
||||||
else \
|
else \
|
||||||
echo "$$app needs to be owned by group $(inst_group) and setgid;"; \
|
echo "$$app needs to be owned by group $(inst_group) and setgid;"; \
|
||||||
echo "otherwise the \`-l' option will probably not work."; \
|
echo "otherwise the '-l' option will probably not work."; \
|
||||||
echo "You may need special privileges to complete the installation"; \
|
echo "You may need special privileges to complete the installation"; \
|
||||||
echo "of $$app."; \
|
echo "of $$app."; \
|
||||||
fi; \
|
fi; \
|
||||||
|
|
36
Makefile.ami
36
Makefile.ami
|
@ -1,7 +1,7 @@
|
||||||
# -*-Makefile-*- for GNU make on Amiga
|
# -*-Makefile-*- for GNU make on Amiga
|
||||||
#
|
#
|
||||||
# NOTE: If you have no `make' program at all to process this makefile, run
|
# NOTE: If you have no 'make' program at all to process this makefile, run
|
||||||
# `build.sh' instead.
|
# 'build.sh' instead.
|
||||||
#
|
#
|
||||||
# Copyright (C) 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
# Copyright (C) 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
||||||
# 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 Free Software Foundation, Inc.
|
# 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 Free Software Foundation, Inc.
|
||||||
|
@ -32,18 +32,18 @@ CPPFLAGS =
|
||||||
LDFLAGS =
|
LDFLAGS =
|
||||||
|
|
||||||
# Define these for your system as follows:
|
# Define these for your system as follows:
|
||||||
# -DNO_ARCHIVES To disable `ar' archive support.
|
# -DNO_ARCHIVES To disable 'ar' archive support.
|
||||||
# -DNO_FLOAT To avoid using floating-point numbers.
|
# -DNO_FLOAT To avoid using floating-point numbers.
|
||||||
# -DENUM_BITFIELDS If the compiler isn't GCC but groks enum foo:2.
|
# -DENUM_BITFIELDS If the compiler isn't GCC but groks enum foo:2.
|
||||||
# Some compilers apparently accept this
|
# Some compilers apparently accept this
|
||||||
# without complaint but produce losing code,
|
# without complaint but produce losing code,
|
||||||
# so beware.
|
# so beware.
|
||||||
# NeXT 1.0a uses an old version of GCC, which required -D__inline=inline.
|
# NeXT 1.0a uses an old version of GCC, which required -D__inline=inline.
|
||||||
# See also `config.h'.
|
# See also 'config.h'.
|
||||||
defines =
|
defines =
|
||||||
|
|
||||||
# Which flavor of remote job execution support to use.
|
# Which flavor of remote job execution support to use.
|
||||||
# The code is found in `remote-$(REMOTE).c'.
|
# The code is found in 'remote-$(REMOTE).c'.
|
||||||
REMOTE = stub
|
REMOTE = stub
|
||||||
|
|
||||||
# If you are using the GNU C library, or have the GNU getopt functions in
|
# If you are using the GNU C library, or have the GNU getopt functions in
|
||||||
|
@ -77,9 +77,9 @@ prefix =
|
||||||
# Common prefix for machine-dependent installed files.
|
# Common prefix for machine-dependent installed files.
|
||||||
exec_prefix =
|
exec_prefix =
|
||||||
|
|
||||||
# Directory to install `make' in.
|
# Directory to install 'make' in.
|
||||||
bindir = sc:c
|
bindir = sc:c
|
||||||
# Directory to find libraries in for `-lXXX'.
|
# Directory to find libraries in for '-lXXX'.
|
||||||
libdir = lib:
|
libdir = lib:
|
||||||
# Directory to search by default for included makefiles.
|
# Directory to search by default for included makefiles.
|
||||||
includedir = include:
|
includedir = include:
|
||||||
|
@ -89,20 +89,20 @@ infodir = doc:
|
||||||
mandir = t:
|
mandir = t:
|
||||||
# Number to put on the man page filename.
|
# Number to put on the man page filename.
|
||||||
manext = 1
|
manext = 1
|
||||||
# Prefix to put on installed `make' binary file name.
|
# Prefix to put on installed 'make' binary file name.
|
||||||
binprefix =
|
binprefix =
|
||||||
# Prefix to put on installed `make' man page file name.
|
# Prefix to put on installed 'make' man page file name.
|
||||||
manprefix = $(binprefix)
|
manprefix = $(binprefix)
|
||||||
|
|
||||||
# Whether or not make needs to be installed setgid.
|
# Whether or not make needs to be installed setgid.
|
||||||
# The value should be either `true' or `false'.
|
# The value should be either 'true' or 'false'.
|
||||||
# On many systems, the getloadavg function (used to implement the `-l'
|
# On many systems, the getloadavg function (used to implement the '-l'
|
||||||
# switch) will not work unless make is installed setgid kmem.
|
# switch) will not work unless make is installed setgid kmem.
|
||||||
install_setgid = false
|
install_setgid = false
|
||||||
# Install make setgid to this group so it can read /dev/kmem.
|
# Install make setgid to this group so it can read /dev/kmem.
|
||||||
group = sys
|
group = sys
|
||||||
|
|
||||||
# Program to install `make'.
|
# Program to install 'make'.
|
||||||
INSTALL_PROGRAM = copy
|
INSTALL_PROGRAM = copy
|
||||||
# Program to install the man page.
|
# Program to install the man page.
|
||||||
INSTALL_DATA = copy
|
INSTALL_DATA = copy
|
||||||
|
@ -145,7 +145,7 @@ srcs = $(srcdir)commands.c $(srcdir)job.c $(srcdir)dir.c \
|
||||||
all: make
|
all: make
|
||||||
info: make.info
|
info: make.info
|
||||||
dvi: make.dvi
|
dvi: make.dvi
|
||||||
# Some makes apparently use .PHONY as the default goal if it is before `all'.
|
# Some makes apparently use .PHONY as the default goal if it is before 'all'.
|
||||||
.PHONY: all check info dvi
|
.PHONY: all check info dvi
|
||||||
|
|
||||||
make.info: make.texinfo
|
make.info: make.texinfo
|
||||||
|
@ -197,7 +197,7 @@ $(bindir)$(binprefix)make: make
|
||||||
echo "chgrp $(group) $@.new && chmod g+s $@.new"; \
|
echo "chgrp $(group) $@.new && chmod g+s $@.new"; \
|
||||||
else \
|
else \
|
||||||
echo "$@ needs to be owned by group $(group) and setgid;"; \
|
echo "$@ needs to be owned by group $(group) and setgid;"; \
|
||||||
echo "otherwise the \`-l' option will probably not work."; \
|
echo "otherwise the '-l' option will probably not work."; \
|
||||||
echo "You may need special privileges to install $@."; \
|
echo "You may need special privileges to install $@."; \
|
||||||
fi; \
|
fi; \
|
||||||
else true; fi
|
else true; fi
|
||||||
|
@ -214,9 +214,9 @@ $(infodir)make.info: make.info
|
||||||
`echo $@ | sed "s,make.info\$$,$$name,"`; \
|
`echo $@ | sed "s,make.info\$$,$$name,"`; \
|
||||||
done
|
done
|
||||||
# Run install-info only if it exists.
|
# Run install-info only if it exists.
|
||||||
# Use `if' instead of just prepending `-' to the
|
# Use 'if' instead of just prepending '-' to the
|
||||||
# line so we notice real errors from install-info.
|
# line so we notice real errors from install-info.
|
||||||
# We use `$(SHELL) -c' because some shells do not
|
# We use '$(SHELL) -c' because some shells do not
|
||||||
# fail gracefully when there is an unknown command.
|
# fail gracefully when there is an unknown command.
|
||||||
if $(SHELL) -c 'install-info --version' >/dev/null 2>&1; then \
|
if $(SHELL) -c 'install-info --version' >/dev/null 2>&1; then \
|
||||||
if [ -r ./make.info ]; then dir=.; else dir=$(srcdir); fi; \
|
if [ -r ./make.info ]; then dir=.; else dir=$(srcdir); fi; \
|
||||||
|
@ -267,8 +267,8 @@ glob-clean glob-realclean:
|
||||||
.NOEXPORT:
|
.NOEXPORT:
|
||||||
|
|
||||||
# The automatically generated dependencies below may omit config.h
|
# The automatically generated dependencies below may omit config.h
|
||||||
# because it is included with ``#include <config.h>'' rather than
|
# because it is included with '#include <config.h>' rather than
|
||||||
# ``#include "config.h"''. So we add the explicit dependency to make sure.
|
# '#include "config.h"'. So we add the explicit dependency to make sure.
|
||||||
$(objs): config.h
|
$(objs): config.h
|
||||||
|
|
||||||
# Automatically generated dependencies will be put at the end of the file.
|
# Automatically generated dependencies will be put at the end of the file.
|
||||||
|
|
|
@ -8,12 +8,12 @@ New (since 3.74) DOS-specific features:
|
||||||
1. Supports long filenames when run from DOS box on Windows 9x.
|
1. Supports long filenames when run from DOS box on Windows 9x.
|
||||||
|
|
||||||
2. Supports both stock DOS COMMAND.COM and Unix-style shells
|
2. Supports both stock DOS COMMAND.COM and Unix-style shells
|
||||||
(details in ``Notes'' below).
|
(details in 'Notes' below).
|
||||||
|
|
||||||
3. Supports DOS drive letters in dependencies and pattern rules.
|
3. Supports DOS drive letters in dependencies and pattern rules.
|
||||||
|
|
||||||
4. Better support for DOS-style backslashes in pathnames (but see
|
4. Better support for DOS-style backslashes in pathnames (but see
|
||||||
``Notes'' below).
|
'Notes' below).
|
||||||
|
|
||||||
5. The $(shell) built-in can run arbitrary complex commands,
|
5. The $(shell) built-in can run arbitrary complex commands,
|
||||||
including pipes and redirection, even when COMMAND.COM is your
|
including pipes and redirection, even when COMMAND.COM is your
|
||||||
|
@ -55,7 +55,7 @@ To build from sources:
|
||||||
either DJTAR (which is part of the DJGPP development
|
either DJTAR (which is part of the DJGPP development
|
||||||
environment), or the DJGPP port of GNU Tar.
|
environment), or the DJGPP port of GNU Tar.
|
||||||
|
|
||||||
2. Invoke the `configure.bat' batch file.
|
2. Invoke the 'configure.bat' batch file.
|
||||||
|
|
||||||
If you are building Make in-place, i.e. in the same directory
|
If you are building Make in-place, i.e. in the same directory
|
||||||
where its sources are kept, just type "configure.bat" and press
|
where its sources are kept, just type "configure.bat" and press
|
||||||
|
@ -68,7 +68,7 @@ To build from sources:
|
||||||
use them here.
|
use them here.
|
||||||
|
|
||||||
3. If configure.bat doesn't find a working Make, it will suggest to
|
3. If configure.bat doesn't find a working Make, it will suggest to
|
||||||
use the `dosbuild.bat' batch file to build Make. Either do as it
|
use the 'dosbuild.bat' batch file to build Make. Either do as it
|
||||||
suggests or install another Make program (a pre-compiled binary
|
suggests or install another Make program (a pre-compiled binary
|
||||||
should be available from the usual DJGPP sites) and rerun
|
should be available from the usual DJGPP sites) and rerun
|
||||||
configure.bat.
|
configure.bat.
|
||||||
|
@ -91,7 +91,7 @@ To build from sources:
|
||||||
else Make might fail.
|
else Make might fail.
|
||||||
|
|
||||||
6. After Make finishes, if you have a Unix-style shell installed,
|
6. After Make finishes, if you have a Unix-style shell installed,
|
||||||
you can use the `install' target to install the package. You
|
you can use the 'install' target to install the package. You
|
||||||
will also need GNU Fileutils and GNU Sed for this (they should
|
will also need GNU Fileutils and GNU Sed for this (they should
|
||||||
be available from the DJGPP sites).
|
be available from the DJGPP sites).
|
||||||
|
|
||||||
|
@ -107,12 +107,12 @@ To build from sources:
|
||||||
Without a Unix-style shell, you will have to install programs
|
Without a Unix-style shell, you will have to install programs
|
||||||
and the docs manually. Copy make.exe to a directory on your
|
and the docs manually. Copy make.exe to a directory on your
|
||||||
PATH, make.i* info files to your Info directory, and update the
|
PATH, make.i* info files to your Info directory, and update the
|
||||||
file `dir' in your Info directory by adding the following item
|
file 'dir' in your Info directory by adding the following item
|
||||||
to the main menu:
|
to the main menu:
|
||||||
|
|
||||||
* Make: (make.info). The GNU make utility.
|
* Make: (make.info). The GNU make utility.
|
||||||
|
|
||||||
If you have the `install-info' program (from the GNU Texinfo
|
If you have the 'install-info' program (from the GNU Texinfo
|
||||||
package), it will do that for you if you invoke it like this:
|
package), it will do that for you if you invoke it like this:
|
||||||
|
|
||||||
install-info --info-dir=c:/djgpp/info c:/djgpp/info/make.info
|
install-info --info-dir=c:/djgpp/info c:/djgpp/info/make.info
|
||||||
|
@ -120,8 +120,8 @@ To build from sources:
|
||||||
(If your Info directory is other than C:\DJGPP\INFO, change this
|
(If your Info directory is other than C:\DJGPP\INFO, change this
|
||||||
command accordingly.)
|
command accordingly.)
|
||||||
|
|
||||||
7. The `clean' targets also require Unix-style shell, and GNU Sed
|
7. The 'clean' targets also require Unix-style shell, and GNU Sed
|
||||||
and `rm' programs (the latter from Fileutils).
|
and 'rm' programs (the latter from Fileutils).
|
||||||
|
|
||||||
8. To run the test suite, type "make check". This requires a Unix
|
8. To run the test suite, type "make check". This requires a Unix
|
||||||
shell (I used the DJGPP port of Bash 2.03), Perl, Sed, Fileutils
|
shell (I used the DJGPP port of Bash 2.03), Perl, Sed, Fileutils
|
||||||
|
@ -144,7 +144,7 @@ Notes:
|
||||||
|
|
||||||
This port supports both DOS shells (the stock COMMAND.COM and its
|
This port supports both DOS shells (the stock COMMAND.COM and its
|
||||||
4DOS/NDOS replacements), and Unix-style shells (tested with the
|
4DOS/NDOS replacements), and Unix-style shells (tested with the
|
||||||
venerable Stewartson's `ms_sh' 2.3 and the DJGPP port of `bash' by
|
venerable Stewartson's 'ms_sh' 2.3 and the DJGPP port of 'bash' by
|
||||||
Daisuke Aoyama <jack@st.rim.or.jp>).
|
Daisuke Aoyama <jack@st.rim.or.jp>).
|
||||||
|
|
||||||
When the $SHELL variable points to a Unix-style shell, Make
|
When the $SHELL variable points to a Unix-style shell, Make
|
||||||
|
@ -166,17 +166,17 @@ Notes:
|
||||||
redirection and pipes, and shall only call the shell when a
|
redirection and pipes, and shall only call the shell when a
|
||||||
batch file or a command internal to the shell is invoked. (Even
|
batch file or a command internal to the shell is invoked. (Even
|
||||||
when a command is an internal shell command, Make will first
|
when a command is an internal shell command, Make will first
|
||||||
search the $PATH for it, so that if a Makefile calls `mkdir',
|
search the $PATH for it, so that if a Makefile calls 'mkdir',
|
||||||
you can install, say, a port of GNU `mkdir' and have it called
|
you can install, say, a port of GNU 'mkdir' and have it called
|
||||||
in that case.)
|
in that case.)
|
||||||
|
|
||||||
The key to all this is the extended functionality of `spawn' and
|
The key to all this is the extended functionality of 'spawn' and
|
||||||
`system' functions from the DJGPP library; this port just calls
|
'system' functions from the DJGPP library; this port just calls
|
||||||
`system' where it would invoke the shell on Unix. The most
|
'system' where it would invoke the shell on Unix. The most
|
||||||
important aspect of these functions is that they use a special
|
important aspect of these functions is that they use a special
|
||||||
mechanism to pass long (up to 16KB) command lines to DJGPP
|
mechanism to pass long (up to 16KB) command lines to DJGPP
|
||||||
programs. In addition, `system' emulates some internal
|
programs. In addition, 'system' emulates some internal
|
||||||
commands, like `cd' (so that you can now use forward slashes
|
commands, like 'cd' (so that you can now use forward slashes
|
||||||
with it, and can also change the drive if the directory is on
|
with it, and can also change the drive if the directory is on
|
||||||
another drive). Another aspect worth mentioning is that you can
|
another drive). Another aspect worth mentioning is that you can
|
||||||
call Unix shell scripts directly, provided that the shell whose
|
call Unix shell scripts directly, provided that the shell whose
|
||||||
|
@ -186,7 +186,7 @@ Notes:
|
||||||
reference for more details.
|
reference for more details.
|
||||||
|
|
||||||
The $(shell) built-in is implemented in this port by calling
|
The $(shell) built-in is implemented in this port by calling
|
||||||
`popen'. Since `popen' calls `system', the above considerations
|
'popen'. Since 'popen' calls 'system', the above considerations
|
||||||
are valid for $(shell) as well. In particular, you can put
|
are valid for $(shell) as well. In particular, you can put
|
||||||
arbitrary complex commands, including pipes and redirection,
|
arbitrary complex commands, including pipes and redirection,
|
||||||
inside $(shell), which is in many cases a valid substitute for
|
inside $(shell), which is in many cases a valid substitute for
|
||||||
|
@ -197,12 +197,12 @@ Notes:
|
||||||
|
|
||||||
Many Unix Makefiles include a line which sets the SHELL, for
|
Many Unix Makefiles include a line which sets the SHELL, for
|
||||||
those versions of Make which don't have this as the default.
|
those versions of Make which don't have this as the default.
|
||||||
Since many DOS systems don't have `sh' installed (in fact, most
|
Since many DOS systems don't have 'sh' installed (in fact, most
|
||||||
of them don't even have a `/bin' directory), this port takes
|
of them don't even have a '/bin' directory), this port takes
|
||||||
such directives with a grain of salt. It will only honor such a
|
such directives with a grain of salt. It will only honor such a
|
||||||
directive if the basename of the shell name (like `sh' in the
|
directive if the basename of the shell name (like 'sh' in the
|
||||||
above example) can indeed be found in the directory that is
|
above example) can indeed be found in the directory that is
|
||||||
mentioned in the SHELL= line (`/bin' in the above example), or
|
mentioned in the SHELL= line ('/bin' in the above example), or
|
||||||
in the current working directory, or anywhere on the $PATH (in
|
in the current working directory, or anywhere on the $PATH (in
|
||||||
that order). If the basename doesn't include a filename
|
that order). If the basename doesn't include a filename
|
||||||
extension, Make will look for any known extension that indicates
|
extension, Make will look for any known extension that indicates
|
||||||
|
@ -237,8 +237,8 @@ Notes:
|
||||||
require such a shell). More important, you can convert Unix
|
require such a shell). More important, you can convert Unix
|
||||||
Makefiles to MSDOS and leave the line which sets the shell
|
Makefiles to MSDOS and leave the line which sets the shell
|
||||||
intact, so that people who do have Unixy shell could use it for
|
intact, so that people who do have Unixy shell could use it for
|
||||||
targets which aren't converted to DOS (like `install' and
|
targets which aren't converted to DOS (like 'install' and
|
||||||
`uninstall', for example).
|
'uninstall', for example).
|
||||||
|
|
||||||
|
|
||||||
3. Default directories.
|
3. Default directories.
|
||||||
|
@ -258,14 +258,14 @@ Notes:
|
||||||
If you run Make on Windows 9x, you should be aware of the
|
If you run Make on Windows 9x, you should be aware of the
|
||||||
letter-case issue. Make is internally case-sensitive, but all
|
letter-case issue. Make is internally case-sensitive, but all
|
||||||
file operations are case-insensitive on Windows 9x, so
|
file operations are case-insensitive on Windows 9x, so
|
||||||
e.g. files `FAQ', `faq' and `Faq' all refer to the same file, as
|
e.g. files 'FAQ', 'faq' and 'Faq' all refer to the same file, as
|
||||||
far as Windows is concerned. The underlying DJGPP C library
|
far as Windows is concerned. The underlying DJGPP C library
|
||||||
functions honor the letter-case of the filenames they get from
|
functions honor the letter-case of the filenames they get from
|
||||||
the OS, except that by default, they down-case 8+3 DOS filenames
|
the OS, except that by default, they down-case 8+3 DOS filenames
|
||||||
which are stored in upper case in the directory and would break
|
which are stored in upper case in the directory and would break
|
||||||
many Makefiles otherwise. (The details of which filenames are
|
many Makefiles otherwise. (The details of which filenames are
|
||||||
converted to lower case are explained in the DJGPP libc docs,
|
converted to lower case are explained in the DJGPP libc docs,
|
||||||
under the `_preserve_fncase' and `_lfn_gen_short_fname'
|
under the '_preserve_fncase' and '_lfn_gen_short_fname'
|
||||||
functions, but as a thumb rule, any filename that is stored in
|
functions, but as a thumb rule, any filename that is stored in
|
||||||
upper case in the directory, is a valid DOS 8+3 filename and
|
upper case in the directory, is a valid DOS 8+3 filename and
|
||||||
doesn't include characters invalid on MSDOS FAT filesystems,
|
doesn't include characters invalid on MSDOS FAT filesystems,
|
||||||
|
@ -282,8 +282,8 @@ Notes:
|
||||||
|
|
||||||
There are a lot of places throughout the program sources which
|
There are a lot of places throughout the program sources which
|
||||||
make implicit assumptions about the pathname syntax. In
|
make implicit assumptions about the pathname syntax. In
|
||||||
particular, the directories are assumed to be separated by `/',
|
particular, the directories are assumed to be separated by '/',
|
||||||
and any pathname which doesn't begin with a `/' is assumed to be
|
and any pathname which doesn't begin with a '/' is assumed to be
|
||||||
relative to the current directory. This port attempts to
|
relative to the current directory. This port attempts to
|
||||||
support DOS-style pathnames which might include the drive letter
|
support DOS-style pathnames which might include the drive letter
|
||||||
and use backslashes instead of forward slashes. However, this
|
and use backslashes instead of forward slashes. However, this
|
||||||
|
@ -296,7 +296,7 @@ Notes:
|
||||||
is the standard programs which come with MSDOS. Otherwise, you
|
is the standard programs which come with MSDOS. Otherwise, you
|
||||||
are advised to stay away from backslashes whenever possible. In
|
are advised to stay away from backslashes whenever possible. In
|
||||||
particular, filename globbing won't work on pathnames with
|
particular, filename globbing won't work on pathnames with
|
||||||
backslashes, because the GNU `glob' library doesn't support them
|
backslashes, because the GNU 'glob' library doesn't support them
|
||||||
(backslash is special in filename wildcards, and I didn't want
|
(backslash is special in filename wildcards, and I didn't want
|
||||||
to break that).
|
to break that).
|
||||||
|
|
||||||
|
@ -315,7 +315,7 @@ Bug reports:
|
||||||
<djgpp@delorie.com>, which is an email gateway into the above news
|
<djgpp@delorie.com>, which is an email gateway into the above news
|
||||||
group). For other bugs, please follow the procedure explained in
|
group). For other bugs, please follow the procedure explained in
|
||||||
the "Bugs" chapter of the Info docs. If you don't have an Info
|
the "Bugs" chapter of the Info docs. If you don't have an Info
|
||||||
reader, look up that chapter in the `make.i1' file with any text
|
reader, look up that chapter in the 'make.i1' file with any text
|
||||||
browser/editor.
|
browser/editor.
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -140,7 +140,7 @@ to do this but the testsuite ignores the environment. -DNO_CHDIR2 causes
|
||||||
make not to use drive letters for directory names (i.e. _chdir2() and
|
make not to use drive letters for directory names (i.e. _chdir2() and
|
||||||
_getcwd2() are NOT used). The testsuite interpretes the whole output of
|
_getcwd2() are NOT used). The testsuite interpretes the whole output of
|
||||||
make, especially statements like make[1]: Entering directory
|
make, especially statements like make[1]: Entering directory
|
||||||
`C:/somewhere/make-3.79.1/tests' where the testsuite does not expect the
|
'C:/somewhere/make-3.79.1/tests' where the testsuite does not expect the
|
||||||
drive letter. This would be interpreted as an error even if there is
|
drive letter. This would be interpreted as an error even if there is
|
||||||
none.
|
none.
|
||||||
|
|
||||||
|
|
|
@ -35,19 +35,19 @@ you'll need to re-apply them by hand.
|
||||||
Install the Customs library and header files according to the
|
Install the Customs library and header files according to the
|
||||||
documentation. You should also install the man pages (contrary to
|
documentation. You should also install the man pages (contrary to
|
||||||
comments in the documentation, they weren't installed automatically for
|
comments in the documentation, they weren't installed automatically for
|
||||||
me; I had to cd to the ``pmake-2.1.33/doc'' directory and run ``pmake
|
me; I had to cd to the 'pmake-2.1.33/doc' directory and run 'pmake
|
||||||
install'' there directly).
|
install' there directly).
|
||||||
|
|
||||||
|
|
||||||
BUILDING GNU MAKE
|
BUILDING GNU MAKE
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
Once you've installed Customs, you can build GNU make to use it. When
|
Once you've installed Customs, you can build GNU make to use it. When
|
||||||
configuring GNU make, merely use the ``--with-customs=DIR'' option.
|
configuring GNU make, merely use the '--with-customs=DIR' option.
|
||||||
Provide the directory containing the ``lib'' and ``include/customs''
|
Provide the directory containing the 'lib' and 'include/customs'
|
||||||
subdirectories as DIR. For example, if you installed the customs
|
subdirectories as DIR. For example, if you installed the customs
|
||||||
library in /usr/local/lib and the headers in /usr/local/include/customs,
|
library in /usr/local/lib and the headers in /usr/local/include/customs,
|
||||||
then you'd pass ``--with-customs=/usr/local'' as an option to configure.
|
then you'd pass '--with-customs=/usr/local' as an option to configure.
|
||||||
|
|
||||||
Run make (or use build.sh) normally to build GNU make as described in
|
Run make (or use build.sh) normally to build GNU make as described in
|
||||||
the INSTALL file.
|
the INSTALL file.
|
||||||
|
|
|
@ -8,16 +8,16 @@ your operating system.
|
||||||
|
|
||||||
For general building and installation instructions, see the file INSTALL.
|
For general building and installation instructions, see the file INSTALL.
|
||||||
|
|
||||||
If you need to build GNU Make and have no other `make' program to use,
|
If you need to build GNU Make and have no other 'make' program to use,
|
||||||
you can use the shell script `build.sh' instead. To do this, first run
|
you can use the shell script 'build.sh' instead. To do this, first run
|
||||||
`configure' as described in INSTALL. Then, instead of typing `make' to
|
'configure' as described in INSTALL. Then, instead of typing 'make' to
|
||||||
build the program, type `sh build.sh'. This should compile the program
|
build the program, type 'sh build.sh'. This should compile the program
|
||||||
in the current directory. Then you will have a Make program that you can
|
in the current directory. Then you will have a Make program that you can
|
||||||
use for `./make install', or whatever else.
|
use for './make install', or whatever else.
|
||||||
|
|
||||||
Some systems' Make programs are broken and cannot process the Makefile for
|
Some systems' Make programs are broken and cannot process the Makefile for
|
||||||
GNU Make. If you get errors from your system's Make when building GNU
|
GNU Make. If you get errors from your system's Make when building GNU
|
||||||
Make, try using `build.sh' instead.
|
Make, try using 'build.sh' instead.
|
||||||
|
|
||||||
|
|
||||||
GNU Make is free software. See the file COPYING for copying conditions.
|
GNU Make is free software. See the file COPYING for copying conditions.
|
||||||
|
@ -64,7 +64,7 @@ Bug Reporting
|
||||||
-------------
|
-------------
|
||||||
|
|
||||||
You can send GNU make bug reports to <bug-make@gnu.org>. Please see the
|
You can send GNU make bug reports to <bug-make@gnu.org>. Please see the
|
||||||
section of the GNU make manual entitled `Problems and Bugs' for
|
section of the GNU make manual entitled 'Problems and Bugs' for
|
||||||
information on submitting useful and complete bug reports.
|
information on submitting useful and complete bug reports.
|
||||||
|
|
||||||
You can also use the online bug tracking system in the Savannah GNU Make
|
You can also use the online bug tracking system in the Savannah GNU Make
|
||||||
|
@ -112,8 +112,8 @@ System-specific Notes
|
||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
It has been reported that the XLC 1.2 compiler on AIX 3.2 is buggy such
|
It has been reported that the XLC 1.2 compiler on AIX 3.2 is buggy such
|
||||||
that if you compile make with `cc -O' on AIX 3.2, it will not work
|
that if you compile make with 'cc -O' on AIX 3.2, it will not work
|
||||||
correctly. It is said that using `cc' without `-O' does work.
|
correctly. It is said that using 'cc' without '-O' does work.
|
||||||
|
|
||||||
The standard /bin/sh on SunOS 4.1.3_U1 and 4.1.4 is broken and cannot be
|
The standard /bin/sh on SunOS 4.1.3_U1 and 4.1.4 is broken and cannot be
|
||||||
used to configure GNU make. Please install a different shell such as
|
used to configure GNU make. Please install a different shell such as
|
||||||
|
@ -123,15 +123,15 @@ information:
|
||||||
|
|
||||||
One area that is often a problem in configuration and porting is the code
|
One area that is often a problem in configuration and porting is the code
|
||||||
to check the system's current load average. To make it easier to test and
|
to check the system's current load average. To make it easier to test and
|
||||||
debug this code, you can do `make check-loadavg' to see if it works
|
debug this code, you can do 'make check-loadavg' to see if it works
|
||||||
properly on your system. (You must run `configure' beforehand, but you
|
properly on your system. (You must run 'configure' beforehand, but you
|
||||||
need not build Make itself to run this test.)
|
need not build Make itself to run this test.)
|
||||||
|
|
||||||
Another potential source of porting problems is the support for large
|
Another potential source of porting problems is the support for large
|
||||||
files (LFS) in configure for those operating systems that provide it.
|
files (LFS) in configure for those operating systems that provide it.
|
||||||
Please report any bugs that you find in this area. If you run into
|
Please report any bugs that you find in this area. If you run into
|
||||||
difficulties, then as a workaround you should be able to disable LFS by
|
difficulties, then as a workaround you should be able to disable LFS by
|
||||||
adding the `--disable-largefile' option to the `configure' script.
|
adding the '--disable-largefile' option to the 'configure' script.
|
||||||
|
|
||||||
On systems that support micro- and nano-second timestamp values and
|
On systems that support micro- and nano-second timestamp values and
|
||||||
where stat(2) provides this information, GNU make will use it when
|
where stat(2) provides this information, GNU make will use it when
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
|
|
||||||
# Ultrix 2.2 make doesn't expand the value of VPATH.
|
# Ultrix 2.2 make doesn't expand the value of VPATH.
|
||||||
VPATH = /make-%VERSION%/
|
VPATH = /make-%VERSION%/
|
||||||
# This must repeat the value, because configure will remove `VPATH = .'.
|
# This must repeat the value, because configure will remove 'VPATH = .'.
|
||||||
srcdir = /make-%VERSION%/
|
srcdir = /make-%VERSION%/
|
||||||
|
|
||||||
CC = sc
|
CC = sc
|
||||||
|
@ -38,18 +38,18 @@ CPPFLAGS =
|
||||||
LDFLAGS =
|
LDFLAGS =
|
||||||
|
|
||||||
# Define these for your system as follows:
|
# Define these for your system as follows:
|
||||||
# -DNO_ARCHIVES To disable `ar' archive support.
|
# -DNO_ARCHIVES To disable 'ar' archive support.
|
||||||
# -DNO_FLOAT To avoid using floating-point numbers.
|
# -DNO_FLOAT To avoid using floating-point numbers.
|
||||||
# -DENUM_BITFIELDS If the compiler isn't GCC but groks enum foo:2.
|
# -DENUM_BITFIELDS If the compiler isn't GCC but groks enum foo:2.
|
||||||
# Some compilers apparently accept this
|
# Some compilers apparently accept this
|
||||||
# without complaint but produce losing code,
|
# without complaint but produce losing code,
|
||||||
# so beware.
|
# so beware.
|
||||||
# NeXT 1.0a uses an old version of GCC, which required -D__inline=inline.
|
# NeXT 1.0a uses an old version of GCC, which required -D__inline=inline.
|
||||||
# See also `config.h'.
|
# See also 'config.h'.
|
||||||
defines =
|
defines =
|
||||||
|
|
||||||
# Which flavor of remote job execution support to use.
|
# Which flavor of remote job execution support to use.
|
||||||
# The code is found in `remote-$(REMOTE).c'.
|
# The code is found in 'remote-$(REMOTE).c'.
|
||||||
REMOTE = stub
|
REMOTE = stub
|
||||||
|
|
||||||
# If you are using the GNU C library, or have the GNU getopt functions in
|
# If you are using the GNU C library, or have the GNU getopt functions in
|
||||||
|
@ -83,9 +83,9 @@ prefix =
|
||||||
# Common prefix for machine-dependent installed files.
|
# Common prefix for machine-dependent installed files.
|
||||||
exec_prefix =
|
exec_prefix =
|
||||||
|
|
||||||
# Directory to install `make' in.
|
# Directory to install 'make' in.
|
||||||
bindir = sc:c
|
bindir = sc:c
|
||||||
# Directory to find libraries in for `-lXXX'.
|
# Directory to find libraries in for '-lXXX'.
|
||||||
libdir = lib:
|
libdir = lib:
|
||||||
# Directory to search by default for included makefiles.
|
# Directory to search by default for included makefiles.
|
||||||
includedir = include:
|
includedir = include:
|
||||||
|
@ -95,20 +95,20 @@ infodir = doc:
|
||||||
mandir = t:
|
mandir = t:
|
||||||
# Number to put on the man page filename.
|
# Number to put on the man page filename.
|
||||||
manext = 1
|
manext = 1
|
||||||
# Prefix to put on installed `make' binary file name.
|
# Prefix to put on installed 'make' binary file name.
|
||||||
binprefix =
|
binprefix =
|
||||||
# Prefix to put on installed `make' man page file name.
|
# Prefix to put on installed 'make' man page file name.
|
||||||
manprefix = $(binprefix)
|
manprefix = $(binprefix)
|
||||||
|
|
||||||
# Whether or not make needs to be installed setgid.
|
# Whether or not make needs to be installed setgid.
|
||||||
# The value should be either `true' or `false'.
|
# The value should be either 'true' or 'false'.
|
||||||
# On many systems, the getloadavg function (used to implement the `-l'
|
# On many systems, the getloadavg function (used to implement the '-l'
|
||||||
# switch) will not work unless make is installed setgid kmem.
|
# switch) will not work unless make is installed setgid kmem.
|
||||||
install_setgid = false
|
install_setgid = false
|
||||||
# Install make setgid to this group so it can read /dev/kmem.
|
# Install make setgid to this group so it can read /dev/kmem.
|
||||||
group = sys
|
group = sys
|
||||||
|
|
||||||
# Program to install `make'.
|
# Program to install 'make'.
|
||||||
INSTALL_PROGRAM = copy
|
INSTALL_PROGRAM = copy
|
||||||
# Program to install the man page.
|
# Program to install the man page.
|
||||||
INSTALL_DATA = copy
|
INSTALL_DATA = copy
|
||||||
|
@ -151,7 +151,7 @@ srcs = $(srcdir)commands.c $(srcdir)job.c $(srcdir)dir.c \
|
||||||
all: make
|
all: make
|
||||||
info: make.info
|
info: make.info
|
||||||
dvi: make.dvi
|
dvi: make.dvi
|
||||||
# Some makes apparently use .PHONY as the default goal if it is before `all'.
|
# Some makes apparently use .PHONY as the default goal if it is before 'all'.
|
||||||
.PHONY: all check info dvi
|
.PHONY: all check info dvi
|
||||||
|
|
||||||
make.info: make.texinfo
|
make.info: make.texinfo
|
||||||
|
|
2
alloca.c
2
alloca.c
|
@ -116,7 +116,7 @@ static int stack_dir; /* 1 or -1 once known. */
|
||||||
static void
|
static void
|
||||||
find_stack_direction (void)
|
find_stack_direction (void)
|
||||||
{
|
{
|
||||||
static char *addr = NULL; /* Address of first `dummy', once known. */
|
static char *addr = NULL; /* Address of first 'dummy', once known. */
|
||||||
auto char dummy; /* To get stack address. */
|
auto char dummy; /* To get stack address. */
|
||||||
|
|
||||||
if (addr == NULL)
|
if (addr == NULL)
|
||||||
|
|
22
ar.c
22
ar.c
|
@ -1,4 +1,4 @@
|
||||||
/* Interface to `ar' archives for GNU Make.
|
/* Interface to 'ar' archives for GNU Make.
|
||||||
Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
|
Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
|
||||||
1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011,
|
1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011,
|
||||||
2012 Free Software Foundation, Inc.
|
2012 Free Software Foundation, Inc.
|
||||||
|
@ -26,9 +26,9 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
#include <fnmatch.h>
|
#include <fnmatch.h>
|
||||||
|
|
||||||
/* Return nonzero if NAME is an archive-member reference, zero if not. An
|
/* Return nonzero if NAME is an archive-member reference, zero if not. An
|
||||||
archive-member reference is a name like `lib(member)' where member is a
|
archive-member reference is a name like 'lib(member)' where member is a
|
||||||
non-empty string.
|
non-empty string.
|
||||||
If a name like `lib((entry))' is used, a fatal error is signaled at
|
If a name like 'lib((entry))' is used, a fatal error is signaled at
|
||||||
the attempt to use this unsupported feature. */
|
the attempt to use this unsupported feature. */
|
||||||
|
|
||||||
int
|
int
|
||||||
|
@ -45,7 +45,7 @@ ar_name (const char *name)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (p[1] == '(' && end[-1] == ')')
|
if (p[1] == '(' && end[-1] == ')')
|
||||||
fatal (NILF, _("attempt to use unsupported feature: `%s'"), name);
|
fatal (NILF, _("attempt to use unsupported feature: '%s'"), name);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -68,7 +68,7 @@ ar_parse_name (const char *name, char **arname_p, char **memname_p)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* This function is called by `ar_scan' to find which member to look at. */
|
/* This function is called by 'ar_scan' to find which member to look at. */
|
||||||
|
|
||||||
/* ARGSUSED */
|
/* ARGSUSED */
|
||||||
static long int
|
static long int
|
||||||
|
@ -146,24 +146,24 @@ ar_touch (const char *name)
|
||||||
switch (ar_member_touch (arname, memname))
|
switch (ar_member_touch (arname, memname))
|
||||||
{
|
{
|
||||||
case -1:
|
case -1:
|
||||||
error (NILF, _("touch: Archive `%s' does not exist"), arname);
|
error (NILF, _("touch: Archive '%s' does not exist"), arname);
|
||||||
break;
|
break;
|
||||||
case -2:
|
case -2:
|
||||||
error (NILF, _("touch: `%s' is not a valid archive"), arname);
|
error (NILF, _("touch: '%s' is not a valid archive"), arname);
|
||||||
break;
|
break;
|
||||||
case -3:
|
case -3:
|
||||||
perror_with_name ("touch: ", arname);
|
perror_with_name ("touch: ", arname);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
error (NILF,
|
error (NILF,
|
||||||
_("touch: Member `%s' does not exist in `%s'"), memname, arname);
|
_("touch: Member '%s' does not exist in '%s'"), memname, arname);
|
||||||
break;
|
break;
|
||||||
case 0:
|
case 0:
|
||||||
val = 0;
|
val = 0;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
error (NILF,
|
error (NILF,
|
||||||
_("touch: Bad return code from ar_member_touch on `%s'"), name);
|
_("touch: Bad return code from ar_member_touch on '%s'"), name);
|
||||||
}
|
}
|
||||||
|
|
||||||
free (arname);
|
free (arname);
|
||||||
|
@ -172,7 +172,7 @@ ar_touch (const char *name)
|
||||||
}
|
}
|
||||||
#endif /* !VMS */
|
#endif /* !VMS */
|
||||||
|
|
||||||
/* State of an `ar_glob' run, passed to `ar_glob_match'. */
|
/* State of an 'ar_glob' run, passed to 'ar_glob_match'. */
|
||||||
|
|
||||||
struct ar_glob_state
|
struct ar_glob_state
|
||||||
{
|
{
|
||||||
|
@ -183,7 +183,7 @@ struct ar_glob_state
|
||||||
unsigned int n;
|
unsigned int n;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* This function is called by `ar_scan' to match one archive
|
/* This function is called by 'ar_scan' to match one archive
|
||||||
element against the pattern in STATE. */
|
element against the pattern in STATE. */
|
||||||
|
|
||||||
static long int
|
static long int
|
||||||
|
|
4
arscan.c
4
arscan.c
|
@ -184,7 +184,7 @@ ar_scan (const char *archive, ar_member_func_t function, const void *arg)
|
||||||
|
|
||||||
if (! (status & 1))
|
if (! (status & 1))
|
||||||
{
|
{
|
||||||
error (NILF, _("unable to open library `%s' to lookup member `%s'"),
|
error (NILF, _("unable to open library '%s' to lookup member '%s'"),
|
||||||
archive, (char *)arg);
|
archive, (char *)arg);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -847,7 +847,7 @@ describe_member (int desc, const char *name, int truncated,
|
||||||
{
|
{
|
||||||
extern char *ctime ();
|
extern char *ctime ();
|
||||||
|
|
||||||
printf (_("Member `%s'%s: %ld bytes at %ld (%ld).\n"),
|
printf (_("Member '%s'%s: %ld bytes at %ld (%ld).\n"),
|
||||||
name, truncated ? _(" (name might be truncated)") : "",
|
name, truncated ? _(" (name might be truncated)") : "",
|
||||||
size, hdrpos, datapos);
|
size, hdrpos, datapos);
|
||||||
printf (_(" Date %s"), ctime (&date));
|
printf (_(" Date %s"), ctime (&date));
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
# Shell script to build GNU Make in the absence of any `make' program.
|
# Shell script to build GNU Make in the absence of any 'make' program.
|
||||||
# @configure_input@
|
# @configure_input@
|
||||||
|
|
||||||
# Copyright (C) 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
# Copyright (C) 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
||||||
|
@ -40,7 +40,7 @@ EXEEXT='@EXEEXT@'
|
||||||
prefix='@prefix@'
|
prefix='@prefix@'
|
||||||
# Common prefix for machine-dependent installed files.
|
# Common prefix for machine-dependent installed files.
|
||||||
exec_prefix=`eval echo @exec_prefix@`
|
exec_prefix=`eval echo @exec_prefix@`
|
||||||
# Directory to find libraries in for `-lXXX'.
|
# Directory to find libraries in for '-lXXX'.
|
||||||
libdir=${exec_prefix}/lib
|
libdir=${exec_prefix}/lib
|
||||||
# Directory to search by default for included makefiles.
|
# Directory to search by default for included makefiles.
|
||||||
includedir=${prefix}/include
|
includedir=${prefix}/include
|
||||||
|
|
20
commands.c
20
commands.c
|
@ -71,8 +71,8 @@ set_file_variables (struct file *file)
|
||||||
const char *at, *percent, *star, *less;
|
const char *at, *percent, *star, *less;
|
||||||
|
|
||||||
#ifndef NO_ARCHIVES
|
#ifndef NO_ARCHIVES
|
||||||
/* If the target is an archive member `lib(member)',
|
/* If the target is an archive member 'lib(member)',
|
||||||
then $@ is `lib' and $% is `member'. */
|
then $@ is 'lib' and $% is 'member'. */
|
||||||
|
|
||||||
if (ar_name (file->name))
|
if (ar_name (file->name))
|
||||||
{
|
{
|
||||||
|
@ -103,7 +103,7 @@ set_file_variables (struct file *file)
|
||||||
{
|
{
|
||||||
/* In Unix make, $* is set to the target name with
|
/* In Unix make, $* is set to the target name with
|
||||||
any suffix in the .SUFFIXES list stripped off for
|
any suffix in the .SUFFIXES list stripped off for
|
||||||
explicit rules. We store this in the `stem' member. */
|
explicit rules. We store this in the 'stem' member. */
|
||||||
const char *name;
|
const char *name;
|
||||||
unsigned int len;
|
unsigned int len;
|
||||||
|
|
||||||
|
@ -325,7 +325,7 @@ set_file_variables (struct file *file)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Chop CMDS up into individual command lines if necessary.
|
/* Chop CMDS up into individual command lines if necessary.
|
||||||
Also set the `lines_flags' and `any_recurse' members. */
|
Also set the 'lines_flags' and 'any_recurse' members. */
|
||||||
|
|
||||||
void
|
void
|
||||||
chop_commands (struct commands *cmds)
|
chop_commands (struct commands *cmds)
|
||||||
|
@ -622,10 +622,10 @@ delete_target (struct file *file, const char *on_behalf_of)
|
||||||
if (ar_member_date (file->name) != file_date)
|
if (ar_member_date (file->name) != file_date)
|
||||||
{
|
{
|
||||||
if (on_behalf_of)
|
if (on_behalf_of)
|
||||||
error (NILF, _("*** [%s] Archive member `%s' may be bogus; not deleted"),
|
error (NILF, _("*** [%s] Archive member '%s' may be bogus; not deleted"),
|
||||||
on_behalf_of, file->name);
|
on_behalf_of, file->name);
|
||||||
else
|
else
|
||||||
error (NILF, _("*** Archive member `%s' may be bogus; not deleted"),
|
error (NILF, _("*** Archive member '%s' may be bogus; not deleted"),
|
||||||
file->name);
|
file->name);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
@ -638,9 +638,9 @@ delete_target (struct file *file, const char *on_behalf_of)
|
||||||
&& FILE_TIMESTAMP_STAT_MODTIME (file->name, st) != file->last_mtime)
|
&& FILE_TIMESTAMP_STAT_MODTIME (file->name, st) != file->last_mtime)
|
||||||
{
|
{
|
||||||
if (on_behalf_of)
|
if (on_behalf_of)
|
||||||
error (NILF, _("*** [%s] Deleting file `%s'"), on_behalf_of, file->name);
|
error (NILF, _("*** [%s] Deleting file '%s'"), on_behalf_of, file->name);
|
||||||
else
|
else
|
||||||
error (NILF, _("*** Deleting file `%s'"), file->name);
|
error (NILF, _("*** Deleting file '%s'"), file->name);
|
||||||
if (unlink (file->name) < 0
|
if (unlink (file->name) < 0
|
||||||
&& errno != ENOENT) /* It disappeared; so what. */
|
&& errno != ENOENT) /* It disappeared; so what. */
|
||||||
perror_with_name ("unlink: ", file->name);
|
perror_with_name ("unlink: ", file->name);
|
||||||
|
@ -662,7 +662,7 @@ delete_child_targets (struct child *child)
|
||||||
/* Delete the target file if it changed. */
|
/* Delete the target file if it changed. */
|
||||||
delete_target (child->file, NULL);
|
delete_target (child->file, NULL);
|
||||||
|
|
||||||
/* Also remove any non-precious targets listed in the `also_make' member. */
|
/* Also remove any non-precious targets listed in the 'also_make' member. */
|
||||||
for (d = child->file->also_make; d != 0; d = d->next)
|
for (d = child->file->also_make; d != 0; d = d->next)
|
||||||
delete_target (d->file, child->file->name);
|
delete_target (d->file, child->file->name);
|
||||||
|
|
||||||
|
@ -681,7 +681,7 @@ print_commands (const struct commands *cmds)
|
||||||
if (cmds->fileinfo.filenm == 0)
|
if (cmds->fileinfo.filenm == 0)
|
||||||
puts (_(" (built-in):"));
|
puts (_(" (built-in):"));
|
||||||
else
|
else
|
||||||
printf (_(" (from `%s', line %lu):\n"),
|
printf (_(" (from '%s', line %lu):\n"),
|
||||||
cmds->fileinfo.filenm, cmds->fileinfo.lineno);
|
cmds->fileinfo.filenm, cmds->fileinfo.lineno);
|
||||||
|
|
||||||
s = cmds->commands;
|
s = cmds->commands;
|
||||||
|
|
|
@ -27,11 +27,11 @@ struct commands
|
||||||
char *lines_flags; /* One set of flag bits for each line. */
|
char *lines_flags; /* One set of flag bits for each line. */
|
||||||
unsigned short ncommand_lines;/* Number of command lines. */
|
unsigned short ncommand_lines;/* Number of command lines. */
|
||||||
char recipe_prefix; /* Recipe prefix for this command set. */
|
char recipe_prefix; /* Recipe prefix for this command set. */
|
||||||
unsigned int any_recurse:1; /* Nonzero if any `lines_flags' elt has */
|
unsigned int any_recurse:1; /* Nonzero if any 'lines_flags' elt has */
|
||||||
/* the COMMANDS_RECURSE bit set. */
|
/* the COMMANDS_RECURSE bit set. */
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Bits in `lines_flags'. */
|
/* Bits in 'lines_flags'. */
|
||||||
#define COMMANDS_RECURSE 1 /* Recurses: + or $(MAKE). */
|
#define COMMANDS_RECURSE 1 /* Recurses: + or $(MAKE). */
|
||||||
#define COMMANDS_SILENT 2 /* Silent: @. */
|
#define COMMANDS_SILENT 2 /* Silent: @. */
|
||||||
#define COMMANDS_NOERROR 4 /* No errors: -. */
|
#define COMMANDS_NOERROR 4 /* No errors: -. */
|
||||||
|
|
|
@ -38,14 +38,14 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define for DGUX with <sys/dg_sys_info.h>. */
|
/* Define for DGUX with <sys/dg_sys_info.h>. */
|
||||||
/* #undef DGUX */
|
/* #undef DGUX */
|
||||||
|
|
||||||
/* Define if the `getloadavg' function needs to be run setuid or setgid. */
|
/* Define if the 'getloadavg' function needs to be run setuid or setgid. */
|
||||||
/* #undef GETLOADAVG_PRIVILEGED */
|
/* #undef GETLOADAVG_PRIVILEGED */
|
||||||
|
|
||||||
/* Define to `unsigned long' or `unsigned long long'
|
/* Define to 'unsigned long' or 'unsigned long long'
|
||||||
if <inttypes.h> doesn't define. */
|
if <inttypes.h> doesn't define. */
|
||||||
#define uintmax_t unsigned long
|
#define uintmax_t unsigned long
|
||||||
|
|
||||||
/* Define to `int' if <sys/types.h> doesn't define. */
|
/* Define to 'int' if <sys/types.h> doesn't define. */
|
||||||
#define gid_t int
|
#define gid_t int
|
||||||
|
|
||||||
/* Define if you have alloca, as a function or macro. */
|
/* Define if you have alloca, as a function or macro. */
|
||||||
|
@ -60,7 +60,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define if your system has a working fnmatch function. */
|
/* Define if your system has a working fnmatch function. */
|
||||||
/* #undef HAVE_FNMATCH */
|
/* #undef HAVE_FNMATCH */
|
||||||
|
|
||||||
/* Define if your system has its own `getloadavg' function. */
|
/* Define if your system has its own 'getloadavg' function. */
|
||||||
/* #undef HAVE_GETLOADAVG */
|
/* #undef HAVE_GETLOADAVG */
|
||||||
|
|
||||||
/* Define if you have the getmntent function. */
|
/* Define if you have the getmntent function. */
|
||||||
|
@ -69,13 +69,13 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Embed GNU Guile support */
|
/* Embed GNU Guile support */
|
||||||
/* #undef HAVE_GUILE */
|
/* #undef HAVE_GUILE */
|
||||||
|
|
||||||
/* Define if the `long double' type works. */
|
/* Define if the 'long double' type works. */
|
||||||
/* #undef HAVE_LONG_DOUBLE */
|
/* #undef HAVE_LONG_DOUBLE */
|
||||||
|
|
||||||
/* Define if you support file names longer than 14 characters. */
|
/* Define if you support file names longer than 14 characters. */
|
||||||
#define HAVE_LONG_FILE_NAMES 1
|
#define HAVE_LONG_FILE_NAMES 1
|
||||||
|
|
||||||
/* Define if you have a working `mmap' system call. */
|
/* Define if you have a working 'mmap' system call. */
|
||||||
/* #undef HAVE_MMAP */
|
/* #undef HAVE_MMAP */
|
||||||
|
|
||||||
/* Define if system calls automatically restart after interruption
|
/* Define if system calls automatically restart after interruption
|
||||||
|
@ -134,7 +134,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define if your C compiler doesn't accept -c and -o together. */
|
/* Define if your C compiler doesn't accept -c and -o together. */
|
||||||
/* #undef NO_MINUS_C_MINUS_O */
|
/* #undef NO_MINUS_C_MINUS_O */
|
||||||
|
|
||||||
/* Define to `int' if <sys/types.h> doesn't define. */
|
/* Define to 'int' if <sys/types.h> doesn't define. */
|
||||||
#define pid_t int
|
#define pid_t int
|
||||||
|
|
||||||
/* Define if the system does not provide POSIX.1 features except
|
/* Define if the system does not provide POSIX.1 features except
|
||||||
|
@ -161,7 +161,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
*/
|
*/
|
||||||
#define STACK_DIRECTION -1
|
#define STACK_DIRECTION -1
|
||||||
|
|
||||||
/* Define if the `S_IS*' macros in <sys/stat.h> do not work properly. */
|
/* Define if the 'S_IS*' macros in <sys/stat.h> do not work properly. */
|
||||||
/* #undef STAT_MACROS_BROKEN */
|
/* #undef STAT_MACROS_BROKEN */
|
||||||
|
|
||||||
/* Define if your compiler conforms to the ANSI C standard. */
|
/* Define if your compiler conforms to the ANSI C standard. */
|
||||||
|
@ -173,10 +173,10 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define on System V Release 4. */
|
/* Define on System V Release 4. */
|
||||||
/* #undef SVR4 */
|
/* #undef SVR4 */
|
||||||
|
|
||||||
/* Define if `sys_siglist' is declared by <signal.h>. */
|
/* Define if 'sys_siglist' is declared by <signal.h>. */
|
||||||
/* #undef SYS_SIGLIST_DECLARED */
|
/* #undef SYS_SIGLIST_DECLARED */
|
||||||
|
|
||||||
/* Define to `int' if <sys/types.h> doesn't define. */
|
/* Define to 'int' if <sys/types.h> doesn't define. */
|
||||||
#define uid_t int
|
#define uid_t int
|
||||||
|
|
||||||
/* Define for Encore UMAX. */
|
/* Define for Encore UMAX. */
|
||||||
|
@ -195,10 +195,10 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Version of this package (needed by automake) */
|
/* Version of this package (needed by automake) */
|
||||||
#define VERSION "%VERSION%"
|
#define VERSION "%VERSION%"
|
||||||
|
|
||||||
/* Define to the name of the SCCS `get' command. */
|
/* Define to the name of the SCCS 'get' command. */
|
||||||
#define SCCS_GET "get"
|
#define SCCS_GET "get"
|
||||||
|
|
||||||
/* Define this if the SCCS `get' command understands the `-G<file>' option. */
|
/* Define this if the SCCS 'get' command understands the '-G<file>' option. */
|
||||||
/* #undef SCCS_GET_MINUS_G */
|
/* #undef SCCS_GET_MINUS_G */
|
||||||
|
|
||||||
/* Define this to enable job server support in GNU make. */
|
/* Define this to enable job server support in GNU make. */
|
||||||
|
@ -208,13 +208,13 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
if it exists. */
|
if it exists. */
|
||||||
/* #undef ST_MTIM_NSEC */
|
/* #undef ST_MTIM_NSEC */
|
||||||
|
|
||||||
/* Define this if the C library defines the variable `sys_siglist'. */
|
/* Define this if the C library defines the variable 'sys_siglist'. */
|
||||||
/* #undef HAVE_SYS_SIGLIST */
|
/* #undef HAVE_SYS_SIGLIST */
|
||||||
|
|
||||||
/* Define this if the C library defines the variable `_sys_siglist'. */
|
/* Define this if the C library defines the variable '_sys_siglist'. */
|
||||||
/* #undef HAVE__SYS_SIGLIST */
|
/* #undef HAVE__SYS_SIGLIST */
|
||||||
|
|
||||||
/* Define this if you have the `union wait' type in <sys/wait.h>. */
|
/* Define this if you have the 'union wait' type in <sys/wait.h>. */
|
||||||
/* #undef HAVE_UNION_WAIT */
|
/* #undef HAVE_UNION_WAIT */
|
||||||
|
|
||||||
/* Define if you have the dup2 function. */
|
/* Define if you have the dup2 function. */
|
||||||
|
|
|
@ -60,14 +60,14 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define for DGUX with <sys/dg_sys_info.h>. */
|
/* Define for DGUX with <sys/dg_sys_info.h>. */
|
||||||
/* #undef DGUX */
|
/* #undef DGUX */
|
||||||
|
|
||||||
/* Define to 1 if the `getloadavg' function needs to be run setuid or setgid. */
|
/* Define to 1 if the 'getloadavg' function needs to be run setuid or setgid. */
|
||||||
/* #undef GETLOADAVG_PRIVILEGED */
|
/* #undef GETLOADAVG_PRIVILEGED */
|
||||||
|
|
||||||
/* Define to `unsigned long' or `unsigned long long'
|
/* Define to 'unsigned long' or 'unsigned long long'
|
||||||
if <inttypes.h> doesn't define. */
|
if <inttypes.h> doesn't define. */
|
||||||
#define uintmax_t unsigned long
|
#define uintmax_t unsigned long
|
||||||
|
|
||||||
/* Define to `int' if <sys/types.h> doesn't define. */
|
/* Define to 'int' if <sys/types.h> doesn't define. */
|
||||||
/* #undef gid_t */
|
/* #undef gid_t */
|
||||||
|
|
||||||
/* Define to 1 if you have alloca, as a function or macro. */
|
/* Define to 1 if you have alloca, as a function or macro. */
|
||||||
|
@ -85,19 +85,19 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 if your system has a working fnmatch function. */
|
/* Define to 1 if your system has a working fnmatch function. */
|
||||||
/* #undef HAVE_FNMATCH */
|
/* #undef HAVE_FNMATCH */
|
||||||
|
|
||||||
/* Define to 1 if your system has its own `getloadavg' function. */
|
/* Define to 1 if your system has its own 'getloadavg' function. */
|
||||||
/* #undef HAVE_GETLOADAVG */
|
/* #undef HAVE_GETLOADAVG */
|
||||||
|
|
||||||
/* Define to 1 if you have the getmntent function. */
|
/* Define to 1 if you have the getmntent function. */
|
||||||
/* #undef HAVE_GETMNTENT */
|
/* #undef HAVE_GETMNTENT */
|
||||||
|
|
||||||
/* Define to 1 if the `long double' type works. */
|
/* Define to 1 if the 'long double' type works. */
|
||||||
/* #undef HAVE_LONG_DOUBLE */
|
/* #undef HAVE_LONG_DOUBLE */
|
||||||
|
|
||||||
/* Define to 1 if you support file names longer than 14 characters. */
|
/* Define to 1 if you support file names longer than 14 characters. */
|
||||||
#define HAVE_LONG_FILE_NAMES 1
|
#define HAVE_LONG_FILE_NAMES 1
|
||||||
|
|
||||||
/* Define to 1 if you have a working `mmap' system call. */
|
/* Define to 1 if you have a working 'mmap' system call. */
|
||||||
/* #undef HAVE_MMAP */
|
/* #undef HAVE_MMAP */
|
||||||
|
|
||||||
/* Define to 1 if system calls automatically restart after interruption
|
/* Define to 1 if system calls automatically restart after interruption
|
||||||
|
@ -163,7 +163,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 if your C compiler doesn't accept -c and -o together. */
|
/* Define to 1 if your C compiler doesn't accept -c and -o together. */
|
||||||
/* #undef NO_MINUS_C_MINUS_O */
|
/* #undef NO_MINUS_C_MINUS_O */
|
||||||
|
|
||||||
/* Define to `int' if <sys/types.h> doesn't define. */
|
/* Define to 'int' if <sys/types.h> doesn't define. */
|
||||||
/* I assume types.h is available for all 5.0 cc/cxx compilers */
|
/* I assume types.h is available for all 5.0 cc/cxx compilers */
|
||||||
#if __DECC_VER < 50090000
|
#if __DECC_VER < 50090000
|
||||||
#define pid_t int
|
#define pid_t int
|
||||||
|
@ -193,7 +193,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
*/
|
*/
|
||||||
/* #undef STACK_DIRECTION */
|
/* #undef STACK_DIRECTION */
|
||||||
|
|
||||||
/* Define to 1 if the `S_IS*' macros in <sys/stat.h> do not work properly. */
|
/* Define to 1 if the 'S_IS*' macros in <sys/stat.h> do not work properly. */
|
||||||
/* #undef STAT_MACROS_BROKEN */
|
/* #undef STAT_MACROS_BROKEN */
|
||||||
|
|
||||||
/* Define to 1 if you have the ANSI C header files. */
|
/* Define to 1 if you have the ANSI C header files. */
|
||||||
|
@ -202,10 +202,10 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define on System V Release 4. */
|
/* Define on System V Release 4. */
|
||||||
/* #undef SVR4 */
|
/* #undef SVR4 */
|
||||||
|
|
||||||
/* Define to 1 if `sys_siglist' is declared by <signal.h>. */
|
/* Define to 1 if 'sys_siglist' is declared by <signal.h>. */
|
||||||
/* #undef SYS_SIGLIST_DECLARED */
|
/* #undef SYS_SIGLIST_DECLARED */
|
||||||
|
|
||||||
/* Define to `int' if <sys/types.h> doesn't define. */
|
/* Define to 'int' if <sys/types.h> doesn't define. */
|
||||||
#if __DECC_VER < 50090000
|
#if __DECC_VER < 50090000
|
||||||
#define uid_t int
|
#define uid_t int
|
||||||
#endif
|
#endif
|
||||||
|
@ -226,10 +226,10 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Version of this package (needed by automake) */
|
/* Version of this package (needed by automake) */
|
||||||
#define VERSION "%VERSION%"
|
#define VERSION "%VERSION%"
|
||||||
|
|
||||||
/* Define to the name of the SCCS `get' command. */
|
/* Define to the name of the SCCS 'get' command. */
|
||||||
/* #undef SCCS_GET */
|
/* #undef SCCS_GET */
|
||||||
|
|
||||||
/* Define this if the SCCS `get' command understands the `-G<file>' option. */
|
/* Define this if the SCCS 'get' command understands the '-G<file>' option. */
|
||||||
/* #undef SCCS_GET_MINUS_G */
|
/* #undef SCCS_GET_MINUS_G */
|
||||||
|
|
||||||
/* Define this to enable job server support in GNU make. */
|
/* Define this to enable job server support in GNU make. */
|
||||||
|
@ -239,13 +239,13 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
if it exists. */
|
if it exists. */
|
||||||
/* #undef ST_MTIM_NSEC */
|
/* #undef ST_MTIM_NSEC */
|
||||||
|
|
||||||
/* Define to 1 if the C library defines the variable `sys_siglist'. */
|
/* Define to 1 if the C library defines the variable 'sys_siglist'. */
|
||||||
/* #undefine HAVE_SYS_SIGLIST */
|
/* #undefine HAVE_SYS_SIGLIST */
|
||||||
|
|
||||||
/* Define to 1 if the C library defines the variable `_sys_siglist'. */
|
/* Define to 1 if the C library defines the variable '_sys_siglist'. */
|
||||||
/* #undef HAVE__SYS_SIGLIST */
|
/* #undef HAVE__SYS_SIGLIST */
|
||||||
|
|
||||||
/* Define to 1 if you have the `union wait' type in <sys/wait.h>. */
|
/* Define to 1 if you have the 'union wait' type in <sys/wait.h>. */
|
||||||
/* #undef HAVE_UNION_WAIT */
|
/* #undef HAVE_UNION_WAIT */
|
||||||
|
|
||||||
/* Define to 1 if you have the dup2 function. */
|
/* Define to 1 if you have the dup2 function. */
|
||||||
|
|
|
@ -28,18 +28,18 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
# define _CRT_NONSTDC_NO_WARNINGS /* functions w/o a leading underscore */
|
# define _CRT_NONSTDC_NO_WARNINGS /* functions w/o a leading underscore */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Define to 1 if the `closedir' function returns void instead of `int'. */
|
/* Define to 1 if the 'closedir' function returns void instead of 'int'. */
|
||||||
/* #undef CLOSEDIR_VOID */
|
/* #undef CLOSEDIR_VOID */
|
||||||
|
|
||||||
/* Define to one of `_getb67', `GETB67', `getb67' for Cray-2 and Cray-YMP
|
/* Define to one of '_getb67', 'GETB67', 'getb67' for Cray-2 and Cray-YMP
|
||||||
systems. This function is required for `alloca.c' support on those systems.
|
systems. This function is required for 'alloca.c' support on those systems.
|
||||||
*/
|
*/
|
||||||
/* #undef CRAY_STACKSEG_END */
|
/* #undef CRAY_STACKSEG_END */
|
||||||
|
|
||||||
/* Define to 1 if using `alloca.c'. */
|
/* Define to 1 if using 'alloca.c'. */
|
||||||
/* #undef C_ALLOCA */
|
/* #undef C_ALLOCA */
|
||||||
|
|
||||||
/* Define to 1 if using `getloadavg.c'. */
|
/* Define to 1 if using 'getloadavg.c'. */
|
||||||
#define C_GETLOADAVG 1
|
#define C_GETLOADAVG 1
|
||||||
|
|
||||||
/* Define to 1 for DGUX with <sys/dg_sys_info.h>. */
|
/* Define to 1 for DGUX with <sys/dg_sys_info.h>. */
|
||||||
|
@ -52,11 +52,11 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Use high resolution file timestamps if nonzero. */
|
/* Use high resolution file timestamps if nonzero. */
|
||||||
#define FILE_TIMESTAMP_HI_RES 0
|
#define FILE_TIMESTAMP_HI_RES 0
|
||||||
|
|
||||||
/* Define to 1 if the `getloadavg' function needs to be run setuid or setgid.
|
/* Define to 1 if the 'getloadavg' function needs to be run setuid or setgid.
|
||||||
*/
|
*/
|
||||||
/* #undef GETLOADAVG_PRIVILEGED */
|
/* #undef GETLOADAVG_PRIVILEGED */
|
||||||
|
|
||||||
/* Define to 1 if you have `alloca', as a function or macro. */
|
/* Define to 1 if you have 'alloca', as a function or macro. */
|
||||||
#define HAVE_ALLOCA 1
|
#define HAVE_ALLOCA 1
|
||||||
|
|
||||||
/* Define to 1 if you have <alloca.h> and it should be used (not on Ultrix).
|
/* Define to 1 if you have <alloca.h> and it should be used (not on Ultrix).
|
||||||
|
@ -66,7 +66,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 if your compiler conforms to the ANSI C standard. */
|
/* Define to 1 if your compiler conforms to the ANSI C standard. */
|
||||||
#define HAVE_ANSI_COMPILER 1
|
#define HAVE_ANSI_COMPILER 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `atexit' function. */
|
/* Define to 1 if you have the 'atexit' function. */
|
||||||
#define HAVE_ATEXIT 1
|
#define HAVE_ATEXIT 1
|
||||||
|
|
||||||
/* Use case insensitive file names */
|
/* Use case insensitive file names */
|
||||||
|
@ -83,23 +83,23 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
*/
|
*/
|
||||||
/* #undef HAVE_DCGETTEXT */
|
/* #undef HAVE_DCGETTEXT */
|
||||||
|
|
||||||
/* Define to 1 if you have the declaration of `bsd_signal', and to 0 if you
|
/* Define to 1 if you have the declaration of 'bsd_signal', and to 0 if you
|
||||||
don't. */
|
don't. */
|
||||||
#define HAVE_DECL_BSD_SIGNAL 0
|
#define HAVE_DECL_BSD_SIGNAL 0
|
||||||
|
|
||||||
/* Define to 1 if you have the declaration of `sys_siglist', and to 0 if you
|
/* Define to 1 if you have the declaration of 'sys_siglist', and to 0 if you
|
||||||
don't. */
|
don't. */
|
||||||
#define HAVE_DECL_SYS_SIGLIST 0
|
#define HAVE_DECL_SYS_SIGLIST 0
|
||||||
|
|
||||||
/* Define to 1 if you have the declaration of `_sys_siglist', and to 0 if you
|
/* Define to 1 if you have the declaration of '_sys_siglist', and to 0 if you
|
||||||
don't. */
|
don't. */
|
||||||
#define HAVE_DECL__SYS_SIGLIST 0
|
#define HAVE_DECL__SYS_SIGLIST 0
|
||||||
|
|
||||||
/* Define to 1 if you have the declaration of `__sys_siglist', and to 0 if you
|
/* Define to 1 if you have the declaration of '__sys_siglist', and to 0 if you
|
||||||
don't. */
|
don't. */
|
||||||
#define HAVE_DECL___SYS_SIGLIST 0
|
#define HAVE_DECL___SYS_SIGLIST 0
|
||||||
|
|
||||||
/* Define to 1 if you have the <dirent.h> header file, and it defines `DIR'.
|
/* Define to 1 if you have the <dirent.h> header file, and it defines 'DIR'.
|
||||||
*/
|
*/
|
||||||
#define HAVE_DIRENT_H 1
|
#define HAVE_DIRENT_H 1
|
||||||
|
|
||||||
|
@ -110,45 +110,45 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
# define HAVE_DIRECT_H 1
|
# define HAVE_DIRECT_H 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Define to 1 if you don't have `vprintf' but do have `_doprnt.' */
|
/* Define to 1 if you don't have 'vprintf' but do have '_doprnt.' */
|
||||||
/* #undef HAVE_DOPRNT */
|
/* #undef HAVE_DOPRNT */
|
||||||
|
|
||||||
/* Use platform specific coding */
|
/* Use platform specific coding */
|
||||||
#define HAVE_DOS_PATHS 1
|
#define HAVE_DOS_PATHS 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `dup2' function. */
|
/* Define to 1 if you have the 'dup2' function. */
|
||||||
#define HAVE_DUP2 1
|
#define HAVE_DUP2 1
|
||||||
|
|
||||||
/* Define to 1 if you have the <fcntl.h> header file. */
|
/* Define to 1 if you have the <fcntl.h> header file. */
|
||||||
#define HAVE_FCNTL_H 1
|
#define HAVE_FCNTL_H 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `fdopen' function. */
|
/* Define to 1 if you have the 'fdopen' function. */
|
||||||
#ifdef __MINGW32__
|
#ifdef __MINGW32__
|
||||||
#define HAVE_FDOPEN 1
|
#define HAVE_FDOPEN 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Define to 1 if you have the `fileno' function. */
|
/* Define to 1 if you have the 'fileno' function. */
|
||||||
#define HAVE_FILENO 1
|
#define HAVE_FILENO 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `fork' function. */
|
/* Define to 1 if you have the 'fork' function. */
|
||||||
/* #undef HAVE_FORK */
|
/* #undef HAVE_FORK */
|
||||||
|
|
||||||
/* Define to 1 if you have the `getcwd' function. */
|
/* Define to 1 if you have the 'getcwd' function. */
|
||||||
#define HAVE_GETCWD 1
|
#define HAVE_GETCWD 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `getgroups' function. */
|
/* Define to 1 if you have the 'getgroups' function. */
|
||||||
/* #undef HAVE_GETGROUPS */
|
/* #undef HAVE_GETGROUPS */
|
||||||
|
|
||||||
/* Define to 1 if you have the `gethostbyname' function. */
|
/* Define to 1 if you have the 'gethostbyname' function. */
|
||||||
/* #undef HAVE_GETHOSTBYNAME */
|
/* #undef HAVE_GETHOSTBYNAME */
|
||||||
|
|
||||||
/* Define to 1 if you have the `gethostname' function. */
|
/* Define to 1 if you have the 'gethostname' function. */
|
||||||
/* #undef HAVE_GETHOSTNAME */
|
/* #undef HAVE_GETHOSTNAME */
|
||||||
|
|
||||||
/* Define to 1 if you have the `getloadavg' function. */
|
/* Define to 1 if you have the 'getloadavg' function. */
|
||||||
/* #undef HAVE_GETLOADAVG */
|
/* #undef HAVE_GETLOADAVG */
|
||||||
|
|
||||||
/* Define to 1 if you have the `getrlimit' function. */
|
/* Define to 1 if you have the 'getrlimit' function. */
|
||||||
/* #undef HAVE_GETRLIMIT */
|
/* #undef HAVE_GETRLIMIT */
|
||||||
|
|
||||||
/* Define if the GNU gettext() function is already present or preinstalled. */
|
/* Define if the GNU gettext() function is already present or preinstalled. */
|
||||||
|
@ -167,10 +167,10 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
#define HAVE_INTTYPES_H 1
|
#define HAVE_INTTYPES_H 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Define to 1 if you have the `dgc' library (-ldgc). */
|
/* Define to 1 if you have the 'dgc' library (-ldgc). */
|
||||||
/* #undef HAVE_LIBDGC */
|
/* #undef HAVE_LIBDGC */
|
||||||
|
|
||||||
/* Define to 1 if you have the `kstat' library (-lkstat). */
|
/* Define to 1 if you have the 'kstat' library (-lkstat). */
|
||||||
/* #undef HAVE_LIBKSTAT */
|
/* #undef HAVE_LIBKSTAT */
|
||||||
|
|
||||||
/* Define to 1 if you have the <limits.h> header file. */
|
/* Define to 1 if you have the <limits.h> header file. */
|
||||||
|
@ -179,7 +179,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 if you have the <locale.h> header file. */
|
/* Define to 1 if you have the <locale.h> header file. */
|
||||||
/*#define HAVE_LOCALE_H 1*/
|
/*#define HAVE_LOCALE_H 1*/
|
||||||
|
|
||||||
/* Define to 1 if you have the `lstat' function. */
|
/* Define to 1 if you have the 'lstat' function. */
|
||||||
/* #undef HAVE_LSTAT */
|
/* #undef HAVE_LSTAT */
|
||||||
|
|
||||||
/* Define to 1 if you have the <mach/mach.h> header file. */
|
/* Define to 1 if you have the <mach/mach.h> header file. */
|
||||||
|
@ -188,64 +188,64 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 if you have the <memory.h> header file. */
|
/* Define to 1 if you have the <memory.h> header file. */
|
||||||
#define HAVE_MEMORY_H 1
|
#define HAVE_MEMORY_H 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `mkstemp' function. */
|
/* Define to 1 if you have the 'mkstemp' function. */
|
||||||
/* #undef HAVE_MKSTEMP */
|
/* #undef HAVE_MKSTEMP */
|
||||||
|
|
||||||
/* Define to 1 if you have the `mktemp' function. */
|
/* Define to 1 if you have the 'mktemp' function. */
|
||||||
#define HAVE_MKTEMP 1
|
#define HAVE_MKTEMP 1
|
||||||
|
|
||||||
/* Define to 1 if you have the <ndir.h> header file, and it defines `DIR'. */
|
/* Define to 1 if you have the <ndir.h> header file, and it defines 'DIR'. */
|
||||||
/* #undef HAVE_NDIR_H */
|
/* #undef HAVE_NDIR_H */
|
||||||
|
|
||||||
/* Define to 1 if you have the <nlist.h> header file. */
|
/* Define to 1 if you have the <nlist.h> header file. */
|
||||||
/* #undef HAVE_NLIST_H */
|
/* #undef HAVE_NLIST_H */
|
||||||
|
|
||||||
/* Define to 1 if you have the `pipe' function. */
|
/* Define to 1 if you have the 'pipe' function. */
|
||||||
/* #undef HAVE_PIPE */
|
/* #undef HAVE_PIPE */
|
||||||
|
|
||||||
/* Define to 1 if you have the `pstat_getdynamic' function. */
|
/* Define to 1 if you have the 'pstat_getdynamic' function. */
|
||||||
/* #undef HAVE_PSTAT_GETDYNAMIC */
|
/* #undef HAVE_PSTAT_GETDYNAMIC */
|
||||||
|
|
||||||
/* Define to 1 if you have the `readlink' function. */
|
/* Define to 1 if you have the 'readlink' function. */
|
||||||
/* #undef HAVE_READLINK */
|
/* #undef HAVE_READLINK */
|
||||||
|
|
||||||
/* Define to 1 if you have the `realpath' function. */
|
/* Define to 1 if you have the 'realpath' function. */
|
||||||
/* #undef HAVE_REALPATH */
|
/* #undef HAVE_REALPATH */
|
||||||
|
|
||||||
/* Define to 1 if <signal.h> defines the SA_RESTART constant. */
|
/* Define to 1 if <signal.h> defines the SA_RESTART constant. */
|
||||||
/* #undef HAVE_SA_RESTART */
|
/* #undef HAVE_SA_RESTART */
|
||||||
|
|
||||||
/* Define to 1 if you have the `setegid' function. */
|
/* Define to 1 if you have the 'setegid' function. */
|
||||||
/* #undef HAVE_SETEGID */
|
/* #undef HAVE_SETEGID */
|
||||||
|
|
||||||
/* Define to 1 if you have the `seteuid' function. */
|
/* Define to 1 if you have the 'seteuid' function. */
|
||||||
/* #undef HAVE_SETEUID */
|
/* #undef HAVE_SETEUID */
|
||||||
|
|
||||||
/* Define to 1 if you have the `setlinebuf' function. */
|
/* Define to 1 if you have the 'setlinebuf' function. */
|
||||||
/* #undef HAVE_SETLINEBUF */
|
/* #undef HAVE_SETLINEBUF */
|
||||||
|
|
||||||
/* Define to 1 if you have the `setlocale' function. */
|
/* Define to 1 if you have the 'setlocale' function. */
|
||||||
/*#define HAVE_SETLOCALE 1*/
|
/*#define HAVE_SETLOCALE 1*/
|
||||||
|
|
||||||
/* Define to 1 if you have the `setregid' function. */
|
/* Define to 1 if you have the 'setregid' function. */
|
||||||
/* #undef HAVE_SETREGID */
|
/* #undef HAVE_SETREGID */
|
||||||
|
|
||||||
/* Define to 1 if you have the `setreuid' function. */
|
/* Define to 1 if you have the 'setreuid' function. */
|
||||||
/* #undef HAVE_SETREUID */
|
/* #undef HAVE_SETREUID */
|
||||||
|
|
||||||
/* Define to 1 if you have the `setrlimit' function. */
|
/* Define to 1 if you have the 'setrlimit' function. */
|
||||||
/* #undef HAVE_SETRLIMIT */
|
/* #undef HAVE_SETRLIMIT */
|
||||||
|
|
||||||
/* Define to 1 if you have the `setvbuf' function. */
|
/* Define to 1 if you have the 'setvbuf' function. */
|
||||||
#define HAVE_SETVBUF 1
|
#define HAVE_SETVBUF 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `sigaction' function. */
|
/* Define to 1 if you have the 'sigaction' function. */
|
||||||
/* #undef HAVE_SIGACTION */
|
/* #undef HAVE_SIGACTION */
|
||||||
|
|
||||||
/* Define to 1 if you have the `sigsetmask' function. */
|
/* Define to 1 if you have the 'sigsetmask' function. */
|
||||||
/* #undef HAVE_SIGSETMASK */
|
/* #undef HAVE_SIGSETMASK */
|
||||||
|
|
||||||
/* Define to 1 if you have the `socket' function. */
|
/* Define to 1 if you have the 'socket' function. */
|
||||||
/* #undef HAVE_SOCKET */
|
/* #undef HAVE_SOCKET */
|
||||||
|
|
||||||
/* Define to 1 if you have the <stdarg.h> header file. */
|
/* Define to 1 if you have the <stdarg.h> header file. */
|
||||||
|
@ -259,25 +259,25 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 if you have the <stdlib.h> header file. */
|
/* Define to 1 if you have the <stdlib.h> header file. */
|
||||||
#define HAVE_STDLIB_H 1
|
#define HAVE_STDLIB_H 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `strcasecmp' function. */
|
/* Define to 1 if you have the 'strcasecmp' function. */
|
||||||
#ifdef __MINGW32__
|
#ifdef __MINGW32__
|
||||||
#define HAVE_STRCASECMP 1
|
#define HAVE_STRCASECMP 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Define to 1 if you have the `strcmpi' function. */
|
/* Define to 1 if you have the 'strcmpi' function. */
|
||||||
#define HAVE_STRCMPI 1
|
#define HAVE_STRCMPI 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `strcoll' function and it is properly defined.
|
/* Define to 1 if you have the 'strcoll' function and it is properly defined.
|
||||||
*/
|
*/
|
||||||
#define HAVE_STRCOLL 1
|
#define HAVE_STRCOLL 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `strdup' function. */
|
/* Define to 1 if you have the 'strdup' function. */
|
||||||
#define HAVE_STRDUP 1
|
#define HAVE_STRDUP 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `strerror' function. */
|
/* Define to 1 if you have the 'strerror' function. */
|
||||||
#define HAVE_STRERROR 1
|
#define HAVE_STRERROR 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `stricmp' function. */
|
/* Define to 1 if you have the 'stricmp' function. */
|
||||||
#define HAVE_STRICMP 1
|
#define HAVE_STRICMP 1
|
||||||
|
|
||||||
/* Define to 1 if you have the <strings.h> header file. */
|
/* Define to 1 if you have the <strings.h> header file. */
|
||||||
|
@ -286,33 +286,33 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 if you have the <string.h> header file. */
|
/* Define to 1 if you have the <string.h> header file. */
|
||||||
#define HAVE_STRING_H 1
|
#define HAVE_STRING_H 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `strncasecmp' function. */
|
/* Define to 1 if you have the 'strncasecmp' function. */
|
||||||
#ifdef __MINGW32__
|
#ifdef __MINGW32__
|
||||||
#define HAVE_STRNCASECMP 1
|
#define HAVE_STRNCASECMP 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Define to 1 if you have the `strncmpi' function. */
|
/* Define to 1 if you have the 'strncmpi' function. */
|
||||||
/* #undef HAVE_STRNCMPI */
|
/* #undef HAVE_STRNCMPI */
|
||||||
|
|
||||||
/* Define to 1 if you have the `strndup' function. */
|
/* Define to 1 if you have the 'strndup' function. */
|
||||||
/* #undef HAVE_STRNDUP */
|
/* #undef HAVE_STRNDUP */
|
||||||
|
|
||||||
/* Define to 1 if you have the `strnicmp' function. */
|
/* Define to 1 if you have the 'strnicmp' function. */
|
||||||
#ifdef __MINGW32__
|
#ifdef __MINGW32__
|
||||||
#define HAVE_STRNICMP 1
|
#define HAVE_STRNICMP 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Define to 1 if you have the `strsignal' function. */
|
/* Define to 1 if you have the 'strsignal' function. */
|
||||||
/* #undef HAVE_STRSIGNAL */
|
/* #undef HAVE_STRSIGNAL */
|
||||||
|
|
||||||
/* Define to 1 if `n_un.n_name' is a member of `struct nlist'. */
|
/* Define to 1 if 'n_un.n_name' is a member of 'struct nlist'. */
|
||||||
/* #undef HAVE_STRUCT_NLIST_N_UN_N_NAME */
|
/* #undef HAVE_STRUCT_NLIST_N_UN_N_NAME */
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/dir.h> header file, and it defines `DIR'.
|
/* Define to 1 if you have the <sys/dir.h> header file, and it defines 'DIR'.
|
||||||
*/
|
*/
|
||||||
/* #undef HAVE_SYS_DIR_H */
|
/* #undef HAVE_SYS_DIR_H */
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/ndir.h> header file, and it defines `DIR'.
|
/* Define to 1 if you have the <sys/ndir.h> header file, and it defines 'DIR'.
|
||||||
*/
|
*/
|
||||||
/* #undef HAVE_SYS_NDIR_H */
|
/* #undef HAVE_SYS_NDIR_H */
|
||||||
|
|
||||||
|
@ -341,7 +341,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 if you have the <sys/wait.h> header file. */
|
/* Define to 1 if you have the <sys/wait.h> header file. */
|
||||||
/* #undef HAVE_SYS_WAIT_H */
|
/* #undef HAVE_SYS_WAIT_H */
|
||||||
|
|
||||||
/* Define to 1 if you have the \`union wait' type in <sys/wait.h>. */
|
/* Define to 1 if you have the \'union wait' type in <sys/wait.h>. */
|
||||||
/* #undef HAVE_UNION_WAIT */
|
/* #undef HAVE_UNION_WAIT */
|
||||||
|
|
||||||
/* Define to 1 if you have the <unistd.h> header file. */
|
/* Define to 1 if you have the <unistd.h> header file. */
|
||||||
|
@ -352,26 +352,26 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 if you have the <varargs.h> header file. */
|
/* Define to 1 if you have the <varargs.h> header file. */
|
||||||
/* #undef HAVE_VARARGS_H */
|
/* #undef HAVE_VARARGS_H */
|
||||||
|
|
||||||
/* Define to 1 if you have the `vfork' function. */
|
/* Define to 1 if you have the 'vfork' function. */
|
||||||
/* #undef HAVE_VFORK */
|
/* #undef HAVE_VFORK */
|
||||||
|
|
||||||
/* Define to 1 if you have the <vfork.h> header file. */
|
/* Define to 1 if you have the <vfork.h> header file. */
|
||||||
/* #undef HAVE_VFORK_H */
|
/* #undef HAVE_VFORK_H */
|
||||||
|
|
||||||
/* Define to 1 if you have the `vprintf' function. */
|
/* Define to 1 if you have the 'vprintf' function. */
|
||||||
#define HAVE_VPRINTF 1
|
#define HAVE_VPRINTF 1
|
||||||
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `wait3' function. */
|
/* Define to 1 if you have the 'wait3' function. */
|
||||||
/* #undef HAVE_WAIT3 */
|
/* #undef HAVE_WAIT3 */
|
||||||
|
|
||||||
/* Define to 1 if you have the `waitpid' function. */
|
/* Define to 1 if you have the 'waitpid' function. */
|
||||||
/* #undef HAVE_WAITPID */
|
/* #undef HAVE_WAITPID */
|
||||||
|
|
||||||
/* Define to 1 if `fork' works. */
|
/* Define to 1 if 'fork' works. */
|
||||||
/* #undef HAVE_WORKING_FORK */
|
/* #undef HAVE_WORKING_FORK */
|
||||||
|
|
||||||
/* Define to 1 if `vfork' works. */
|
/* Define to 1 if 'vfork' works. */
|
||||||
/* #undef HAVE_WORKING_VFORK */
|
/* #undef HAVE_WORKING_VFORK */
|
||||||
|
|
||||||
/* Build host information. */
|
/* Build host information. */
|
||||||
|
@ -383,8 +383,8 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 to enable symbolic link timestamp checking. */
|
/* Define to 1 to enable symbolic link timestamp checking. */
|
||||||
/* #undef MAKE_SYMLINKS */
|
/* #undef MAKE_SYMLINKS */
|
||||||
|
|
||||||
/* Define to 1 if your `struct nlist' has an `n_un' member. Obsolete, depend
|
/* Define to 1 if your 'struct nlist' has an 'n_un' member. Obsolete, depend
|
||||||
on `HAVE_STRUCT_NLIST_N_UN_N_NAME */
|
on 'HAVE_STRUCT_NLIST_N_UN_N_NAME */
|
||||||
/* #undef NLIST_NAME_UNION */
|
/* #undef NLIST_NAME_UNION */
|
||||||
|
|
||||||
/* Define to 1 if struct nlist.n_name is a pointer rather than an array. */
|
/* Define to 1 if struct nlist.n_name is a pointer rather than an array. */
|
||||||
|
@ -411,7 +411,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to the character that separates directories in PATH. */
|
/* Define to the character that separates directories in PATH. */
|
||||||
#define PATH_SEPARATOR_CHAR ';'
|
#define PATH_SEPARATOR_CHAR ';'
|
||||||
|
|
||||||
/* Define as the return type of signal handlers (`int' or `void'). */
|
/* Define as the return type of signal handlers ('int' or 'void'). */
|
||||||
#define RETSIGTYPE void
|
#define RETSIGTYPE void
|
||||||
|
|
||||||
/* Define to the name of the SCCS 'get' command. */
|
/* Define to the name of the SCCS 'get' command. */
|
||||||
|
@ -420,7 +420,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define this if the SCCS 'get' command understands the '-G<file>' option. */
|
/* Define this if the SCCS 'get' command understands the '-G<file>' option. */
|
||||||
/* #undef SCCS_GET_MINUS_G */
|
/* #undef SCCS_GET_MINUS_G */
|
||||||
|
|
||||||
/* Define to 1 if the `setvbuf' function takes the buffering type as its
|
/* Define to 1 if the 'setvbuf' function takes the buffering type as its
|
||||||
second argument and the buffer pointer as the third, as on System V before
|
second argument and the buffer pointer as the third, as on System V before
|
||||||
release 3. */
|
release 3. */
|
||||||
/* #undef SETVBUF_REVERSED */
|
/* #undef SETVBUF_REVERSED */
|
||||||
|
@ -433,7 +433,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
STACK_DIRECTION = 0 => direction of growth unknown */
|
STACK_DIRECTION = 0 => direction of growth unknown */
|
||||||
/* #undef STACK_DIRECTION */
|
/* #undef STACK_DIRECTION */
|
||||||
|
|
||||||
/* Define to 1 if the `S_IS*' macros in <sys/stat.h> do not work properly. */
|
/* Define to 1 if the 'S_IS*' macros in <sys/stat.h> do not work properly. */
|
||||||
/* #undef STAT_MACROS_BROKEN */
|
/* #undef STAT_MACROS_BROKEN */
|
||||||
|
|
||||||
/* Define to 1 if you have the ANSI C header files. */
|
/* Define to 1 if you have the ANSI C header files. */
|
||||||
|
@ -483,18 +483,18 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
this defined. */
|
this defined. */
|
||||||
/* #undef _POSIX_1_SOURCE */
|
/* #undef _POSIX_1_SOURCE */
|
||||||
|
|
||||||
/* Define to 1 if you need to in order for `stat' and other things to work. */
|
/* Define to 1 if you need to in order for 'stat' and other things to work. */
|
||||||
/* #undef _POSIX_SOURCE */
|
/* #undef _POSIX_SOURCE */
|
||||||
|
|
||||||
/* Define to empty if `const' does not conform to ANSI C. */
|
/* Define to empty if 'const' does not conform to ANSI C. */
|
||||||
/* #undef const */
|
/* #undef const */
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
|
||||||
/* Define to `int' if <sys/types.h> doesn't define. */
|
/* Define to 'int' if <sys/types.h> doesn't define. */
|
||||||
#define gid_t int
|
#define gid_t int
|
||||||
|
|
||||||
/* Define to `int' if <sys/types.h> does not define. */
|
/* Define to 'int' if <sys/types.h> does not define. */
|
||||||
/* GCC 4.x reportedly defines pid_t. */
|
/* GCC 4.x reportedly defines pid_t. */
|
||||||
#ifndef _PID_T_
|
#ifndef _PID_T_
|
||||||
#ifdef _WIN64
|
#ifdef _WIN64
|
||||||
|
@ -504,7 +504,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Define to `int' if <sys/types.h> doesn't define. */
|
/* Define to 'int' if <sys/types.h> doesn't define. */
|
||||||
#define uid_t int
|
#define uid_t int
|
||||||
|
|
||||||
/* Define uintmax_t if not defined in <stdint.h> or <inttypes.h>. */
|
/* Define uintmax_t if not defined in <stdint.h> or <inttypes.h>. */
|
||||||
|
@ -512,7 +512,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
#define uintmax_t unsigned long
|
#define uintmax_t unsigned long
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Define as `fork' if `vfork' does not work. */
|
/* Define as 'fork' if 'vfork' does not work. */
|
||||||
/*#define vfork fork*/
|
/*#define vfork fork*/
|
||||||
|
|
||||||
/* Define if you have <sys/wait.h> that is POSIX.1 compatible. */
|
/* Define if you have <sys/wait.h> that is POSIX.1 compatible. */
|
||||||
|
|
|
@ -25,10 +25,10 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#if __DJGPP__ > 2 || __DJGPP_MINOR__ > 1
|
#if __DJGPP__ > 2 || __DJGPP_MINOR__ > 1
|
||||||
|
|
||||||
/* Define to 1 if `sys_siglist' is declared by <signal.h> or <unistd.h>. */
|
/* Define to 1 if 'sys_siglist' is declared by <signal.h> or <unistd.h>. */
|
||||||
# define SYS_SIGLIST_DECLARED 1
|
# define SYS_SIGLIST_DECLARED 1
|
||||||
|
|
||||||
/* Define to 1 if the C library defines the variable `_sys_siglist'. */
|
/* Define to 1 if the C library defines the variable '_sys_siglist'. */
|
||||||
# define HAVE_DECL_SYS_SIGLIST 1
|
# define HAVE_DECL_SYS_SIGLIST 1
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
@ -41,13 +41,13 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Use high resolution file timestamps if nonzero. */
|
/* Use high resolution file timestamps if nonzero. */
|
||||||
#define FILE_TIMESTAMP_HI_RES 0
|
#define FILE_TIMESTAMP_HI_RES 0
|
||||||
|
|
||||||
/* Define to 1 if you have `alloca', as a function or macro. */
|
/* Define to 1 if you have 'alloca', as a function or macro. */
|
||||||
#define HAVE_ALLOCA 1
|
#define HAVE_ALLOCA 1
|
||||||
|
|
||||||
/* Define to 1 if you have the fdopen function. */
|
/* Define to 1 if you have the fdopen function. */
|
||||||
#define HAVE_FDOPEN 1
|
#define HAVE_FDOPEN 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `getgroups' function. */
|
/* Define to 1 if you have the 'getgroups' function. */
|
||||||
#define HAVE_GETGROUPS 1
|
#define HAVE_GETGROUPS 1
|
||||||
|
|
||||||
/* Define to 1 if you have the <memory.h> header file. */
|
/* Define to 1 if you have the <memory.h> header file. */
|
||||||
|
@ -56,18 +56,18 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 if you have the mkstemp function. */
|
/* Define to 1 if you have the mkstemp function. */
|
||||||
#define HAVE_MKSTEMP 1
|
#define HAVE_MKSTEMP 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `mktemp' function. */
|
/* Define to 1 if you have the 'mktemp' function. */
|
||||||
#define HAVE_MKTEMP 1
|
#define HAVE_MKTEMP 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `setlinebuf' function. */
|
/* Define to 1 if you have the 'setlinebuf' function. */
|
||||||
#define HAVE_SETLINEBUF 1
|
#define HAVE_SETLINEBUF 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `setvbuf' function. */
|
/* Define to 1 if you have the 'setvbuf' function. */
|
||||||
#define HAVE_SETVBUF 1
|
#define HAVE_SETVBUF 1
|
||||||
|
|
||||||
#define SCCS_GET "get"
|
#define SCCS_GET "get"
|
||||||
|
|
||||||
/* Define to `unsigned long' or `unsigned long long'
|
/* Define to 'unsigned long' or 'unsigned long long'
|
||||||
if <inttypes.h> doesn't define. */
|
if <inttypes.h> doesn't define. */
|
||||||
#define uintmax_t unsigned long long
|
#define uintmax_t unsigned long long
|
||||||
|
|
||||||
|
@ -90,7 +90,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
/* Define to 1 if you have the stricmp function. */
|
/* Define to 1 if you have the stricmp function. */
|
||||||
#define HAVE_STRICMP 1
|
#define HAVE_STRICMP 1
|
||||||
|
|
||||||
/* Define to 1 if you have the `strncasecmp' function. */
|
/* Define to 1 if you have the 'strncasecmp' function. */
|
||||||
#define HAVE_STRNCASECMP 1
|
#define HAVE_STRNCASECMP 1
|
||||||
|
|
||||||
/* Name of the package */
|
/* Name of the package */
|
||||||
|
|
|
@ -243,7 +243,7 @@ AC_CACHE_CHECK([for union wait], [make_cv_union_wait],
|
||||||
])
|
])
|
||||||
AS_IF([test "$make_cv_union_wait" = yes],
|
AS_IF([test "$make_cv_union_wait" = yes],
|
||||||
[ AC_DEFINE([HAVE_UNION_WAIT], [1],
|
[ AC_DEFINE([HAVE_UNION_WAIT], [1],
|
||||||
[Define to 1 if you have the \`union wait' type in <sys/wait.h>.])
|
[Define to 1 if you have the 'union wait' type in <sys/wait.h>.])
|
||||||
])
|
])
|
||||||
|
|
||||||
|
|
||||||
|
|
12
default.c
12
default.c
|
@ -32,8 +32,8 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
|
||||||
/* This is the default list of suffixes for suffix rules.
|
/* This is the default list of suffixes for suffix rules.
|
||||||
`.s' must come last, so that a `.o' file will be made from
|
'.s' must come last, so that a '.o' file will be made from
|
||||||
a `.c' or `.p' or ... file rather than from a .s file. */
|
a '.c' or '.p' or ... file rather than from a .s file. */
|
||||||
|
|
||||||
static char default_suffixes[]
|
static char default_suffixes[]
|
||||||
#ifdef VMS
|
#ifdef VMS
|
||||||
|
@ -56,8 +56,8 @@ static struct pspec default_pattern_rules[] =
|
||||||
"$(AR) $(ARFLAGS) $@ $<" },
|
"$(AR) $(ARFLAGS) $@ $<" },
|
||||||
|
|
||||||
/* The X.out rules are only in BSD's default set because
|
/* The X.out rules are only in BSD's default set because
|
||||||
BSD Make has no null-suffix rules, so `foo.out' and
|
BSD Make has no null-suffix rules, so 'foo.out' and
|
||||||
`foo' are the same thing. */
|
'foo' are the same thing. */
|
||||||
#ifdef VMS
|
#ifdef VMS
|
||||||
{ "%.exe", "%",
|
{ "%.exe", "%",
|
||||||
"copy $< $@" },
|
"copy $< $@" },
|
||||||
|
@ -293,13 +293,13 @@ static char *default_suffix_rules[] =
|
||||||
"$(TEXI2DVI) $(TEXI2DVI_FLAGS) $<",
|
"$(TEXI2DVI) $(TEXI2DVI_FLAGS) $<",
|
||||||
|
|
||||||
".w.c",
|
".w.c",
|
||||||
"$(CTANGLE) $< - $@", /* The `-' says there is no `.ch' file. */
|
"$(CTANGLE) $< - $@", /* The '-' says there is no '.ch' file. */
|
||||||
|
|
||||||
".web.p",
|
".web.p",
|
||||||
"$(TANGLE) $<",
|
"$(TANGLE) $<",
|
||||||
|
|
||||||
".w.tex",
|
".w.tex",
|
||||||
"$(CWEAVE) $< - $@", /* The `-' says there is no `.ch' file. */
|
"$(CWEAVE) $< - $@", /* The '-' says there is no '.ch' file. */
|
||||||
|
|
||||||
".web.tex",
|
".web.tex",
|
||||||
"$(WEAVE) $<",
|
"$(WEAVE) $<",
|
||||||
|
|
10
dep.h
10
dep.h
|
@ -16,9 +16,9 @@ A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||||
You should have received a copy of the GNU General Public License along with
|
You should have received a copy of the GNU General Public License along with
|
||||||
this program. If not, see <http://www.gnu.org/licenses/>. */
|
this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
/* Flag bits for the second argument to `read_makefile'.
|
/* Flag bits for the second argument to 'read_makefile'.
|
||||||
These flags are saved in the `changed' field of each
|
These flags are saved in the 'changed' field of each
|
||||||
`struct dep' in the chain returned by `read_all_makefiles'. */
|
'struct dep' in the chain returned by 'read_all_makefiles'. */
|
||||||
|
|
||||||
#define RM_NO_DEFAULT_GOAL (1 << 0) /* Do not set default goal. */
|
#define RM_NO_DEFAULT_GOAL (1 << 0) /* Do not set default goal. */
|
||||||
#define RM_INCLUDED (1 << 1) /* Search makefile search path. */
|
#define RM_INCLUDED (1 << 1) /* Search makefile search path. */
|
||||||
|
@ -27,8 +27,8 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
#define RM_NOFLAG 0
|
#define RM_NOFLAG 0
|
||||||
|
|
||||||
/* Structure representing one dependency of a file.
|
/* Structure representing one dependency of a file.
|
||||||
Each struct file's `deps' points to a chain of these,
|
Each struct file's 'deps' points to a chain of these,
|
||||||
chained through the `next'. `stem' is the stem for this
|
chained through the 'next'. 'stem' is the stem for this
|
||||||
dep line of static pattern rule or NULL.
|
dep line of static pattern rule or NULL.
|
||||||
|
|
||||||
Note that the first two words of this match a struct nameseq. */
|
Note that the first two words of this match a struct nameseq. */
|
||||||
|
|
12
dir.c
12
dir.c
|
@ -337,7 +337,7 @@ struct directory
|
||||||
|
|
||||||
/* The directory's contents. This data may be shared by several
|
/* The directory's contents. This data may be shared by several
|
||||||
entries in the hash table, which refer to the same directory
|
entries in the hash table, which refer to the same directory
|
||||||
(identified uniquely by `dev' and `ino') under different names. */
|
(identified uniquely by 'dev' and 'ino') under different names. */
|
||||||
struct directory_contents *contents;
|
struct directory_contents *contents;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -410,7 +410,7 @@ static int dir_contents_file_exists_p (struct directory_contents *dir,
|
||||||
const char *filename);
|
const char *filename);
|
||||||
static struct directory *find_directory (const char *name);
|
static struct directory *find_directory (const char *name);
|
||||||
|
|
||||||
/* Find the directory named NAME and return its `struct directory'. */
|
/* Find the directory named NAME and return its 'struct directory'. */
|
||||||
|
|
||||||
static struct directory *
|
static struct directory *
|
||||||
find_directory (const char *name)
|
find_directory (const char *name)
|
||||||
|
@ -482,7 +482,7 @@ find_directory (const char *name)
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
{
|
{
|
||||||
/* Couldn't stat the directory. Mark this by
|
/* Couldn't stat the directory. Mark this by
|
||||||
setting the `contents' member to a nil pointer. */
|
setting the 'contents' member to a nil pointer. */
|
||||||
dir->contents = 0;
|
dir->contents = 0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -553,7 +553,7 @@ find_directory (const char *name)
|
||||||
ENULLLOOP (dc->dirstream, opendir (name));
|
ENULLLOOP (dc->dirstream, opendir (name));
|
||||||
if (dc->dirstream == 0)
|
if (dc->dirstream == 0)
|
||||||
/* Couldn't open the directory. Mark this by setting the
|
/* Couldn't open the directory. Mark this by setting the
|
||||||
`files' member to a nil pointer. */
|
'files' member to a nil pointer. */
|
||||||
dc->dirfiles.ht_vec = 0;
|
dc->dirfiles.ht_vec = 0;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -805,7 +805,7 @@ file_exists_p (const char *name)
|
||||||
return dir_file_exists_p (dirname, slash + 1);
|
return dir_file_exists_p (dirname, slash + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Mark FILENAME as `impossible' for `file_impossible_p'.
|
/* Mark FILENAME as 'impossible' for 'file_impossible_p'.
|
||||||
This means an attempt has been made to search for FILENAME
|
This means an attempt has been made to search for FILENAME
|
||||||
as an intermediate file, and it has failed. */
|
as an intermediate file, and it has failed. */
|
||||||
|
|
||||||
|
@ -1146,7 +1146,7 @@ read_dirstream (__ptr_t stream)
|
||||||
struct dirfile *df = *ds->dirfile_slot++;
|
struct dirfile *df = *ds->dirfile_slot++;
|
||||||
if (! HASH_VACANT (df) && !df->impossible)
|
if (! HASH_VACANT (df) && !df->impossible)
|
||||||
{
|
{
|
||||||
/* The glob interface wants a `struct dirent', so mock one up. */
|
/* The glob interface wants a 'struct dirent', so mock one up. */
|
||||||
struct dirent *d;
|
struct dirent *d;
|
||||||
unsigned int len = df->length + 1;
|
unsigned int len = df->length + 1;
|
||||||
unsigned int sz = sizeof (*d) - sizeof (d->d_name) + len;
|
unsigned int sz = sizeof (*d) - sizeof (d->d_name) + len;
|
||||||
|
|
10
expand.c
10
expand.c
|
@ -124,7 +124,7 @@ recursively_expand_for_file (struct variable *v, struct file *file)
|
||||||
if (!v->exp_count)
|
if (!v->exp_count)
|
||||||
/* Expanding V causes infinite recursion. Lose. */
|
/* Expanding V causes infinite recursion. Lose. */
|
||||||
fatal (*expanding_var,
|
fatal (*expanding_var,
|
||||||
_("Recursive variable `%s' references itself (eventually)"),
|
_("Recursive variable '%s' references itself (eventually)"),
|
||||||
v->name);
|
v->name);
|
||||||
--v->exp_count;
|
--v->exp_count;
|
||||||
}
|
}
|
||||||
|
@ -187,7 +187,7 @@ reference_variable (char *o, const char *name, unsigned int length)
|
||||||
LENGTH bytes of STRING are actually scanned. If LENGTH is -1, scan until
|
LENGTH bytes of STRING are actually scanned. If LENGTH is -1, scan until
|
||||||
a null byte is found.
|
a null byte is found.
|
||||||
|
|
||||||
Write the results to LINE, which must point into `variable_buffer'. If
|
Write the results to LINE, which must point into 'variable_buffer'. If
|
||||||
LINE is NULL, start at the beginning of the buffer.
|
LINE is NULL, start at the beginning of the buffer.
|
||||||
Return a pointer to LINE, or to the beginning of the buffer if LINE is
|
Return a pointer to LINE, or to the beginning of the buffer if LINE is
|
||||||
NULL.
|
NULL.
|
||||||
|
@ -284,7 +284,7 @@ variable_expand_string (char *line, const char *string, long length)
|
||||||
}
|
}
|
||||||
/* If COUNT is >= 0, there were unmatched opening parens
|
/* If COUNT is >= 0, there were unmatched opening parens
|
||||||
or braces, so we go to the simple case of a variable name
|
or braces, so we go to the simple case of a variable name
|
||||||
such as `$($(a)'. */
|
such as '$($(a)'. */
|
||||||
if (count < 0)
|
if (count < 0)
|
||||||
{
|
{
|
||||||
abeg = expand_argument (beg, p); /* Expand the name. */
|
abeg = expand_argument (beg, p); /* Expand the name. */
|
||||||
|
@ -413,7 +413,7 @@ variable_expand_string (char *line, const char *string, long length)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Scan LINE for variable references and expansion-function calls.
|
/* Scan LINE for variable references and expansion-function calls.
|
||||||
Build in `variable_buffer' the result of expanding the references and calls.
|
Build in 'variable_buffer' the result of expanding the references and calls.
|
||||||
Return the address of the resulting string, which is null-terminated
|
Return the address of the resulting string, which is null-terminated
|
||||||
and is valid only until the next time this function is called. */
|
and is valid only until the next time this function is called. */
|
||||||
|
|
||||||
|
@ -426,7 +426,7 @@ variable_expand (const char *line)
|
||||||
/* Expand an argument for an expansion function.
|
/* Expand an argument for an expansion function.
|
||||||
The text starting at STR and ending at END is variable-expanded
|
The text starting at STR and ending at END is variable-expanded
|
||||||
into a null-terminated string that is returned as the value.
|
into a null-terminated string that is returned as the value.
|
||||||
This is done without clobbering `variable_buffer' or the current
|
This is done without clobbering 'variable_buffer' or the current
|
||||||
variable-expansion that is in progress. */
|
variable-expansion that is in progress. */
|
||||||
|
|
||||||
char *
|
char *
|
||||||
|
|
30
file.c
30
file.c
|
@ -202,7 +202,7 @@ enter_file (const char *name)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Rehash FILE to NAME. This is not as simple as resetting
|
/* Rehash FILE to NAME. This is not as simple as resetting
|
||||||
the `hname' member, since it must be put in a new hash bucket,
|
the 'hname' member, since it must be put in a new hash bucket,
|
||||||
and possibly merged with an existing file called NAME. */
|
and possibly merged with an existing file called NAME. */
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -264,18 +264,18 @@ rehash_file (struct file *from_file, const char *to_hname)
|
||||||
but give a message to let the user know what's going on. */
|
but give a message to let the user know what's going on. */
|
||||||
if (to_file->cmds->fileinfo.filenm != 0)
|
if (to_file->cmds->fileinfo.filenm != 0)
|
||||||
error (&from_file->cmds->fileinfo,
|
error (&from_file->cmds->fileinfo,
|
||||||
_("Recipe was specified for file `%s' at %s:%lu,"),
|
_("Recipe was specified for file '%s' at %s:%lu,"),
|
||||||
from_file->name, to_file->cmds->fileinfo.filenm,
|
from_file->name, to_file->cmds->fileinfo.filenm,
|
||||||
to_file->cmds->fileinfo.lineno);
|
to_file->cmds->fileinfo.lineno);
|
||||||
else
|
else
|
||||||
error (&from_file->cmds->fileinfo,
|
error (&from_file->cmds->fileinfo,
|
||||||
_("Recipe for file `%s' was found by implicit rule search,"),
|
_("Recipe for file '%s' was found by implicit rule search,"),
|
||||||
from_file->name);
|
from_file->name);
|
||||||
error (&from_file->cmds->fileinfo,
|
error (&from_file->cmds->fileinfo,
|
||||||
_("but `%s' is now considered the same file as `%s'."),
|
_("but '%s' is now considered the same file as '%s'."),
|
||||||
from_file->name, to_hname);
|
from_file->name, to_hname);
|
||||||
error (&from_file->cmds->fileinfo,
|
error (&from_file->cmds->fileinfo,
|
||||||
_("Recipe for `%s' will be ignored in favor of the one for `%s'."),
|
_("Recipe for '%s' will be ignored in favor of the one for '%s'."),
|
||||||
to_hname, from_file->name);
|
to_hname, from_file->name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -295,12 +295,12 @@ rehash_file (struct file *from_file, const char *to_hname)
|
||||||
merge_variable_set_lists (&to_file->variables, from_file->variables);
|
merge_variable_set_lists (&to_file->variables, from_file->variables);
|
||||||
|
|
||||||
if (to_file->double_colon && from_file->is_target && !from_file->double_colon)
|
if (to_file->double_colon && from_file->is_target && !from_file->double_colon)
|
||||||
fatal (NILF, _("can't rename single-colon `%s' to double-colon `%s'"),
|
fatal (NILF, _("can't rename single-colon '%s' to double-colon '%s'"),
|
||||||
from_file->name, to_hname);
|
from_file->name, to_hname);
|
||||||
if (!to_file->double_colon && from_file->double_colon)
|
if (!to_file->double_colon && from_file->double_colon)
|
||||||
{
|
{
|
||||||
if (to_file->is_target)
|
if (to_file->is_target)
|
||||||
fatal (NILF, _("can't rename double-colon `%s' to single-colon `%s'"),
|
fatal (NILF, _("can't rename double-colon '%s' to single-colon '%s'"),
|
||||||
from_file->name, to_hname);
|
from_file->name, to_hname);
|
||||||
else
|
else
|
||||||
to_file->double_colon = from_file->double_colon;
|
to_file->double_colon = from_file->double_colon;
|
||||||
|
@ -327,7 +327,7 @@ rehash_file (struct file *from_file, const char *to_hname)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Rename FILE to NAME. This is not as simple as resetting
|
/* Rename FILE to NAME. This is not as simple as resetting
|
||||||
the `name' member, since it must be put in a new hash bucket,
|
the 'name' member, since it must be put in a new hash bucket,
|
||||||
and possibly merged with an existing file called NAME. */
|
and possibly merged with an existing file called NAME. */
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -389,7 +389,7 @@ remove_intermediates (int sig)
|
||||||
if (!f->dontcare)
|
if (!f->dontcare)
|
||||||
{
|
{
|
||||||
if (sig)
|
if (sig)
|
||||||
error (NILF, _("*** Deleting intermediate file `%s'"), f->name);
|
error (NILF, _("*** Deleting intermediate file '%s'"), f->name);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (! doneany)
|
if (! doneany)
|
||||||
|
@ -637,8 +637,8 @@ reset_updating (const void *item)
|
||||||
f->updating = 0;
|
f->updating = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* For each dependency of each file, make the `struct dep' point
|
/* For each dependency of each file, make the 'struct dep' point
|
||||||
at the appropriate `struct file' (which may have to be created).
|
at the appropriate 'struct file' (which may have to be created).
|
||||||
|
|
||||||
Also mark the files depended on by .PRECIOUS, .PHONY, .SILENT,
|
Also mark the files depended on by .PRECIOUS, .PHONY, .SILENT,
|
||||||
and various other special targets. */
|
and various other special targets. */
|
||||||
|
@ -772,7 +772,7 @@ snap_deps (void)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set the `command_state' member of FILE and all its `also_make's. */
|
/* Set the 'command_state' member of FILE and all its 'also_make's. */
|
||||||
|
|
||||||
void
|
void
|
||||||
set_command_state (struct file *file, enum cmd_state state)
|
set_command_state (struct file *file, enum cmd_state state)
|
||||||
|
@ -951,7 +951,7 @@ print_file (const void *item)
|
||||||
? _("# Implicit rule search has been done.")
|
? _("# Implicit rule search has been done.")
|
||||||
: _("# Implicit rule search has not been done."));
|
: _("# Implicit rule search has not been done."));
|
||||||
if (f->stem != 0)
|
if (f->stem != 0)
|
||||||
printf (_("# Implicit/static pattern stem: `%s'\n"), f->stem);
|
printf (_("# Implicit/static pattern stem: '%s'\n"), f->stem);
|
||||||
if (f->intermediate)
|
if (f->intermediate)
|
||||||
puts (_("# File is an intermediate prerequisite."));
|
puts (_("# File is an intermediate prerequisite."));
|
||||||
if (f->also_make != 0)
|
if (f->also_make != 0)
|
||||||
|
@ -1001,14 +1001,14 @@ print_file (const void *item)
|
||||||
puts (_("# Failed to be updated."));
|
puts (_("# Failed to be updated."));
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
puts (_("# Invalid value in `update_status' member!"));
|
puts (_("# Invalid value in 'update_status' member!"));
|
||||||
fflush (stdout);
|
fflush (stdout);
|
||||||
fflush (stderr);
|
fflush (stderr);
|
||||||
abort ();
|
abort ();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
puts (_("# Invalid value in `command_state' member!"));
|
puts (_("# Invalid value in 'command_state' member!"));
|
||||||
fflush (stdout);
|
fflush (stdout);
|
||||||
fflush (stderr);
|
fflush (stderr);
|
||||||
abort ();
|
abort ();
|
||||||
|
|
10
filedef.h
10
filedef.h
|
@ -19,7 +19,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
/* Structure that represents the info on one file
|
/* Structure that represents the info on one file
|
||||||
that the makefile says how to make.
|
that the makefile says how to make.
|
||||||
All of these are chained together through `next'. */
|
All of these are chained together through 'next'. */
|
||||||
|
|
||||||
#include "hash.h"
|
#include "hash.h"
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ struct file
|
||||||
struct file *last; /* Last entry for the same file name. */
|
struct file *last; /* Last entry for the same file name. */
|
||||||
|
|
||||||
/* File that this file was renamed to. After any time that a
|
/* File that this file was renamed to. After any time that a
|
||||||
file could be renamed, call `check_renamed' (below). */
|
file could be renamed, call 'check_renamed' (below). */
|
||||||
struct file *renamed;
|
struct file *renamed;
|
||||||
|
|
||||||
/* List of variable sets used for this file. */
|
/* List of variable sets used for this file. */
|
||||||
|
@ -189,10 +189,10 @@ FILE_TIMESTAMP f_mtime (struct file *file, int search);
|
||||||
<< FILE_TIMESTAMP_LO_BITS) \
|
<< FILE_TIMESTAMP_LO_BITS) \
|
||||||
+ ORDINARY_MTIME_MIN + FILE_TIMESTAMPS_PER_S - 1)
|
+ ORDINARY_MTIME_MIN + FILE_TIMESTAMPS_PER_S - 1)
|
||||||
|
|
||||||
/* Modtime value to use for `infinitely new'. We used to get the current time
|
/* Modtime value to use for 'infinitely new'. We used to get the current time
|
||||||
from the system and use that whenever we wanted `new'. But that causes
|
from the system and use that whenever we wanted 'new'. But that causes
|
||||||
trouble when the machine running make and the machine holding a file have
|
trouble when the machine running make and the machine holding a file have
|
||||||
different ideas about what time it is; and can also lose for `force'
|
different ideas about what time it is; and can also lose for 'force'
|
||||||
targets, which need to be considered newer than anything that depends on
|
targets, which need to be considered newer than anything that depends on
|
||||||
them, even if said dependents' modtimes are in the future. */
|
them, even if said dependents' modtimes are in the future. */
|
||||||
#define NEW_MTIME INTEGER_TYPE_MAXIMUM (FILE_TIMESTAMP)
|
#define NEW_MTIME INTEGER_TYPE_MAXIMUM (FILE_TIMESTAMP)
|
||||||
|
|
30
function.c
30
function.c
|
@ -356,7 +356,7 @@ string_glob (char *line)
|
||||||
unsigned int idx;
|
unsigned int idx;
|
||||||
|
|
||||||
chain = PARSE_FILE_SEQ (&line, struct nameseq, '\0', NULL,
|
chain = PARSE_FILE_SEQ (&line, struct nameseq, '\0', NULL,
|
||||||
/* We do not want parse_file_seq to strip `./'s.
|
/* We do not want parse_file_seq to strip './'s.
|
||||||
That would break examples like:
|
That would break examples like:
|
||||||
$(patsubst ./%.c,obj/%.o,$(wildcard ./?*.c)). */
|
$(patsubst ./%.c,obj/%.o,$(wildcard ./?*.c)). */
|
||||||
PARSEFS_NOSTRIP|PARSEFS_NOCACHE|PARSEFS_EXISTS);
|
PARSEFS_NOSTRIP|PARSEFS_NOCACHE|PARSEFS_EXISTS);
|
||||||
|
@ -755,12 +755,12 @@ func_word (char *o, char **argv, const char *funcname UNUSED)
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* Check the first argument. */
|
/* Check the first argument. */
|
||||||
check_numeric (argv[0], _("non-numeric first argument to `word' function"));
|
check_numeric (argv[0], _("non-numeric first argument to 'word' function"));
|
||||||
i = atoi (argv[0]);
|
i = atoi (argv[0]);
|
||||||
|
|
||||||
if (i == 0)
|
if (i == 0)
|
||||||
fatal (*expanding_var,
|
fatal (*expanding_var,
|
||||||
_("first argument to `word' function must be greater than 0"));
|
_("first argument to 'word' function must be greater than 0"));
|
||||||
|
|
||||||
end_p = argv[1];
|
end_p = argv[1];
|
||||||
while ((p = find_next_token (&end_p, 0)) != 0)
|
while ((p = find_next_token (&end_p, 0)) != 0)
|
||||||
|
@ -780,14 +780,14 @@ func_wordlist (char *o, char **argv, const char *funcname UNUSED)
|
||||||
|
|
||||||
/* Check the arguments. */
|
/* Check the arguments. */
|
||||||
check_numeric (argv[0],
|
check_numeric (argv[0],
|
||||||
_("non-numeric first argument to `wordlist' function"));
|
_("non-numeric first argument to 'wordlist' function"));
|
||||||
check_numeric (argv[1],
|
check_numeric (argv[1],
|
||||||
_("non-numeric second argument to `wordlist' function"));
|
_("non-numeric second argument to 'wordlist' function"));
|
||||||
|
|
||||||
start = atoi (argv[0]);
|
start = atoi (argv[0]);
|
||||||
if (start < 1)
|
if (start < 1)
|
||||||
fatal (*expanding_var,
|
fatal (*expanding_var,
|
||||||
"invalid first argument to `wordlist' function: `%d'", start);
|
"invalid first argument to 'wordlist' function: '%d'", start);
|
||||||
|
|
||||||
count = atoi (argv[1]) - start + 1;
|
count = atoi (argv[1]) - start + 1;
|
||||||
|
|
||||||
|
@ -1509,7 +1509,7 @@ windows32_openpipe (int *pipedes, pid_t *pid_p, char **command_argv, char **envp
|
||||||
|
|
||||||
/* make sure that CreateProcess() has Path it needs */
|
/* make sure that CreateProcess() has Path it needs */
|
||||||
sync_Path_environment();
|
sync_Path_environment();
|
||||||
/* `sync_Path_environment' may realloc `environ', so take note of
|
/* 'sync_Path_environment' may realloc 'environ', so take note of
|
||||||
the new value. */
|
the new value. */
|
||||||
envp = environ;
|
envp = environ;
|
||||||
|
|
||||||
|
@ -1552,7 +1552,7 @@ FILE *
|
||||||
msdos_openpipe (int* pipedes, int *pidp, char *text)
|
msdos_openpipe (int* pipedes, int *pidp, char *text)
|
||||||
{
|
{
|
||||||
FILE *fpipe=0;
|
FILE *fpipe=0;
|
||||||
/* MSDOS can't fork, but it has `popen'. */
|
/* MSDOS can't fork, but it has 'popen'. */
|
||||||
struct variable *sh = lookup_variable ("SHELL", 5);
|
struct variable *sh = lookup_variable ("SHELL", 5);
|
||||||
int e;
|
int e;
|
||||||
extern int dos_command_running, dos_status;
|
extern int dos_command_running, dos_status;
|
||||||
|
@ -1656,7 +1656,7 @@ func_shell_base (char *o, char **argv, int trim_newlines)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Using a target environment for `shell' loses in cases like:
|
/* Using a target environment for 'shell' loses in cases like:
|
||||||
export var = $(shell echo foobie)
|
export var = $(shell echo foobie)
|
||||||
because target_environment hits a loop trying to expand $(var)
|
because target_environment hits a loop trying to expand $(var)
|
||||||
to put it in the environment. This is even more confusing when
|
to put it in the environment. This is even more confusing when
|
||||||
|
@ -1740,7 +1740,7 @@ func_shell_base (char *o, char **argv, int trim_newlines)
|
||||||
|
|
||||||
/* Close the write side of the pipe. We test for -1, since
|
/* Close the write side of the pipe. We test for -1, since
|
||||||
pipedes[1] is -1 on MS-Windows, and some versions of MS
|
pipedes[1] is -1 on MS-Windows, and some versions of MS
|
||||||
libraries barf when `close' is called with -1. */
|
libraries barf when 'close' is called with -1. */
|
||||||
if (pipedes[1] >= 0)
|
if (pipedes[1] >= 0)
|
||||||
close (pipedes[1]);
|
close (pipedes[1]);
|
||||||
#endif
|
#endif
|
||||||
|
@ -1946,8 +1946,8 @@ func_not (char *o, char **argv, char *funcname)
|
||||||
#define ROOT_LEN 1
|
#define ROOT_LEN 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Return the absolute name of file NAME which does not contain any `.',
|
/* Return the absolute name of file NAME which does not contain any '.',
|
||||||
`..' components nor any repeated path separators ('/'). */
|
'..' components nor any repeated path separators ('/'). */
|
||||||
|
|
||||||
static char *
|
static char *
|
||||||
abspath (const char *name, char *apath)
|
abspath (const char *name, char *apath)
|
||||||
|
@ -2247,7 +2247,7 @@ expand_builtin_function (char *o, int argc, char **argv,
|
||||||
{
|
{
|
||||||
if (argc < (int)entry_p->minimum_args)
|
if (argc < (int)entry_p->minimum_args)
|
||||||
fatal (*expanding_var,
|
fatal (*expanding_var,
|
||||||
_("insufficient number of arguments (%d) to function `%s'"),
|
_("insufficient number of arguments (%d) to function '%s'"),
|
||||||
argc, entry_p->name);
|
argc, entry_p->name);
|
||||||
|
|
||||||
/* I suppose technically some function could do something with no
|
/* I suppose technically some function could do something with no
|
||||||
|
@ -2259,7 +2259,7 @@ expand_builtin_function (char *o, int argc, char **argv,
|
||||||
|
|
||||||
if (!entry_p->func_ptr)
|
if (!entry_p->func_ptr)
|
||||||
fatal (*expanding_var,
|
fatal (*expanding_var,
|
||||||
_("unimplemented on this platform: function `%s'"), entry_p->name);
|
_("unimplemented on this platform: function '%s'"), entry_p->name);
|
||||||
|
|
||||||
return entry_p->func_ptr (o, argv, entry_p->name);
|
return entry_p->func_ptr (o, argv, entry_p->name);
|
||||||
}
|
}
|
||||||
|
@ -2309,7 +2309,7 @@ handle_function (char **op, const char **stringp)
|
||||||
|
|
||||||
if (count >= 0)
|
if (count >= 0)
|
||||||
fatal (*expanding_var,
|
fatal (*expanding_var,
|
||||||
_("unterminated call to function `%s': missing `%c'"),
|
_("unterminated call to function '%s': missing '%c'"),
|
||||||
entry_p->name, closeparen);
|
entry_p->name, closeparen);
|
||||||
|
|
||||||
*stringp = end;
|
*stringp = end;
|
||||||
|
|
|
@ -86,9 +86,9 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
|
||||||
/* Exclude all the code except the test program at the end
|
/* Exclude all the code except the test program at the end
|
||||||
if the system has its own `getloadavg' function.
|
if the system has its own 'getloadavg' function.
|
||||||
|
|
||||||
The declaration of `errno' is needed by the test program
|
The declaration of 'errno' is needed by the test program
|
||||||
as well as the function itself, so it comes first. */
|
as well as the function itself, so it comes first. */
|
||||||
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
@ -745,7 +745,7 @@ getloadavg (double loadavg[], int nelem)
|
||||||
# define LDAV_DONE
|
# define LDAV_DONE
|
||||||
/* This call can return -1 for an error, but with good args
|
/* This call can return -1 for an error, but with good args
|
||||||
it's not supposed to fail. The first argument is for no
|
it's not supposed to fail. The first argument is for no
|
||||||
apparent reason of type `long int *'. */
|
apparent reason of type 'long int *'. */
|
||||||
dg_sys_info ((long int *) &load_info,
|
dg_sys_info ((long int *) &load_info,
|
||||||
DG_SYS_INFO_LOAD_INFO_TYPE,
|
DG_SYS_INFO_LOAD_INFO_TYPE,
|
||||||
DG_SYS_INFO_LOAD_VERSION_0);
|
DG_SYS_INFO_LOAD_VERSION_0);
|
||||||
|
|
22
getopt.c
22
getopt.c
|
@ -83,7 +83,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
#define _(msgid) gettext (msgid)
|
#define _(msgid) gettext (msgid)
|
||||||
|
|
||||||
|
|
||||||
/* This version of `getopt' appears to the caller like standard Unix `getopt'
|
/* This version of `getopt' appears to the caller like standard Unix 'getopt'
|
||||||
but it behaves differently for the user, since it allows the user
|
but it behaves differently for the user, since it allows the user
|
||||||
to intersperse the options with the other arguments.
|
to intersperse the options with the other arguments.
|
||||||
|
|
||||||
|
@ -658,7 +658,7 @@ _getopt_internal (int argc, char *const *argv, const char *optstring,
|
||||||
if (ambig && !exact)
|
if (ambig && !exact)
|
||||||
{
|
{
|
||||||
if (opterr)
|
if (opterr)
|
||||||
fprintf (stderr, _("%s: option `%s' is ambiguous\n"),
|
fprintf (stderr, _("%s: option '%s' is ambiguous\n"),
|
||||||
argv[0], argv[optind]);
|
argv[0], argv[optind]);
|
||||||
nextchar += strlen (nextchar);
|
nextchar += strlen (nextchar);
|
||||||
optind++;
|
optind++;
|
||||||
|
@ -682,12 +682,12 @@ _getopt_internal (int argc, char *const *argv, const char *optstring,
|
||||||
if (argv[optind - 1][1] == '-')
|
if (argv[optind - 1][1] == '-')
|
||||||
/* --option */
|
/* --option */
|
||||||
fprintf (stderr,
|
fprintf (stderr,
|
||||||
_("%s: option `--%s' doesn't allow an argument\n"),
|
_("%s: option '--%s' doesn't allow an argument\n"),
|
||||||
argv[0], pfound->name);
|
argv[0], pfound->name);
|
||||||
else
|
else
|
||||||
/* +option or -option */
|
/* +option or -option */
|
||||||
fprintf (stderr,
|
fprintf (stderr,
|
||||||
_("%s: option `%c%s' doesn't allow an argument\n"),
|
_("%s: option '%c%s' doesn't allow an argument\n"),
|
||||||
argv[0], argv[optind - 1][0], pfound->name);
|
argv[0], argv[optind - 1][0], pfound->name);
|
||||||
|
|
||||||
nextchar += strlen (nextchar);
|
nextchar += strlen (nextchar);
|
||||||
|
@ -704,7 +704,7 @@ _getopt_internal (int argc, char *const *argv, const char *optstring,
|
||||||
{
|
{
|
||||||
if (opterr)
|
if (opterr)
|
||||||
fprintf (stderr,
|
fprintf (stderr,
|
||||||
_("%s: option `%s' requires an argument\n"),
|
_("%s: option '%s' requires an argument\n"),
|
||||||
argv[0], argv[optind - 1]);
|
argv[0], argv[optind - 1]);
|
||||||
nextchar += strlen (nextchar);
|
nextchar += strlen (nextchar);
|
||||||
optopt = pfound->val;
|
optopt = pfound->val;
|
||||||
|
@ -733,11 +733,11 @@ _getopt_internal (int argc, char *const *argv, const char *optstring,
|
||||||
{
|
{
|
||||||
if (argv[optind][1] == '-')
|
if (argv[optind][1] == '-')
|
||||||
/* --option */
|
/* --option */
|
||||||
fprintf (stderr, _("%s: unrecognized option `--%s'\n"),
|
fprintf (stderr, _("%s: unrecognized option '--%s'\n"),
|
||||||
argv[0], nextchar);
|
argv[0], nextchar);
|
||||||
else
|
else
|
||||||
/* +option or -option */
|
/* +option or -option */
|
||||||
fprintf (stderr, _("%s: unrecognized option `%c%s'\n"),
|
fprintf (stderr, _("%s: unrecognized option '%c%s'\n"),
|
||||||
argv[0], argv[optind][0], nextchar);
|
argv[0], argv[optind][0], nextchar);
|
||||||
}
|
}
|
||||||
nextchar = (char *) "";
|
nextchar = (char *) "";
|
||||||
|
@ -843,7 +843,7 @@ _getopt_internal (int argc, char *const *argv, const char *optstring,
|
||||||
if (ambig && !exact)
|
if (ambig && !exact)
|
||||||
{
|
{
|
||||||
if (opterr)
|
if (opterr)
|
||||||
fprintf (stderr, _("%s: option `-W %s' is ambiguous\n"),
|
fprintf (stderr, _("%s: option '-W %s' is ambiguous\n"),
|
||||||
argv[0], argv[optind]);
|
argv[0], argv[optind]);
|
||||||
nextchar += strlen (nextchar);
|
nextchar += strlen (nextchar);
|
||||||
optind++;
|
optind++;
|
||||||
|
@ -862,7 +862,7 @@ _getopt_internal (int argc, char *const *argv, const char *optstring,
|
||||||
{
|
{
|
||||||
if (opterr)
|
if (opterr)
|
||||||
fprintf (stderr, _("\
|
fprintf (stderr, _("\
|
||||||
%s: option `-W %s' doesn't allow an argument\n"),
|
%s: option '-W %s' doesn't allow an argument\n"),
|
||||||
argv[0], pfound->name);
|
argv[0], pfound->name);
|
||||||
|
|
||||||
nextchar += strlen (nextchar);
|
nextchar += strlen (nextchar);
|
||||||
|
@ -877,7 +877,7 @@ _getopt_internal (int argc, char *const *argv, const char *optstring,
|
||||||
{
|
{
|
||||||
if (opterr)
|
if (opterr)
|
||||||
fprintf (stderr,
|
fprintf (stderr,
|
||||||
_("%s: option `%s' requires an argument\n"),
|
_("%s: option '%s' requires an argument\n"),
|
||||||
argv[0], argv[optind - 1]);
|
argv[0], argv[optind - 1]);
|
||||||
nextchar += strlen (nextchar);
|
nextchar += strlen (nextchar);
|
||||||
return optstring[0] == ':' ? ':' : '?';
|
return optstring[0] == ':' ? ':' : '?';
|
||||||
|
@ -1003,7 +1003,7 @@ main (int argc, char **argv)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'c':
|
case 'c':
|
||||||
printf ("option c with value `%s'\n", optarg);
|
printf ("option c with value '%s'\n", optarg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case '?':
|
case '?':
|
||||||
|
|
|
@ -149,11 +149,11 @@ main (int argc, char **argv)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'c':
|
case 'c':
|
||||||
printf ("option c with value `%s'\n", optarg);
|
printf ("option c with value '%s'\n", optarg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'd':
|
case 'd':
|
||||||
printf ("option d with value `%s'\n", optarg);
|
printf ("option d with value '%s'\n", optarg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case '?':
|
case '?':
|
||||||
|
|
8
hash.c
8
hash.c
|
@ -26,7 +26,7 @@ static void hash_rehash __P((struct hash_table* ht));
|
||||||
static unsigned long round_up_2 __P((unsigned long rough));
|
static unsigned long round_up_2 __P((unsigned long rough));
|
||||||
|
|
||||||
/* Implement double hashing with open addressing. The table size is
|
/* Implement double hashing with open addressing. The table size is
|
||||||
always a power of two. The secondary (`increment') hash function
|
always a power of two. The secondary ('increment') hash function
|
||||||
is forced to return an odd-value, in order to be relatively prime
|
is forced to return an odd-value, in order to be relatively prime
|
||||||
to the table size. This guarantees that the increment can
|
to the table size. This guarantees that the increment can
|
||||||
potentially hit every slot in the table during collision
|
potentially hit every slot in the table during collision
|
||||||
|
@ -61,7 +61,7 @@ hash_init (struct hash_table *ht, unsigned long size,
|
||||||
ht->ht_compare = hash_cmp;
|
ht->ht_compare = hash_cmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Load an array of items into `ht'. */
|
/* Load an array of items into 'ht'. */
|
||||||
|
|
||||||
void
|
void
|
||||||
hash_load (struct hash_table *ht, void *item_table,
|
hash_load (struct hash_table *ht, void *item_table,
|
||||||
|
@ -75,9 +75,9 @@ hash_load (struct hash_table *ht, void *item_table,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Returns the address of the table slot matching `key'. If `key' is
|
/* Returns the address of the table slot matching 'key'. If 'key' is
|
||||||
not found, return the address of an empty slot suitable for
|
not found, return the address of an empty slot suitable for
|
||||||
inserting `key'. The caller is responsible for incrementing
|
inserting 'key'. The caller is responsible for incrementing
|
||||||
ht_fill on insertion. */
|
ht_fill on insertion. */
|
||||||
|
|
||||||
void **
|
void **
|
||||||
|
|
6
hash.h
6
hash.h
|
@ -28,9 +28,9 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
#else /* Not C++ or ANSI C. */
|
#else /* Not C++ or ANSI C. */
|
||||||
# undef __P
|
# undef __P
|
||||||
# define __P(protos) ()
|
# define __P(protos) ()
|
||||||
/* We can get away without defining `const' here only because in this file
|
/* We can get away without defining 'const' here only because in this file
|
||||||
it is used only inside the prototype for `fnmatch', which is elided in
|
it is used only inside the prototype for 'fnmatch', which is elided in
|
||||||
non-ANSI C where `const' is problematical. */
|
non-ANSI C where 'const' is problematical. */
|
||||||
#endif /* C++ or ANSI C. */
|
#endif /* C++ or ANSI C. */
|
||||||
|
|
||||||
typedef unsigned long (*hash_func_t) __P((void const *key));
|
typedef unsigned long (*hash_func_t) __P((void const *key));
|
||||||
|
|
30
implicit.c
30
implicit.c
|
@ -37,7 +37,7 @@ static int pattern_search (struct file *file, int archive,
|
||||||
int
|
int
|
||||||
try_implicit_rule (struct file *file, unsigned int depth)
|
try_implicit_rule (struct file *file, unsigned int depth)
|
||||||
{
|
{
|
||||||
DBF (DB_IMPLICIT, _("Looking for an implicit rule for `%s'.\n"));
|
DBF (DB_IMPLICIT, _("Looking for an implicit rule for '%s'.\n"));
|
||||||
|
|
||||||
/* The order of these searches was previously reversed. My logic now is
|
/* The order of these searches was previously reversed. My logic now is
|
||||||
that since the non-archive search uses more information in the target
|
that since the non-archive search uses more information in the target
|
||||||
|
@ -53,7 +53,7 @@ try_implicit_rule (struct file *file, unsigned int depth)
|
||||||
if (ar_name (file->name))
|
if (ar_name (file->name))
|
||||||
{
|
{
|
||||||
DBF (DB_IMPLICIT,
|
DBF (DB_IMPLICIT,
|
||||||
_("Looking for archive-member implicit rule for `%s'.\n"));
|
_("Looking for archive-member implicit rule for '%s'.\n"));
|
||||||
if (pattern_search (file, 1, depth, 0))
|
if (pattern_search (file, 1, depth, 0))
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -251,7 +251,7 @@ pattern_search (struct file *file, int archive,
|
||||||
int file_vars_initialized = 0;
|
int file_vars_initialized = 0;
|
||||||
|
|
||||||
/* Nonzero if we have matched a pattern-rule target
|
/* Nonzero if we have matched a pattern-rule target
|
||||||
that is not just `%'. */
|
that is not just '%'. */
|
||||||
int specific_rule_matched = 0;
|
int specific_rule_matched = 0;
|
||||||
|
|
||||||
struct dep dep_simple;
|
struct dep dep_simple;
|
||||||
|
@ -490,12 +490,12 @@ pattern_search (struct file *file, int archive,
|
||||||
|
|
||||||
if (stemlen > GET_PATH_MAX)
|
if (stemlen > GET_PATH_MAX)
|
||||||
{
|
{
|
||||||
DBS (DB_IMPLICIT, (_("Stem too long: `%.*s'.\n"),
|
DBS (DB_IMPLICIT, (_("Stem too long: '%.*s'.\n"),
|
||||||
(int) stemlen, stem));
|
(int) stemlen, stem));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
DBS (DB_IMPLICIT, (_("Trying pattern rule with stem `%.*s'.\n"),
|
DBS (DB_IMPLICIT, (_("Trying pattern rule with stem '%.*s'.\n"),
|
||||||
(int) stemlen, stem));
|
(int) stemlen, stem));
|
||||||
|
|
||||||
strncpy (stem_str, stem, stemlen);
|
strncpy (stem_str, stem, stemlen);
|
||||||
|
@ -678,8 +678,8 @@ pattern_search (struct file *file, int archive,
|
||||||
second pass either since we know that will fail. */
|
second pass either since we know that will fail. */
|
||||||
DBS (DB_IMPLICIT,
|
DBS (DB_IMPLICIT,
|
||||||
(is_rule
|
(is_rule
|
||||||
? _("Rejecting impossible rule prerequisite `%s'.\n")
|
? _("Rejecting impossible rule prerequisite '%s'.\n")
|
||||||
: _("Rejecting impossible implicit prerequisite `%s'.\n"),
|
: _("Rejecting impossible implicit prerequisite '%s'.\n"),
|
||||||
d->name));
|
d->name));
|
||||||
tryrules[ri].rule = 0;
|
tryrules[ri].rule = 0;
|
||||||
|
|
||||||
|
@ -692,8 +692,8 @@ pattern_search (struct file *file, int archive,
|
||||||
|
|
||||||
DBS (DB_IMPLICIT,
|
DBS (DB_IMPLICIT,
|
||||||
(is_rule
|
(is_rule
|
||||||
? _("Trying rule prerequisite `%s'.\n")
|
? _("Trying rule prerequisite '%s'.\n")
|
||||||
: _("Trying implicit prerequisite `%s'.\n"), d->name));
|
: _("Trying implicit prerequisite '%s'.\n"), d->name));
|
||||||
|
|
||||||
/* If this prereq is also explicitly mentioned for FILE,
|
/* If this prereq is also explicitly mentioned for FILE,
|
||||||
skip all tests below since it must be built no matter
|
skip all tests below since it must be built no matter
|
||||||
|
@ -732,7 +732,7 @@ pattern_search (struct file *file, int archive,
|
||||||
if (vname)
|
if (vname)
|
||||||
{
|
{
|
||||||
DBS (DB_IMPLICIT,
|
DBS (DB_IMPLICIT,
|
||||||
(_("Found prerequisite `%s' as VPATH `%s'\n"),
|
(_("Found prerequisite '%s' as VPATH '%s'\n"),
|
||||||
d->name, vname));
|
d->name, vname));
|
||||||
(pat++)->name = d->name;
|
(pat++)->name = d->name;
|
||||||
continue;
|
continue;
|
||||||
|
@ -746,7 +746,7 @@ pattern_search (struct file *file, int archive,
|
||||||
if (intermed_ok)
|
if (intermed_ok)
|
||||||
{
|
{
|
||||||
DBS (DB_IMPLICIT,
|
DBS (DB_IMPLICIT,
|
||||||
(_("Looking for a rule with intermediate file `%s'.\n"),
|
(_("Looking for a rule with intermediate file '%s'.\n"),
|
||||||
d->name));
|
d->name));
|
||||||
|
|
||||||
if (int_file == 0)
|
if (int_file == 0)
|
||||||
|
@ -795,7 +795,7 @@ pattern_search (struct file *file, int archive,
|
||||||
|
|
||||||
file->stem = 0;
|
file->stem = 0;
|
||||||
|
|
||||||
/* This rule is no longer `in use' for recursive searches. */
|
/* This rule is no longer 'in use' for recursive searches. */
|
||||||
rule->in_use = 0;
|
rule->in_use = 0;
|
||||||
|
|
||||||
if (! failed)
|
if (! failed)
|
||||||
|
@ -897,8 +897,8 @@ pattern_search (struct file *file, int archive,
|
||||||
/* If the file actually existed (was not an intermediate file), and
|
/* If the file actually existed (was not an intermediate file), and
|
||||||
the rule that found it was a terminal one, then we want to mark
|
the rule that found it was a terminal one, then we want to mark
|
||||||
the found file so that it will not have implicit rule search done
|
the found file so that it will not have implicit rule search done
|
||||||
for it. If we are not entering a `struct file' for it now, we
|
for it. If we are not entering a 'struct file' for it now, we
|
||||||
indicate this with the `changed' flag. */
|
indicate this with the 'changed' flag. */
|
||||||
if (dep->file == 0)
|
if (dep->file == 0)
|
||||||
dep->changed = 1;
|
dep->changed = 1;
|
||||||
else
|
else
|
||||||
|
@ -942,7 +942,7 @@ pattern_search (struct file *file, int archive,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If this rule builds other targets, too, put the others into FILE's
|
/* If this rule builds other targets, too, put the others into FILE's
|
||||||
`also_make' member. */
|
'also_make' member. */
|
||||||
|
|
||||||
if (rule->num > 1)
|
if (rule->num > 1)
|
||||||
for (ri = 0; ri < rule->num; ++ri)
|
for (ri = 0; ri < rule->num; ++ri)
|
||||||
|
|
82
job.c
82
job.c
|
@ -154,7 +154,7 @@ int wait ();
|
||||||
# define WIFEXITED(x) (WTERMSIG (x) == 0)
|
# define WIFEXITED(x) (WTERMSIG (x) == 0)
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
#else /* Have `union wait'. */
|
#else /* Have 'union wait'. */
|
||||||
|
|
||||||
# define WAIT_T union wait
|
# define WAIT_T union wait
|
||||||
# ifndef WTERMSIG
|
# ifndef WTERMSIG
|
||||||
|
@ -173,7 +173,7 @@ int wait ();
|
||||||
# define WIFEXITED(x) (WTERMSIG(x) == 0)
|
# define WIFEXITED(x) (WTERMSIG(x) == 0)
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
#endif /* Don't have `union wait'. */
|
#endif /* Don't have 'union wait'. */
|
||||||
|
|
||||||
#if !defined(HAVE_UNISTD_H) && !defined(WINDOWS32)
|
#if !defined(HAVE_UNISTD_H) && !defined(WINDOWS32)
|
||||||
int dup2 ();
|
int dup2 ();
|
||||||
|
@ -225,7 +225,7 @@ struct child *children = 0;
|
||||||
|
|
||||||
unsigned int job_slots_used = 0;
|
unsigned int job_slots_used = 0;
|
||||||
|
|
||||||
/* Nonzero if the `good' standard input is in use. */
|
/* Nonzero if the 'good' standard input is in use. */
|
||||||
|
|
||||||
static int good_stdin_used = 0;
|
static int good_stdin_used = 0;
|
||||||
|
|
||||||
|
@ -467,7 +467,7 @@ child_error (const struct file *file,
|
||||||
sprintf (a, "%s:%lu", flocp->filenm, flocp->lineno);
|
sprintf (a, "%s:%lu", flocp->filenm, flocp->lineno);
|
||||||
nm = a;
|
nm = a;
|
||||||
}
|
}
|
||||||
message (0, _("%s: recipe for target `%s' failed"), nm, file->name);
|
message (0, _("%s: recipe for target '%s' failed"), nm, file->name);
|
||||||
|
|
||||||
#ifdef VMS
|
#ifdef VMS
|
||||||
if (!(exit_code & 1))
|
if (!(exit_code & 1))
|
||||||
|
@ -518,7 +518,7 @@ child_handler (int sig UNUSED)
|
||||||
extern int shell_function_pid, shell_function_completed;
|
extern int shell_function_pid, shell_function_completed;
|
||||||
|
|
||||||
/* Reap all dead children, storing the returned status and the new command
|
/* Reap all dead children, storing the returned status and the new command
|
||||||
state (`cs_finished') in the `file' member of the `struct child' for the
|
state ('cs_finished') in the 'file' member of the 'struct child' for the
|
||||||
dead child, and removing the child from the chain. In addition, if BLOCK
|
dead child, and removing the child from the chain. In addition, if BLOCK
|
||||||
nonzero, we block in this function until we've reaped at least one
|
nonzero, we block in this function until we've reaped at least one
|
||||||
complete child, waiting for it to die if necessary. If ERR is nonzero,
|
complete child, waiting for it to die if necessary. If ERR is nonzero,
|
||||||
|
@ -763,10 +763,10 @@ reap_children (int block, int err)
|
||||||
#endif /* WINDOWS32 */
|
#endif /* WINDOWS32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check if this is the child of the `shell' function. */
|
/* Check if this is the child of the 'shell' function. */
|
||||||
if (!remote && pid == shell_function_pid)
|
if (!remote && pid == shell_function_pid)
|
||||||
{
|
{
|
||||||
/* It is. Leave an indicator for the `shell' function. */
|
/* It is. Leave an indicator for the 'shell' function. */
|
||||||
if (exit_sig == 0 && exit_code == 127)
|
if (exit_sig == 0 && exit_code == 127)
|
||||||
shell_function_completed = -1;
|
shell_function_completed = -1;
|
||||||
else
|
else
|
||||||
|
@ -1064,7 +1064,7 @@ set_child_handler_action_flags (int set_handler, int set_alarm)
|
||||||
CHILD is updated to reflect the commands and ID of the child process.
|
CHILD is updated to reflect the commands and ID of the child process.
|
||||||
|
|
||||||
NOTE: On return fatal signals are blocked! The caller is responsible
|
NOTE: On return fatal signals are blocked! The caller is responsible
|
||||||
for calling `unblock_sigs', once the new child is safely on the chain so
|
for calling 'unblock_sigs', once the new child is safely on the chain so
|
||||||
it can be cleaned up in the event of a fatal signal. */
|
it can be cleaned up in the event of a fatal signal. */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1151,9 +1151,9 @@ start_job_command (struct child *child)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If -q was given, say that updating `failed' if there was any text on the
|
/* If -q was given, say that updating 'failed' if there was any text on the
|
||||||
command line, or `succeeded' otherwise. The exit status of 1 tells the
|
command line, or 'succeeded' otherwise. The exit status of 1 tells the
|
||||||
user that -q is saying `something to do'; the exit status for a random
|
user that -q is saying 'something to do'; the exit status for a random
|
||||||
error is 2. */
|
error is 2. */
|
||||||
if (argv != 0 && question_flag && !(flags & COMMANDS_RECURSE))
|
if (argv != 0 && question_flag && !(flags & COMMANDS_RECURSE))
|
||||||
{
|
{
|
||||||
|
@ -1200,7 +1200,7 @@ start_job_command (struct child *child)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Print out the command. If silent, we call `message' with null so it
|
/* Print out the command. If silent, we call 'message' with null so it
|
||||||
can log the working directory before the command's own error messages
|
can log the working directory before the command's own error messages
|
||||||
appear. */
|
appear. */
|
||||||
|
|
||||||
|
@ -1286,8 +1286,8 @@ start_job_command (struct child *child)
|
||||||
|
|
||||||
#endif /* !WINDOWS32 && !_AMIGA && !__MSDOS__ */
|
#endif /* !WINDOWS32 && !_AMIGA && !__MSDOS__ */
|
||||||
|
|
||||||
/* Decide whether to give this child the `good' standard input
|
/* Decide whether to give this child the 'good' standard input
|
||||||
(one that points to the terminal or whatever), or the `bad' one
|
(one that points to the terminal or whatever), or the 'bad' one
|
||||||
that points to the read side of a broken pipe. */
|
that points to the read side of a broken pipe. */
|
||||||
|
|
||||||
child->good_stdin = !good_stdin_used;
|
child->good_stdin = !good_stdin_used;
|
||||||
|
@ -1429,25 +1429,25 @@ start_job_command (struct child *child)
|
||||||
block_sigs ();
|
block_sigs ();
|
||||||
dos_status = 0;
|
dos_status = 0;
|
||||||
|
|
||||||
/* We call `system' to do the job of the SHELL, since stock DOS
|
/* We call 'system' to do the job of the SHELL, since stock DOS
|
||||||
shell is too dumb. Our `system' knows how to handle long
|
shell is too dumb. Our 'system' knows how to handle long
|
||||||
command lines even if pipes/redirection is needed; it will only
|
command lines even if pipes/redirection is needed; it will only
|
||||||
call COMMAND.COM when its internal commands are used. */
|
call COMMAND.COM when its internal commands are used. */
|
||||||
if (execute_by_shell)
|
if (execute_by_shell)
|
||||||
{
|
{
|
||||||
char *cmdline = argv[0];
|
char *cmdline = argv[0];
|
||||||
/* We don't have a way to pass environment to `system',
|
/* We don't have a way to pass environment to 'system',
|
||||||
so we need to save and restore ours, sigh... */
|
so we need to save and restore ours, sigh... */
|
||||||
char **parent_environ = environ;
|
char **parent_environ = environ;
|
||||||
|
|
||||||
environ = child->environment;
|
environ = child->environment;
|
||||||
|
|
||||||
/* If we have a *real* shell, tell `system' to call
|
/* If we have a *real* shell, tell 'system' to call
|
||||||
it to do everything for us. */
|
it to do everything for us. */
|
||||||
if (unixy_shell)
|
if (unixy_shell)
|
||||||
{
|
{
|
||||||
/* A *real* shell on MSDOS may not support long
|
/* A *real* shell on MSDOS may not support long
|
||||||
command lines the DJGPP way, so we must use `system'. */
|
command lines the DJGPP way, so we must use 'system'. */
|
||||||
cmdline = argv[2]; /* get past "shell -c" */
|
cmdline = argv[2]; /* get past "shell -c" */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1547,7 +1547,7 @@ start_job_command (struct child *child)
|
||||||
|
|
||||||
/* Try to start a child running.
|
/* Try to start a child running.
|
||||||
Returns nonzero if the child was started (and maybe finished), or zero if
|
Returns nonzero if the child was started (and maybe finished), or zero if
|
||||||
the load was too high and the child was put on the `waiting_jobs' chain. */
|
the load was too high and the child was put on the 'waiting_jobs' chain. */
|
||||||
|
|
||||||
static int
|
static int
|
||||||
start_waiting_job (struct child *c)
|
start_waiting_job (struct child *c)
|
||||||
|
@ -1611,7 +1611,7 @@ start_waiting_job (struct child *c)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Create a `struct child' for FILE and start its commands running. */
|
/* Create a 'struct child' for FILE and start its commands running. */
|
||||||
|
|
||||||
void
|
void
|
||||||
new_job (struct file *file)
|
new_job (struct file *file)
|
||||||
|
@ -1734,7 +1734,7 @@ new_job (struct file *file)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Start the command sequence, record it in a new
|
/* Start the command sequence, record it in a new
|
||||||
`struct child', and add that to the chain. */
|
'struct child', and add that to the chain. */
|
||||||
|
|
||||||
c = xcalloc (sizeof (struct child));
|
c = xcalloc (sizeof (struct child));
|
||||||
c->file = file;
|
c->file = file;
|
||||||
|
@ -1893,9 +1893,9 @@ new_job (struct file *file)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (newer[0] == '\0')
|
if (newer[0] == '\0')
|
||||||
message (0, _("%s: target `%s' does not exist"), nm, c->file->name);
|
message (0, _("%s: target '%s' does not exist"), nm, c->file->name);
|
||||||
else
|
else
|
||||||
message (0, _("%s: update target `%s' due to: %s"), nm,
|
message (0, _("%s: update target '%s' due to: %s"), nm,
|
||||||
c->file->name, newer);
|
c->file->name, newer);
|
||||||
|
|
||||||
free (newer);
|
free (newer);
|
||||||
|
@ -1908,7 +1908,7 @@ new_job (struct file *file)
|
||||||
|
|
||||||
if (job_slots == 1 || not_parallel)
|
if (job_slots == 1 || not_parallel)
|
||||||
/* Since there is only one job slot, make things run linearly.
|
/* Since there is only one job slot, make things run linearly.
|
||||||
Wait for the child to die, setting the state to `cs_finished'. */
|
Wait for the child to die, setting the state to 'cs_finished'. */
|
||||||
while (file->command_state == cs_running)
|
while (file->command_state == cs_running)
|
||||||
reap_children (1, 0);
|
reap_children (1, 0);
|
||||||
|
|
||||||
|
@ -2368,7 +2368,7 @@ void clean_tmp (void)
|
||||||
#ifndef VMS
|
#ifndef VMS
|
||||||
/* Figure out the argument list necessary to run LINE as a command. Try to
|
/* Figure out the argument list necessary to run LINE as a command. Try to
|
||||||
avoid using a shell. This routine handles only ' quoting, and " quoting
|
avoid using a shell. This routine handles only ' quoting, and " quoting
|
||||||
when no backslash, $ or ` characters are seen in the quotes. Starting
|
when no backslash, $ or ' characters are seen in the quotes. Starting
|
||||||
quotes may be escaped with a backslash. If any of the characters in
|
quotes may be escaped with a backslash. If any of the characters in
|
||||||
sh_chars[] is seen, or any of the builtin commands listed in sh_cmds[]
|
sh_chars[] is seen, or any of the builtin commands listed in sh_cmds[]
|
||||||
is the first word of a line, the shell is used.
|
is the first word of a line, the shell is used.
|
||||||
|
@ -2391,22 +2391,22 @@ construct_command_argv_internal (char *line, char **restp, char *shell,
|
||||||
{
|
{
|
||||||
#ifdef __MSDOS__
|
#ifdef __MSDOS__
|
||||||
/* MSDOS supports both the stock DOS shell and ports of Unixy shells.
|
/* MSDOS supports both the stock DOS shell and ports of Unixy shells.
|
||||||
We call `system' for anything that requires ``slow'' processing,
|
We call 'system' for anything that requires ''slow'' processing,
|
||||||
because DOS shells are too dumb. When $SHELL points to a real
|
because DOS shells are too dumb. When $SHELL points to a real
|
||||||
(unix-style) shell, `system' just calls it to do everything. When
|
(unix-style) shell, 'system' just calls it to do everything. When
|
||||||
$SHELL points to a DOS shell, `system' does most of the work
|
$SHELL points to a DOS shell, 'system' does most of the work
|
||||||
internally, calling the shell only for its internal commands.
|
internally, calling the shell only for its internal commands.
|
||||||
However, it looks on the $PATH first, so you can e.g. have an
|
However, it looks on the $PATH first, so you can e.g. have an
|
||||||
external command named `mkdir'.
|
external command named 'mkdir'.
|
||||||
|
|
||||||
Since we call `system', certain characters and commands below are
|
Since we call 'system', certain characters and commands below are
|
||||||
actually not specific to COMMAND.COM, but to the DJGPP implementation
|
actually not specific to COMMAND.COM, but to the DJGPP implementation
|
||||||
of `system'. In particular:
|
of 'system'. In particular:
|
||||||
|
|
||||||
The shell wildcard characters are in DOS_CHARS because they will
|
The shell wildcard characters are in DOS_CHARS because they will
|
||||||
not be expanded if we call the child via `spawnXX'.
|
not be expanded if we call the child via 'spawnXX'.
|
||||||
|
|
||||||
The `;' is in DOS_CHARS, because our `system' knows how to run
|
The ';' is in DOS_CHARS, because our 'system' knows how to run
|
||||||
multiple commands on a single line.
|
multiple commands on a single line.
|
||||||
|
|
||||||
DOS_CHARS also include characters special to 4DOS/NDOS, so we
|
DOS_CHARS also include characters special to 4DOS/NDOS, so we
|
||||||
|
@ -2562,7 +2562,7 @@ construct_command_argv_internal (char *line, char **restp, char *shell,
|
||||||
{
|
{
|
||||||
extern int _is_unixy_shell (const char *_path);
|
extern int _is_unixy_shell (const char *_path);
|
||||||
|
|
||||||
DB (DB_BASIC, (_("$SHELL changed (was `%s', now `%s')\n"),
|
DB (DB_BASIC, (_("$SHELL changed (was '%s', now '%s')\n"),
|
||||||
default_shell, shell));
|
default_shell, shell));
|
||||||
unixy_shell = _is_unixy_shell (shell);
|
unixy_shell = _is_unixy_shell (shell);
|
||||||
/* we must allocate a copy of shell: construct_command_argv() will free
|
/* we must allocate a copy of shell: construct_command_argv() will free
|
||||||
|
@ -2671,7 +2671,7 @@ construct_command_argv_internal (char *line, char **restp, char *shell,
|
||||||
goto slow;
|
goto slow;
|
||||||
#ifdef __MSDOS__
|
#ifdef __MSDOS__
|
||||||
else if (*p == '.' && p[1] == '.' && p[2] == '.' && p[3] != '.')
|
else if (*p == '.' && p[1] == '.' && p[2] == '.' && p[3] != '.')
|
||||||
/* `...' is a wildcard in DJGPP. */
|
/* '...' is a wildcard in DJGPP. */
|
||||||
goto slow;
|
goto slow;
|
||||||
#endif
|
#endif
|
||||||
else
|
else
|
||||||
|
@ -2760,10 +2760,10 @@ construct_command_argv_internal (char *line, char **restp, char *shell,
|
||||||
last_argument_was_empty = 0;
|
last_argument_was_empty = 0;
|
||||||
|
|
||||||
/* Update SEEN_NONEQUALS, which tells us if every word
|
/* Update SEEN_NONEQUALS, which tells us if every word
|
||||||
heretofore has contained an `='. */
|
heretofore has contained an '='. */
|
||||||
seen_nonequals |= ! word_has_equals;
|
seen_nonequals |= ! word_has_equals;
|
||||||
if (word_has_equals && ! seen_nonequals)
|
if (word_has_equals && ! seen_nonequals)
|
||||||
/* An `=' in a word before the first
|
/* An '=' in a word before the first
|
||||||
word without one is magical. */
|
word without one is magical. */
|
||||||
goto slow;
|
goto slow;
|
||||||
word_has_equals = 0; /* Prepare for the next word. */
|
word_has_equals = 0; /* Prepare for the next word. */
|
||||||
|
@ -2838,7 +2838,7 @@ construct_command_argv_internal (char *line, char **restp, char *shell,
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef __MSDOS__
|
#ifdef __MSDOS__
|
||||||
execute_by_shell = 1; /* actually, call `system' if shell isn't unixy */
|
execute_by_shell = 1; /* actually, call 'system' if shell isn't unixy */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef _AMIGA
|
#ifdef _AMIGA
|
||||||
|
@ -3045,7 +3045,7 @@ construct_command_argv_internal (char *line, char **restp, char *shell,
|
||||||
#ifdef __MSDOS__
|
#ifdef __MSDOS__
|
||||||
else if (unixy_shell && strneq (p, "...", 3))
|
else if (unixy_shell && strneq (p, "...", 3))
|
||||||
{
|
{
|
||||||
/* The case of `...' wildcard again. */
|
/* The case of '...' wildcard again. */
|
||||||
strcpy (ap, "\\.\\.\\");
|
strcpy (ap, "\\.\\.\\");
|
||||||
ap += 5;
|
ap += 5;
|
||||||
p += 2;
|
p += 2;
|
||||||
|
@ -3205,7 +3205,7 @@ construct_command_argv_internal (char *line, char **restp, char *shell,
|
||||||
|
|
||||||
/* Figure out the argument list necessary to run LINE as a command. Try to
|
/* Figure out the argument list necessary to run LINE as a command. Try to
|
||||||
avoid using a shell. This routine handles only ' quoting, and " quoting
|
avoid using a shell. This routine handles only ' quoting, and " quoting
|
||||||
when no backslash, $ or ` characters are seen in the quotes. Starting
|
when no backslash, $ or ' characters are seen in the quotes. Starting
|
||||||
quotes may be escaped with a backslash. If any of the characters in
|
quotes may be escaped with a backslash. If any of the characters in
|
||||||
sh_chars[] is seen, or any of the builtin commands listed in sh_cmds[]
|
sh_chars[] is seen, or any of the builtin commands listed in sh_cmds[]
|
||||||
is the first word of a line, the shell is used.
|
is the first word of a line, the shell is used.
|
||||||
|
|
2
job.h
2
job.h
|
@ -59,7 +59,7 @@ struct child
|
||||||
char *sh_batch_file; /* Script file for shell commands */
|
char *sh_batch_file; /* Script file for shell commands */
|
||||||
unsigned int remote:1; /* Nonzero if executing remotely. */
|
unsigned int remote:1; /* Nonzero if executing remotely. */
|
||||||
|
|
||||||
unsigned int noerror:1; /* Nonzero if commands contained a `-'. */
|
unsigned int noerror:1; /* Nonzero if commands contained a '-'. */
|
||||||
|
|
||||||
unsigned int good_stdin:1; /* Nonzero if this child has a good stdin. */
|
unsigned int good_stdin:1; /* Nonzero if this child has a good stdin. */
|
||||||
unsigned int deleted:1; /* Nonzero if targets have been deleted. */
|
unsigned int deleted:1; /* Nonzero if targets have been deleted. */
|
||||||
|
|
54
main.c
54
main.c
|
@ -489,7 +489,7 @@ struct variable * default_goal_var;
|
||||||
|
|
||||||
struct file *default_file;
|
struct file *default_file;
|
||||||
|
|
||||||
/* Nonzero if we have seen the magic `.POSIX' target.
|
/* Nonzero if we have seen the magic '.POSIX' target.
|
||||||
This turns on pedantic compliance with POSIX.2. */
|
This turns on pedantic compliance with POSIX.2. */
|
||||||
|
|
||||||
int posix_pedantic;
|
int posix_pedantic;
|
||||||
|
@ -505,7 +505,7 @@ int second_expansion;
|
||||||
|
|
||||||
int one_shell;
|
int one_shell;
|
||||||
|
|
||||||
/* Nonzero if we have seen the `.NOTPARALLEL' target.
|
/* Nonzero if we have seen the '.NOTPARALLEL' target.
|
||||||
This turns off parallel builds for this invocation of make. */
|
This turns off parallel builds for this invocation of make. */
|
||||||
|
|
||||||
int not_parallel;
|
int not_parallel;
|
||||||
|
@ -650,7 +650,7 @@ decode_debug_flags (void)
|
||||||
db_level |= DB_BASIC | DB_VERBOSE;
|
db_level |= DB_BASIC | DB_VERBOSE;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
fatal (NILF, _("unknown debug level specification `%s'"), p);
|
fatal (NILF, _("unknown debug level specification '%s'"), p);
|
||||||
}
|
}
|
||||||
|
|
||||||
while (*(++p) != '\0')
|
while (*(++p) != '\0')
|
||||||
|
@ -962,7 +962,7 @@ main (int argc, char **argv, char **envp)
|
||||||
reading_file = 0;
|
reading_file = 0;
|
||||||
|
|
||||||
#if defined (__MSDOS__) && !defined (_POSIX_SOURCE)
|
#if defined (__MSDOS__) && !defined (_POSIX_SOURCE)
|
||||||
/* Request the most powerful version of `system', to
|
/* Request the most powerful version of 'system', to
|
||||||
make up for the dumb default shell. */
|
make up for the dumb default shell. */
|
||||||
__system_flags = (__system_redirect
|
__system_flags = (__system_redirect
|
||||||
| __system_use_shell
|
| __system_use_shell
|
||||||
|
@ -1198,7 +1198,7 @@ main (int argc, char **argv, char **envp)
|
||||||
environment. We used to rely on target_environment's
|
environment. We used to rely on target_environment's
|
||||||
v_default code to do this. But that does not work for the
|
v_default code to do this. But that does not work for the
|
||||||
case where an environment variable is redefined in a makefile
|
case where an environment variable is redefined in a makefile
|
||||||
with `override'; it should then still be exported, because it
|
with 'override'; it should then still be exported, because it
|
||||||
was originally in the environment. */
|
was originally in the environment. */
|
||||||
v->export = v_export;
|
v->export = v_export;
|
||||||
|
|
||||||
|
@ -1294,7 +1294,7 @@ main (int argc, char **argv, char **envp)
|
||||||
{
|
{
|
||||||
print_version ();
|
print_version ();
|
||||||
|
|
||||||
/* `make --version' is supposed to just print the version and exit. */
|
/* 'make --version' is supposed to just print the version and exit. */
|
||||||
if (print_version_flag)
|
if (print_version_flag)
|
||||||
die (0);
|
die (0);
|
||||||
}
|
}
|
||||||
|
@ -1575,7 +1575,7 @@ main (int argc, char **argv, char **envp)
|
||||||
#ifndef __EMX__ /* Don't use a SIGCHLD handler for OS/2 */
|
#ifndef __EMX__ /* Don't use a SIGCHLD handler for OS/2 */
|
||||||
#if defined(MAKE_JOBSERVER) || !defined(HAVE_WAIT_NOHANG)
|
#if defined(MAKE_JOBSERVER) || !defined(HAVE_WAIT_NOHANG)
|
||||||
/* Set up to handle children dying. This must be done before
|
/* Set up to handle children dying. This must be done before
|
||||||
reading in the makefiles so that `shell' function calls will work.
|
reading in the makefiles so that 'shell' function calls will work.
|
||||||
|
|
||||||
If we don't have a hanging wait we have to fall back to old, broken
|
If we don't have a hanging wait we have to fall back to old, broken
|
||||||
functionality here and rely on the signal handler and counting
|
functionality here and rely on the signal handler and counting
|
||||||
|
@ -1734,14 +1734,14 @@ main (int argc, char **argv, char **envp)
|
||||||
if (! open_jobserver_semaphore(cp))
|
if (! open_jobserver_semaphore(cp))
|
||||||
{
|
{
|
||||||
DWORD err = GetLastError();
|
DWORD err = GetLastError();
|
||||||
fatal (NILF, _("internal error: unable to open jobserver semaphore `%s': (Error %ld: %s)"),
|
fatal (NILF, _("internal error: unable to open jobserver semaphore '%s': (Error %ld: %s)"),
|
||||||
cp, err, map_windows32_error_to_string(err));
|
cp, err, map_windows32_error_to_string(err));
|
||||||
}
|
}
|
||||||
DB (DB_JOBS, (_("Jobserver client (semaphore %s)\n"), cp));
|
DB (DB_JOBS, (_("Jobserver client (semaphore %s)\n"), cp));
|
||||||
#else
|
#else
|
||||||
if (sscanf (cp, "%d,%d", &job_fds[0], &job_fds[1]) != 2)
|
if (sscanf (cp, "%d,%d", &job_fds[0], &job_fds[1]) != 2)
|
||||||
fatal (NILF,
|
fatal (NILF,
|
||||||
_("internal error: invalid --jobserver-fds string `%s'"), cp);
|
_("internal error: invalid --jobserver-fds string '%s'"), cp);
|
||||||
|
|
||||||
DB (DB_JOBS,
|
DB (DB_JOBS,
|
||||||
(_("Jobserver client (fds %d,%d)\n"), job_fds[0], job_fds[1]));
|
(_("Jobserver client (fds %d,%d)\n"), job_fds[0], job_fds[1]));
|
||||||
|
@ -1768,7 +1768,7 @@ main (int argc, char **argv, char **envp)
|
||||||
pfatal_with_name (_("dup jobserver"));
|
pfatal_with_name (_("dup jobserver"));
|
||||||
|
|
||||||
error (NILF,
|
error (NILF,
|
||||||
_("warning: jobserver unavailable: using -j1. Add `+' to parent make rule."));
|
_("warning: jobserver unavailable: using -j1. Add '+' to parent make rule."));
|
||||||
job_slots = 1;
|
job_slots = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -1871,7 +1871,7 @@ main (int argc, char **argv, char **envp)
|
||||||
|
|
||||||
define_makeflags (1, 0);
|
define_makeflags (1, 0);
|
||||||
|
|
||||||
/* Make each `struct dep' point at the `struct file' for the file
|
/* Make each 'struct dep' point at the 'struct file' for the file
|
||||||
depended on. Also do magic for special targets. */
|
depended on. Also do magic for special targets. */
|
||||||
|
|
||||||
snap_deps ();
|
snap_deps ();
|
||||||
|
@ -1967,7 +1967,7 @@ main (int argc, char **argv, char **envp)
|
||||||
you write your makefiles.) */
|
you write your makefiles.) */
|
||||||
|
|
||||||
DB (DB_VERBOSE,
|
DB (DB_VERBOSE,
|
||||||
(_("Makefile `%s' might loop; not remaking it.\n"),
|
(_("Makefile '%s' might loop; not remaking it.\n"),
|
||||||
f->name));
|
f->name));
|
||||||
|
|
||||||
if (last == 0)
|
if (last == 0)
|
||||||
|
@ -1995,7 +1995,7 @@ main (int argc, char **argv, char **envp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set up `MAKEFLAGS' specially while remaking makefiles. */
|
/* Set up 'MAKEFLAGS' specially while remaking makefiles. */
|
||||||
define_makeflags (1, 1);
|
define_makeflags (1, 1);
|
||||||
|
|
||||||
rebuilding_makefiles = 1;
|
rebuilding_makefiles = 1;
|
||||||
|
@ -2046,7 +2046,7 @@ main (int argc, char **argv, char **envp)
|
||||||
FILE_TIMESTAMP mtime;
|
FILE_TIMESTAMP mtime;
|
||||||
/* The update failed and this makefile was not
|
/* The update failed and this makefile was not
|
||||||
from the MAKEFILES variable, so we care. */
|
from the MAKEFILES variable, so we care. */
|
||||||
error (NILF, _("Failed to remake makefile `%s'."),
|
error (NILF, _("Failed to remake makefile '%s'."),
|
||||||
d->file->name);
|
d->file->name);
|
||||||
mtime = file_mtime_no_search (d->file);
|
mtime = file_mtime_no_search (d->file);
|
||||||
any_remade |= (mtime != NONEXISTENT_MTIME
|
any_remade |= (mtime != NONEXISTENT_MTIME
|
||||||
|
@ -2063,12 +2063,12 @@ main (int argc, char **argv, char **envp)
|
||||||
/* An included makefile. We don't need
|
/* An included makefile. We don't need
|
||||||
to die, but we do want to complain. */
|
to die, but we do want to complain. */
|
||||||
error (NILF,
|
error (NILF,
|
||||||
_("Included makefile `%s' was not found."),
|
_("Included makefile '%s' was not found."),
|
||||||
dep_name (d));
|
dep_name (d));
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* A normal makefile. We must die later. */
|
/* A normal makefile. We must die later. */
|
||||||
error (NILF, _("Makefile `%s' was not found"),
|
error (NILF, _("Makefile '%s' was not found"),
|
||||||
dep_name (d));
|
dep_name (d));
|
||||||
any_failed = 1;
|
any_failed = 1;
|
||||||
}
|
}
|
||||||
|
@ -2250,7 +2250,7 @@ main (int argc, char **argv, char **envp)
|
||||||
free (makefile_mtimes);
|
free (makefile_mtimes);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set up `MAKEFLAGS' again for the normal targets. */
|
/* Set up 'MAKEFLAGS' again for the normal targets. */
|
||||||
define_makeflags (1, 0);
|
define_makeflags (1, 0);
|
||||||
|
|
||||||
/* Set always_make_flag if -B was given. */
|
/* Set always_make_flag if -B was given. */
|
||||||
|
@ -2443,7 +2443,7 @@ handle_non_switch_argument (char *arg, int env)
|
||||||
/* Non-option argument. It might be a variable definition. */
|
/* Non-option argument. It might be a variable definition. */
|
||||||
struct variable *v;
|
struct variable *v;
|
||||||
if (arg[0] == '-' && arg[1] == '\0')
|
if (arg[0] == '-' && arg[1] == '\0')
|
||||||
/* Ignore plain `-' for compatibility. */
|
/* Ignore plain '-' for compatibility. */
|
||||||
return;
|
return;
|
||||||
v = try_variable_definition (0, arg, o_command, 0);
|
v = try_variable_definition (0, arg, o_command, 0);
|
||||||
if (v != 0)
|
if (v != 0)
|
||||||
|
@ -2617,7 +2617,7 @@ decode_switches (int argc, char **argv, int env)
|
||||||
else
|
else
|
||||||
op = cs->long_name;
|
op = cs->long_name;
|
||||||
|
|
||||||
error (NILF, _("the `%s%s' option requires a non-empty string argument"),
|
error (NILF, _("the '%s%s' option requires a non-empty string argument"),
|
||||||
short_option (cs->c) ? "-" : "--", op);
|
short_option (cs->c) ? "-" : "--", op);
|
||||||
bad = 1;
|
bad = 1;
|
||||||
}
|
}
|
||||||
|
@ -2672,7 +2672,7 @@ decode_switches (int argc, char **argv, int env)
|
||||||
|
|
||||||
if (i < 1 || cp[0] != '\0')
|
if (i < 1 || cp[0] != '\0')
|
||||||
{
|
{
|
||||||
error (NILF, _("the `-%c' option requires a positive integral argument"),
|
error (NILF, _("the '-%c' option requires a positive integral argument"),
|
||||||
cs->c);
|
cs->c);
|
||||||
bad = 1;
|
bad = 1;
|
||||||
}
|
}
|
||||||
|
@ -2812,7 +2812,7 @@ quote_for_env (char *out, const char *in)
|
||||||
|
|
||||||
/* Define the MAKEFLAGS and MFLAGS variables to reflect the settings of the
|
/* Define the MAKEFLAGS and MFLAGS variables to reflect the settings of the
|
||||||
command switches. Include options with args if ALL is nonzero.
|
command switches. Include options with args if ALL is nonzero.
|
||||||
Don't include options with the `no_makefile' flag set if MAKEFILE. */
|
Don't include options with the 'no_makefile' flag set if MAKEFILE. */
|
||||||
|
|
||||||
static const char *
|
static const char *
|
||||||
define_makeflags (int all, int makefile)
|
define_makeflags (int all, int makefile)
|
||||||
|
@ -2826,7 +2826,7 @@ define_makeflags (int all, int makefile)
|
||||||
unsigned int words;
|
unsigned int words;
|
||||||
struct variable *v;
|
struct variable *v;
|
||||||
|
|
||||||
/* We will construct a linked list of `struct flag's describing
|
/* We will construct a linked list of 'struct flag's describing
|
||||||
all the flags which need to go in MAKEFLAGS. Then, once we
|
all the flags which need to go in MAKEFLAGS. Then, once we
|
||||||
know how many there are and their lengths, we can put them all
|
know how many there are and their lengths, we can put them all
|
||||||
together in a string. */
|
together in a string. */
|
||||||
|
@ -3084,7 +3084,7 @@ define_makeflags (int all, int makefile)
|
||||||
if (! all)
|
if (! all)
|
||||||
/* The first time we are called, set MAKEFLAGS to always be exported.
|
/* The first time we are called, set MAKEFLAGS to always be exported.
|
||||||
We should not do this again on the second call, because that is
|
We should not do this again on the second call, because that is
|
||||||
after reading makefiles which might have done `unexport MAKEFLAGS'. */
|
after reading makefiles which might have done 'unexport MAKEFLAGS'. */
|
||||||
v->export = v_export;
|
v->export = v_export;
|
||||||
|
|
||||||
return v->value;
|
return v->value;
|
||||||
|
@ -3313,10 +3313,10 @@ log_working_directory (int entering)
|
||||||
printf (_("%s: Leaving an unknown directory\n"), program);
|
printf (_("%s: Leaving an unknown directory\n"), program);
|
||||||
else
|
else
|
||||||
if (entering)
|
if (entering)
|
||||||
printf (_("%s: Entering directory `%s'\n"),
|
printf (_("%s: Entering directory '%s'\n"),
|
||||||
program, starting_directory);
|
program, starting_directory);
|
||||||
else
|
else
|
||||||
printf (_("%s: Leaving directory `%s'\n"),
|
printf (_("%s: Leaving directory '%s'\n"),
|
||||||
program, starting_directory);
|
program, starting_directory);
|
||||||
else
|
else
|
||||||
if (starting_directory == 0)
|
if (starting_directory == 0)
|
||||||
|
@ -3328,10 +3328,10 @@ log_working_directory (int entering)
|
||||||
program, makelevel);
|
program, makelevel);
|
||||||
else
|
else
|
||||||
if (entering)
|
if (entering)
|
||||||
printf (_("%s[%u]: Entering directory `%s'\n"),
|
printf (_("%s[%u]: Entering directory '%s'\n"),
|
||||||
program, makelevel, starting_directory);
|
program, makelevel, starting_directory);
|
||||||
else
|
else
|
||||||
printf (_("%s[%u]: Leaving directory `%s'\n"),
|
printf (_("%s[%u]: Leaving directory '%s'\n"),
|
||||||
program, makelevel, starting_directory);
|
program, makelevel, starting_directory);
|
||||||
|
|
||||||
/* Flush stdout to be sure this comes before any stderr output. */
|
/* Flush stdout to be sure this comes before any stderr output. */
|
||||||
|
|
|
@ -201,7 +201,7 @@ update: po-update scm-update
|
||||||
## Sanity checks. ##
|
## Sanity checks. ##
|
||||||
## --------------- ##
|
## --------------- ##
|
||||||
|
|
||||||
# Checks that don't require cvs. Run `changelog-check' last as
|
# Checks that don't require cvs. Run 'changelog-check' last as
|
||||||
# previous test may reveal problems requiring new ChangeLog entries.
|
# previous test may reveal problems requiring new ChangeLog entries.
|
||||||
local-check: po-check changelog-check
|
local-check: po-check changelog-check
|
||||||
|
|
||||||
|
|
8
make.1
8
make.1
|
@ -1,4 +1,4 @@
|
||||||
.TH MAKE 1 "27 December 2010" "GNU" "User Commands"
|
.TH MAKE 1 "03 March 2012" "GNU" "User Commands"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
make \- GNU make utility to maintain groups of programs
|
make \- GNU make utility to maintain groups of programs
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
|
@ -82,7 +82,7 @@ and will not be understood by other versions of
|
||||||
.BR make .
|
.BR make .
|
||||||
If
|
If
|
||||||
.I makefile
|
.I makefile
|
||||||
is `\-', the standard input is read.
|
is '\-', the standard input is read.
|
||||||
.LP
|
.LP
|
||||||
.B make
|
.B make
|
||||||
updates a target if it depends on prerequisite files
|
updates a target if it depends on prerequisite files
|
||||||
|
@ -332,14 +332,14 @@ programs are properly installed at your site, the command
|
||||||
.PP
|
.PP
|
||||||
should give you access to the complete manual.
|
should give you access to the complete manual.
|
||||||
.SH BUGS
|
.SH BUGS
|
||||||
See the chapter `Problems and Bugs' in
|
See the chapter ``Problems and Bugs'' in
|
||||||
.IR "The GNU Make Manual" .
|
.IR "The GNU Make Manual" .
|
||||||
.SH AUTHOR
|
.SH AUTHOR
|
||||||
This manual page contributed by Dennis Morse of Stanford University.
|
This manual page contributed by Dennis Morse of Stanford University.
|
||||||
Further updates contributed by Mike Frysinger. It has been reworked by Roland
|
Further updates contributed by Mike Frysinger. It has been reworked by Roland
|
||||||
McGrath. Maintained by Paul Smith.
|
McGrath. Maintained by Paul Smith.
|
||||||
.SH "COPYRIGHT"
|
.SH "COPYRIGHT"
|
||||||
Copyright \(co 1992, 1993, 1996, 1999, 2007, 2010 Free Software Foundation, Inc.
|
Copyright \(co 1992-1993, 1996-2012 Free Software Foundation, Inc.
|
||||||
This file is part of
|
This file is part of
|
||||||
.IR "GNU make" .
|
.IR "GNU make" .
|
||||||
.LP
|
.LP
|
||||||
|
|
8
make.h
8
make.h
|
@ -68,7 +68,7 @@ char *alloca ();
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
#ifdef HAVE_SYS_TIMEB_H
|
#ifdef HAVE_SYS_TIMEB_H
|
||||||
/* SCO 3.2 "devsys 4.2" has a prototype for `ftime' in <time.h> that bombs
|
/* SCO 3.2 "devsys 4.2" has a prototype for 'ftime' in <time.h> that bombs
|
||||||
unless <sys/timeb.h> has been included first. */
|
unless <sys/timeb.h> has been included first. */
|
||||||
# include <sys/timeb.h>
|
# include <sys/timeb.h>
|
||||||
#endif
|
#endif
|
||||||
|
@ -96,7 +96,7 @@ extern int errno;
|
||||||
#ifdef HAVE_UNISTD_H
|
#ifdef HAVE_UNISTD_H
|
||||||
# include <unistd.h>
|
# include <unistd.h>
|
||||||
/* Ultrix's unistd.h always defines _POSIX_VERSION, but you only get
|
/* Ultrix's unistd.h always defines _POSIX_VERSION, but you only get
|
||||||
POSIX.1 behavior with `cc -YPOSIX', which predefines POSIX itself! */
|
POSIX.1 behavior with 'cc -YPOSIX', which predefines POSIX itself! */
|
||||||
# if defined (_POSIX_VERSION) && !defined (ultrix) && !defined (VMS)
|
# if defined (_POSIX_VERSION) && !defined (ultrix) && !defined (VMS)
|
||||||
# define POSIX 1
|
# define POSIX 1
|
||||||
# endif
|
# endif
|
||||||
|
@ -201,7 +201,7 @@ unsigned int get_path_max (void);
|
||||||
# if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 5) || __STRICT_ANSI__
|
# if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 5) || __STRICT_ANSI__
|
||||||
# define __attribute__(x)
|
# define __attribute__(x)
|
||||||
# endif
|
# endif
|
||||||
/* The __-protected variants of `format' and `printf' attributes
|
/* The __-protected variants of 'format' and 'printf' attributes
|
||||||
are accepted by gcc versions 2.6.4 (effectively 2.7) and later. */
|
are accepted by gcc versions 2.6.4 (effectively 2.7) and later. */
|
||||||
# if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 7)
|
# if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 7)
|
||||||
# define __format__ format
|
# define __format__ format
|
||||||
|
@ -275,7 +275,7 @@ char *strsignal (int signum);
|
||||||
- It's typically faster.
|
- It's typically faster.
|
||||||
POSIX 1003.2-1992 section 2.5.2.1 page 50 lines 1556-1558 says that
|
POSIX 1003.2-1992 section 2.5.2.1 page 50 lines 1556-1558 says that
|
||||||
only '0' through '9' are digits. Prefer ISDIGIT to isdigit() unless
|
only '0' through '9' are digits. Prefer ISDIGIT to isdigit() unless
|
||||||
it's important to use the locale's definition of `digit' even when the
|
it's important to use the locale's definition of 'digit' even when the
|
||||||
host does not conform to POSIX. */
|
host does not conform to POSIX. */
|
||||||
#define ISDIGIT(c) ((unsigned) (c) - '0' <= 9)
|
#define ISDIGIT(c) ((unsigned) (c) - '0' <= 9)
|
||||||
|
|
||||||
|
|
|
@ -82,7 +82,7 @@ extras = ,signame.obj,remote-stub.obj,vmsfunctions.obj,vmsify.obj
|
||||||
# as an alternative:
|
# as an alternative:
|
||||||
glob = ,[.glob]glob.obj,[.glob]fnmatch.obj
|
glob = ,[.glob]glob.obj,[.glob]fnmatch.obj
|
||||||
getopt = ,getopt.obj,getopt1.obj
|
getopt = ,getopt.obj,getopt1.obj
|
||||||
# Directory to install `make' in.
|
# Directory to install 'make' in.
|
||||||
bindir = []
|
bindir = []
|
||||||
# Directory to install the man page in.
|
# Directory to install the man page in.
|
||||||
mandir = []
|
mandir = []
|
||||||
|
|
4
misc.c
4
misc.c
|
@ -535,7 +535,7 @@ find_next_token (const char **ptr, unsigned int *lengthptr)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Copy a chain of `struct dep'. For 2nd expansion deps, dup the name. */
|
/* Copy a chain of 'struct dep'. For 2nd expansion deps, dup the name. */
|
||||||
|
|
||||||
struct dep *
|
struct dep *
|
||||||
copy_dep_chain (const struct dep *d)
|
copy_dep_chain (const struct dep *d)
|
||||||
|
@ -941,7 +941,7 @@ get_path_max (void)
|
||||||
the failure. That's what the ferror test is checking below.
|
the failure. That's what the ferror test is checking below.
|
||||||
|
|
||||||
It's important to detect such failures and exit nonzero because many
|
It's important to detect such failures and exit nonzero because many
|
||||||
tools (most notably `make' and other build-management systems) depend
|
tools (most notably 'make' and other build-management systems) depend
|
||||||
on being able to detect failure in other tools via their exit status. */
|
on being able to detect failure in other tools via their exit status. */
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
78
read.c
78
read.c
|
@ -76,12 +76,12 @@ enum make_word_type
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/* A `struct conditionals' contains the information describing
|
/* A 'struct conditionals' contains the information describing
|
||||||
all the active conditionals in a makefile.
|
all the active conditionals in a makefile.
|
||||||
|
|
||||||
The global variable `conditionals' contains the conditionals
|
The global variable 'conditionals' contains the conditionals
|
||||||
information for the current makefile. It is initialized from
|
information for the current makefile. It is initialized from
|
||||||
the static structure `toplevel_conditionals' and is later changed
|
the static structure 'toplevel_conditionals' and is later changed
|
||||||
to new structures for included makefiles. */
|
to new structures for included makefiles. */
|
||||||
|
|
||||||
struct conditionals
|
struct conditionals
|
||||||
|
@ -91,7 +91,7 @@ struct conditionals
|
||||||
char *ignoring; /* Are we ignoring or interpreting?
|
char *ignoring; /* Are we ignoring or interpreting?
|
||||||
0=interpreting, 1=not yet interpreted,
|
0=interpreting, 1=not yet interpreted,
|
||||||
2=already interpreted */
|
2=already interpreted */
|
||||||
char *seen_else; /* Have we already seen an `else'? */
|
char *seen_else; /* Have we already seen an 'else'? */
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct conditionals toplevel_conditionals;
|
static struct conditionals toplevel_conditionals;
|
||||||
|
@ -260,7 +260,7 @@ read_all_makefiles (const char **makefiles)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* No default makefile was found. Add the default makefiles to the
|
/* No default makefile was found. Add the default makefiles to the
|
||||||
`read_makefiles' chain so they will be updated if possible. */
|
'read_makefiles' chain so they will be updated if possible. */
|
||||||
struct dep *tail = read_makefiles;
|
struct dep *tail = read_makefiles;
|
||||||
/* Add them to the tail, after any MAKEFILES variable makefiles. */
|
/* Add them to the tail, after any MAKEFILES variable makefiles. */
|
||||||
while (tail != 0 && tail->next != 0)
|
while (tail != 0 && tail->next != 0)
|
||||||
|
@ -329,7 +329,7 @@ eval_makefile (const char *filename, int flags)
|
||||||
|
|
||||||
if (ISDB (DB_VERBOSE))
|
if (ISDB (DB_VERBOSE))
|
||||||
{
|
{
|
||||||
printf (_("Reading makefile `%s'"), filename);
|
printf (_("Reading makefile '%s'"), filename);
|
||||||
if (flags & RM_NO_DEFAULT_GOAL)
|
if (flags & RM_NO_DEFAULT_GOAL)
|
||||||
printf (_(" (no default goal)"));
|
printf (_(" (no default goal)"));
|
||||||
if (flags & RM_INCLUDED)
|
if (flags & RM_INCLUDED)
|
||||||
|
@ -343,7 +343,7 @@ eval_makefile (const char *filename, int flags)
|
||||||
|
|
||||||
/* First, get a stream to read. */
|
/* First, get a stream to read. */
|
||||||
|
|
||||||
/* Expand ~ in FILENAME unless it came from `include',
|
/* Expand ~ in FILENAME unless it came from 'include',
|
||||||
in which case it was already done. */
|
in which case it was already done. */
|
||||||
if (!(flags & RM_NO_TILDE) && filename[0] == '~')
|
if (!(flags & RM_NO_TILDE) && filename[0] == '~')
|
||||||
{
|
{
|
||||||
|
@ -357,7 +357,7 @@ eval_makefile (const char *filename, int flags)
|
||||||
makefile_errno = errno;
|
makefile_errno = errno;
|
||||||
|
|
||||||
/* If the makefile wasn't found and it's either a makefile from
|
/* If the makefile wasn't found and it's either a makefile from
|
||||||
the `MAKEFILES' variable or an included makefile,
|
the 'MAKEFILES' variable or an included makefile,
|
||||||
search the included makefile search path for this makefile. */
|
search the included makefile search path for this makefile. */
|
||||||
if (ebuf.fp == 0 && (flags & RM_INCLUDED) && *filename != '/')
|
if (ebuf.fp == 0 && (flags & RM_INCLUDED) && *filename != '/')
|
||||||
{
|
{
|
||||||
|
@ -819,7 +819,7 @@ eval (struct ebuffer *ebuf, int set_default)
|
||||||
/* Handle include and variants. */
|
/* Handle include and variants. */
|
||||||
if (word1eq ("include") || word1eq ("-include") || word1eq ("sinclude"))
|
if (word1eq ("include") || word1eq ("-include") || word1eq ("sinclude"))
|
||||||
{
|
{
|
||||||
/* We have found an `include' line specifying a nested
|
/* We have found an 'include' line specifying a nested
|
||||||
makefile to be read at this point. */
|
makefile to be read at this point. */
|
||||||
struct conditionals *save;
|
struct conditionals *save;
|
||||||
struct conditionals new_conditionals;
|
struct conditionals new_conditionals;
|
||||||
|
@ -884,11 +884,11 @@ eval (struct ebuffer *ebuf, int set_default)
|
||||||
/* This line describes some target files. This is complicated by
|
/* This line describes some target files. This is complicated by
|
||||||
the existence of target-specific variables, because we can't
|
the existence of target-specific variables, because we can't
|
||||||
expand the entire line until we know if we have one or not. So
|
expand the entire line until we know if we have one or not. So
|
||||||
we expand the line word by word until we find the first `:',
|
we expand the line word by word until we find the first ':',
|
||||||
then check to see if it's a target-specific variable.
|
then check to see if it's a target-specific variable.
|
||||||
|
|
||||||
In this algorithm, `lb_next' will point to the beginning of the
|
In this algorithm, 'lb_next' will point to the beginning of the
|
||||||
unexpanded parts of the input buffer, while `p2' points to the
|
unexpanded parts of the input buffer, while 'p2' points to the
|
||||||
parts of the expanded buffer we haven't searched yet. */
|
parts of the expanded buffer we haven't searched yet. */
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -1103,7 +1103,7 @@ eval (struct ebuffer *ebuf, int set_default)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Is this a static pattern rule: `target: %targ: %dep; ...'? */
|
/* Is this a static pattern rule: 'target: %targ: %dep; ...'? */
|
||||||
p = strchr (p2, ':');
|
p = strchr (p2, ':');
|
||||||
while (p != 0 && p[-1] == '\\')
|
while (p != 0 && p[-1] == '\\')
|
||||||
{
|
{
|
||||||
|
@ -1161,7 +1161,7 @@ eval (struct ebuffer *ebuf, int set_default)
|
||||||
pattern_percent = find_percent_cached (&target->name);
|
pattern_percent = find_percent_cached (&target->name);
|
||||||
pattern = target->name;
|
pattern = target->name;
|
||||||
if (pattern_percent == 0)
|
if (pattern_percent == 0)
|
||||||
fatal (fstart, _("target pattern contains no `%%'"));
|
fatal (fstart, _("target pattern contains no '%%'"));
|
||||||
free_ns (target);
|
free_ns (target);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -1227,7 +1227,7 @@ eval (struct ebuffer *ebuf, int set_default)
|
||||||
if (strchr (name, '%') != 0)
|
if (strchr (name, '%') != 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* See if this target's name does not start with a `.',
|
/* See if this target's name does not start with a '.',
|
||||||
unless it contains a slash. */
|
unless it contains a slash. */
|
||||||
if (*name == '.' && strchr (name, '/') == 0
|
if (*name == '.' && strchr (name, '/') == 0
|
||||||
#ifdef HAVE_DOS_PATHS
|
#ifdef HAVE_DOS_PATHS
|
||||||
|
@ -1285,7 +1285,7 @@ eval (struct ebuffer *ebuf, int set_default)
|
||||||
#undef word1eq
|
#undef word1eq
|
||||||
|
|
||||||
if (conditionals->if_cmds)
|
if (conditionals->if_cmds)
|
||||||
fatal (fstart, _("missing `endif'"));
|
fatal (fstart, _("missing 'endif'"));
|
||||||
|
|
||||||
/* At eof, record the last rule. */
|
/* At eof, record the last rule. */
|
||||||
record_waiting_files ();
|
record_waiting_files ();
|
||||||
|
@ -1311,7 +1311,7 @@ remove_comments (char *line)
|
||||||
*comment = '\0';
|
*comment = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Execute a `undefine' directive.
|
/* Execute a 'undefine' directive.
|
||||||
The undefine line has already been read, and NAME is the name of
|
The undefine line has already been read, and NAME is the name of
|
||||||
the variable to be undefined. */
|
the variable to be undefined. */
|
||||||
|
|
||||||
|
@ -1334,7 +1334,7 @@ do_undefine (char *name, enum variable_origin origin, struct ebuffer *ebuf)
|
||||||
free (var);
|
free (var);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Execute a `define' directive.
|
/* Execute a 'define' directive.
|
||||||
The first line has already been read, and NAME is the name of
|
The first line has already been read, and NAME is the name of
|
||||||
the variable to be defined. The following lines remain to be read. */
|
the variable to be defined. The following lines remain to be read. */
|
||||||
|
|
||||||
|
@ -1359,7 +1359,7 @@ do_define (char *name, enum variable_origin origin, struct ebuffer *ebuf)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (var.value[0] != '\0')
|
if (var.value[0] != '\0')
|
||||||
error (&defstart, _("extraneous text after `define' directive"));
|
error (&defstart, _("extraneous text after 'define' directive"));
|
||||||
|
|
||||||
/* Chop the string before the assignment token to get the name. */
|
/* Chop the string before the assignment token to get the name. */
|
||||||
var.name[var.length] = '\0';
|
var.name[var.length] = '\0';
|
||||||
|
@ -1384,7 +1384,7 @@ do_define (char *name, enum variable_origin origin, struct ebuffer *ebuf)
|
||||||
|
|
||||||
/* If there is nothing left to be eval'd, there's no 'endef'!! */
|
/* If there is nothing left to be eval'd, there's no 'endef'!! */
|
||||||
if (nlines < 0)
|
if (nlines < 0)
|
||||||
fatal (&defstart, _("missing `endef', unterminated `define'"));
|
fatal (&defstart, _("missing 'endef', unterminated 'define'"));
|
||||||
|
|
||||||
ebuf->floc.lineno += nlines;
|
ebuf->floc.lineno += nlines;
|
||||||
line = ebuf->buffer;
|
line = ebuf->buffer;
|
||||||
|
@ -1412,7 +1412,7 @@ do_define (char *name, enum variable_origin origin, struct ebuffer *ebuf)
|
||||||
remove_comments (p);
|
remove_comments (p);
|
||||||
if (*(next_token (p)) != '\0')
|
if (*(next_token (p)) != '\0')
|
||||||
error (&ebuf->floc,
|
error (&ebuf->floc,
|
||||||
_("extraneous text after `endef' directive"));
|
_("extraneous text after 'endef' directive"));
|
||||||
|
|
||||||
if (--nlevels == 0)
|
if (--nlevels == 0)
|
||||||
break;
|
break;
|
||||||
|
@ -1483,7 +1483,7 @@ conditional_line (char *line, int len, const struct floc *flocp)
|
||||||
/* Found one: skip past it and any whitespace after it. */
|
/* Found one: skip past it and any whitespace after it. */
|
||||||
line = next_token (line + len);
|
line = next_token (line + len);
|
||||||
|
|
||||||
#define EXTRANEOUS() error (flocp, _("Extraneous text after `%s' directive"), cmdname)
|
#define EXTRANEOUS() error (flocp, _("Extraneous text after '%s' directive"), cmdname)
|
||||||
|
|
||||||
/* An 'endif' cannot contain extra text, and reduces the if-depth by 1 */
|
/* An 'endif' cannot contain extra text, and reduces the if-depth by 1 */
|
||||||
if (cmdtype == c_endif)
|
if (cmdtype == c_endif)
|
||||||
|
@ -1492,7 +1492,7 @@ conditional_line (char *line, int len, const struct floc *flocp)
|
||||||
EXTRANEOUS ();
|
EXTRANEOUS ();
|
||||||
|
|
||||||
if (!conditionals->if_cmds)
|
if (!conditionals->if_cmds)
|
||||||
fatal (flocp, _("extraneous `%s'"), cmdname);
|
fatal (flocp, _("extraneous '%s'"), cmdname);
|
||||||
|
|
||||||
--conditionals->if_cmds;
|
--conditionals->if_cmds;
|
||||||
|
|
||||||
|
@ -1506,12 +1506,12 @@ conditional_line (char *line, int len, const struct floc *flocp)
|
||||||
const char *p;
|
const char *p;
|
||||||
|
|
||||||
if (!conditionals->if_cmds)
|
if (!conditionals->if_cmds)
|
||||||
fatal (flocp, _("extraneous `%s'"), cmdname);
|
fatal (flocp, _("extraneous '%s'"), cmdname);
|
||||||
|
|
||||||
o = conditionals->if_cmds - 1;
|
o = conditionals->if_cmds - 1;
|
||||||
|
|
||||||
if (conditionals->seen_else[o])
|
if (conditionals->seen_else[o])
|
||||||
fatal (flocp, _("only one `else' per conditional"));
|
fatal (flocp, _("only one 'else' per conditional"));
|
||||||
|
|
||||||
/* Change the state of ignorance. */
|
/* Change the state of ignorance. */
|
||||||
switch (conditionals->ignoring[o])
|
switch (conditionals->ignoring[o])
|
||||||
|
@ -1574,7 +1574,7 @@ conditional_line (char *line, int len, const struct floc *flocp)
|
||||||
conditionals->allocated);
|
conditionals->allocated);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Record that we have seen an `if...' but no `else' so far. */
|
/* Record that we have seen an 'if...' but no 'else' so far. */
|
||||||
conditionals->seen_else[o] = 0;
|
conditionals->seen_else[o] = 0;
|
||||||
|
|
||||||
/* Search through the stack to see if we're already ignoring. */
|
/* Search through the stack to see if we're already ignoring. */
|
||||||
|
@ -1825,9 +1825,9 @@ record_target_var (struct nameseq *filenames, char *defn,
|
||||||
with dependencies DEPS, commands to execute described
|
with dependencies DEPS, commands to execute described
|
||||||
by COMMANDS and COMMANDS_IDX, coming from FILENAME:COMMANDS_STARTED.
|
by COMMANDS and COMMANDS_IDX, coming from FILENAME:COMMANDS_STARTED.
|
||||||
TWO_COLON is nonzero if a double colon was used.
|
TWO_COLON is nonzero if a double colon was used.
|
||||||
If not nil, PATTERN is the `%' pattern to make this
|
If not nil, PATTERN is the '%' pattern to make this
|
||||||
a static pattern rule, and PATTERN_PERCENT is a pointer
|
a static pattern rule, and PATTERN_PERCENT is a pointer
|
||||||
to the `%' within it.
|
to the '%' within it.
|
||||||
|
|
||||||
The links of FILENAMES are freed, and so are any names in it
|
The links of FILENAMES are freed, and so are any names in it
|
||||||
that are not incorporated into other data structures. */
|
that are not incorporated into other data structures. */
|
||||||
|
@ -1968,10 +1968,10 @@ record_files (struct nameseq *filenames, const char *pattern,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* If this is a static pattern rule:
|
/* If this is a static pattern rule:
|
||||||
`targets: target%pattern: prereq%pattern; recipe',
|
'targets: target%pattern: prereq%pattern; recipe',
|
||||||
make sure the pattern matches this target name. */
|
make sure the pattern matches this target name. */
|
||||||
if (pattern && !pattern_matches (pattern, pattern_percent, name))
|
if (pattern && !pattern_matches (pattern, pattern_percent, name))
|
||||||
error (flocp, _("target `%s' doesn't match the target pattern"), name);
|
error (flocp, _("target '%s' doesn't match the target pattern"), name);
|
||||||
else if (deps)
|
else if (deps)
|
||||||
/* If there are multiple targets, copy the chain DEPS for all but the
|
/* If there are multiple targets, copy the chain DEPS for all but the
|
||||||
last one. It is not safe for the same deps to go in more than one
|
last one. It is not safe for the same deps to go in more than one
|
||||||
|
@ -1986,13 +1986,13 @@ record_files (struct nameseq *filenames, const char *pattern,
|
||||||
f = enter_file (strcache_add (name));
|
f = enter_file (strcache_add (name));
|
||||||
if (f->double_colon)
|
if (f->double_colon)
|
||||||
fatal (flocp,
|
fatal (flocp,
|
||||||
_("target file `%s' has both : and :: entries"), f->name);
|
_("target file '%s' has both : and :: entries"), f->name);
|
||||||
|
|
||||||
/* If CMDS == F->CMDS, this target was listed in this rule
|
/* If CMDS == F->CMDS, this target was listed in this rule
|
||||||
more than once. Just give a warning since this is harmless. */
|
more than once. Just give a warning since this is harmless. */
|
||||||
if (cmds != 0 && cmds == f->cmds)
|
if (cmds != 0 && cmds == f->cmds)
|
||||||
error (flocp,
|
error (flocp,
|
||||||
_("target `%s' given more than once in the same rule."),
|
_("target '%s' given more than once in the same rule."),
|
||||||
f->name);
|
f->name);
|
||||||
|
|
||||||
/* Check for two single-colon entries both with commands.
|
/* Check for two single-colon entries both with commands.
|
||||||
|
@ -2001,10 +2001,10 @@ record_files (struct nameseq *filenames, const char *pattern,
|
||||||
else if (cmds != 0 && f->cmds != 0 && f->is_target)
|
else if (cmds != 0 && f->cmds != 0 && f->is_target)
|
||||||
{
|
{
|
||||||
error (&cmds->fileinfo,
|
error (&cmds->fileinfo,
|
||||||
_("warning: overriding recipe for target `%s'"),
|
_("warning: overriding recipe for target '%s'"),
|
||||||
f->name);
|
f->name);
|
||||||
error (&f->cmds->fileinfo,
|
error (&f->cmds->fileinfo,
|
||||||
_("warning: ignoring old recipe for target `%s'"),
|
_("warning: ignoring old recipe for target '%s'"),
|
||||||
f->name);
|
f->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2031,7 +2031,7 @@ record_files (struct nameseq *filenames, const char *pattern,
|
||||||
on default suffix rules or makefiles. */
|
on default suffix rules or makefiles. */
|
||||||
if (f != 0 && f->is_target && !f->double_colon)
|
if (f != 0 && f->is_target && !f->double_colon)
|
||||||
fatal (flocp,
|
fatal (flocp,
|
||||||
_("target file `%s' has both : and :: entries"), f->name);
|
_("target file '%s' has both : and :: entries"), f->name);
|
||||||
|
|
||||||
f = enter_file (strcache_add (name));
|
f = enter_file (strcache_add (name));
|
||||||
/* If there was an existing entry and it was a double-colon entry,
|
/* If there was an existing entry and it was a double-colon entry,
|
||||||
|
@ -2049,7 +2049,7 @@ record_files (struct nameseq *filenames, const char *pattern,
|
||||||
f->is_target = 1;
|
f->is_target = 1;
|
||||||
|
|
||||||
/* If this is a static pattern rule, set the stem to the part of its
|
/* If this is a static pattern rule, set the stem to the part of its
|
||||||
name that matched the `%' in the pattern, so you can use $* in the
|
name that matched the '%' in the pattern, so you can use $* in the
|
||||||
commands. If we didn't do it before, enter the prereqs now. */
|
commands. If we didn't do it before, enter the prereqs now. */
|
||||||
if (pattern)
|
if (pattern)
|
||||||
{
|
{
|
||||||
|
@ -2954,10 +2954,10 @@ parse_file_seq (char **stringp, unsigned int size, int stopchar,
|
||||||
/* Strip leading "this directory" references. */
|
/* Strip leading "this directory" references. */
|
||||||
if (! (flags & PARSEFS_NOSTRIP))
|
if (! (flags & PARSEFS_NOSTRIP))
|
||||||
#ifdef VMS
|
#ifdef VMS
|
||||||
/* Skip leading `[]'s. */
|
/* Skip leading '[]'s. */
|
||||||
while (p - s > 2 && s[0] == '[' && s[1] == ']')
|
while (p - s > 2 && s[0] == '[' && s[1] == ']')
|
||||||
#else
|
#else
|
||||||
/* Skip leading `./'s. */
|
/* Skip leading './'s. */
|
||||||
while (p - s > 2 && s[0] == '.' && s[1] == '/')
|
while (p - s > 2 && s[0] == '.' && s[1] == '/')
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
|
@ -3018,7 +3018,7 @@ parse_file_seq (char **stringp, unsigned int size, int stopchar,
|
||||||
"libf.a(x.o) libf.a(y.o) libf.a(z.o)"
|
"libf.a(x.o) libf.a(y.o) libf.a(z.o)"
|
||||||
|
|
||||||
TP == TMP means we're not already in an archive group. Ignore
|
TP == TMP means we're not already in an archive group. Ignore
|
||||||
something starting with `(', as that cannot actually be an
|
something starting with '(', as that cannot actually be an
|
||||||
archive-member reference (and treating it as such results in an empty
|
archive-member reference (and treating it as such results in an empty
|
||||||
file name, which causes much lossage). Also if it ends in ")" then
|
file name, which causes much lossage). Also if it ends in ")" then
|
||||||
it's a complete reference so we don't need to treat it specially.
|
it's a complete reference so we don't need to treat it specially.
|
||||||
|
|
|
@ -212,7 +212,7 @@ returns a modification time 1 hour ahead. This results in GNU make
|
||||||
warning messages. For a just created source you will see:
|
warning messages. For a just created source you will see:
|
||||||
|
|
||||||
$ gmake x.exe
|
$ gmake x.exe
|
||||||
gmake.exe;1: *** Warning: File `x.c' has modification time in the future (940582863 > 940579269)
|
gmake.exe;1: *** Warning: File 'x.c' has modification time in the future (940582863 > 940579269)
|
||||||
cc /obj=x.obj x.c
|
cc /obj=x.obj x.c
|
||||||
link x.obj /exe=x.exe
|
link x.obj /exe=x.exe
|
||||||
gmake.exe;1: *** Warning: Clock skew detected. Your build may be incomplete.
|
gmake.exe;1: *** Warning: Clock skew detected. Your build may be incomplete.
|
||||||
|
|
106
remake.c
106
remake.c
|
@ -43,7 +43,7 @@ extern int try_implicit_rule (struct file *file, unsigned int depth);
|
||||||
|
|
||||||
|
|
||||||
/* The test for circular dependencies is based on the 'updating' bit in
|
/* The test for circular dependencies is based on the 'updating' bit in
|
||||||
`struct file'. However, double colon targets have seperate `struct
|
'struct file'. However, double colon targets have seperate 'struct
|
||||||
file's; make sure we always use the base of the double colon chain. */
|
file's; make sure we always use the base of the double colon chain. */
|
||||||
|
|
||||||
#define start_updating(_f) (((_f)->double_colon ? (_f)->double_colon : (_f))\
|
#define start_updating(_f) (((_f)->double_colon ? (_f)->double_colon : (_f))\
|
||||||
|
@ -70,13 +70,13 @@ static FILE_TIMESTAMP name_mtime (const char *name);
|
||||||
static const char *library_search (const char *lib, FILE_TIMESTAMP *mtime_ptr);
|
static const char *library_search (const char *lib, FILE_TIMESTAMP *mtime_ptr);
|
||||||
|
|
||||||
|
|
||||||
/* Remake all the goals in the `struct dep' chain GOALS. Return -1 if nothing
|
/* Remake all the goals in the 'struct dep' chain GOALS. Return -1 if nothing
|
||||||
was done, 0 if all goals were updated successfully, or 1 if a goal failed.
|
was done, 0 if all goals were updated successfully, or 1 if a goal failed.
|
||||||
|
|
||||||
If rebuilding_makefiles is nonzero, these goals are makefiles, so -t, -q,
|
If rebuilding_makefiles is nonzero, these goals are makefiles, so -t, -q,
|
||||||
and -n should be disabled for them unless they were also command-line
|
and -n should be disabled for them unless they were also command-line
|
||||||
targets, and we should only make one goal at a time and return as soon as
|
targets, and we should only make one goal at a time and return as soon as
|
||||||
one goal whose `changed' member is nonzero is successfully made. */
|
one goal whose 'changed' member is nonzero is successfully made. */
|
||||||
|
|
||||||
int
|
int
|
||||||
update_goal_chain (struct dep *goals)
|
update_goal_chain (struct dep *goals)
|
||||||
|
@ -92,7 +92,7 @@ update_goal_chain (struct dep *goals)
|
||||||
goals = copy_dep_chain (goals);
|
goals = copy_dep_chain (goals);
|
||||||
|
|
||||||
{
|
{
|
||||||
/* Clear the `changed' flag of each goal in the chain.
|
/* Clear the 'changed' flag of each goal in the chain.
|
||||||
We will use the flag below to notice when any commands
|
We will use the flag below to notice when any commands
|
||||||
have actually been run for a target. When no commands
|
have actually been run for a target. When no commands
|
||||||
have been run, we give an "up to date" diagnostic. */
|
have been run, we give an "up to date" diagnostic. */
|
||||||
|
@ -149,7 +149,7 @@ update_goal_chain (struct dep *goals)
|
||||||
touch_flag = question_flag = just_print_flag = 0;
|
touch_flag = question_flag = just_print_flag = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Save the old value of `commands_started' so we can compare
|
/* Save the old value of 'commands_started' so we can compare
|
||||||
later. It will be incremented when any commands are
|
later. It will be incremented when any commands are
|
||||||
actually run. */
|
actually run. */
|
||||||
ocommands_started = commands_started;
|
ocommands_started = commands_started;
|
||||||
|
@ -157,7 +157,7 @@ update_goal_chain (struct dep *goals)
|
||||||
x = update_file (file, rebuilding_makefiles ? 1 : 0);
|
x = update_file (file, rebuilding_makefiles ? 1 : 0);
|
||||||
check_renamed (file);
|
check_renamed (file);
|
||||||
|
|
||||||
/* Set the goal's `changed' flag if any commands were started
|
/* Set the goal's 'changed' flag if any commands were started
|
||||||
by calling update_file above. We check this flag below to
|
by calling update_file above. We check this flag below to
|
||||||
decide when to give an "up to date" diagnostic. */
|
decide when to give an "up to date" diagnostic. */
|
||||||
if (commands_started > ocommands_started)
|
if (commands_started > ocommands_started)
|
||||||
|
@ -231,8 +231,8 @@ update_goal_chain (struct dep *goals)
|
||||||
/* Never give a message under -s or -q. */
|
/* Never give a message under -s or -q. */
|
||||||
&& !silent_flag && !question_flag)
|
&& !silent_flag && !question_flag)
|
||||||
message (1, ((file->phony || file->cmds == 0)
|
message (1, ((file->phony || file->cmds == 0)
|
||||||
? _("Nothing to be done for `%s'.")
|
? _("Nothing to be done for '%s'.")
|
||||||
: _("`%s' is up to date.")),
|
: _("'%s' is up to date.")),
|
||||||
file->name);
|
file->name);
|
||||||
|
|
||||||
/* This goal is finished. Remove it from the chain. */
|
/* This goal is finished. Remove it from the chain. */
|
||||||
|
@ -274,7 +274,7 @@ update_goal_chain (struct dep *goals)
|
||||||
|
|
||||||
/* If FILE is not up to date, execute the commands for it.
|
/* If FILE is not up to date, execute the commands for it.
|
||||||
Return 0 if successful, 1 if unsuccessful;
|
Return 0 if successful, 1 if unsuccessful;
|
||||||
but with some flag settings, just call `exit' if unsuccessful.
|
but with some flag settings, just call 'exit' if unsuccessful.
|
||||||
|
|
||||||
DEPTH is the depth in recursions of this function.
|
DEPTH is the depth in recursions of this function.
|
||||||
We increment it during the consideration of our dependencies,
|
We increment it during the consideration of our dependencies,
|
||||||
|
@ -303,7 +303,7 @@ update_file (struct file *file, unsigned int depth)
|
||||||
then we will have to continue. */
|
then we will have to continue. */
|
||||||
if (!(f->updated && f->update_status > 0 && !f->dontcare && f->no_diag))
|
if (!(f->updated && f->update_status > 0 && !f->dontcare && f->no_diag))
|
||||||
{
|
{
|
||||||
DBF (DB_VERBOSE, _("Pruning file `%s'.\n"));
|
DBF (DB_VERBOSE, _("Pruning file '%s'.\n"));
|
||||||
return f->command_state == cs_finished ? f->update_status : 0;
|
return f->command_state == cs_finished ? f->update_status : 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -375,9 +375,9 @@ complain (struct file *file)
|
||||||
if (d == 0)
|
if (d == 0)
|
||||||
{
|
{
|
||||||
const char *msg_noparent
|
const char *msg_noparent
|
||||||
= _("%sNo rule to make target `%s'%s");
|
= _("%sNo rule to make target '%s'%s");
|
||||||
const char *msg_parent
|
const char *msg_parent
|
||||||
= _("%sNo rule to make target `%s', needed by `%s'%s");
|
= _("%sNo rule to make target '%s', needed by '%s'%s");
|
||||||
|
|
||||||
/* Didn't find any dependencies to complain about. */
|
/* Didn't find any dependencies to complain about. */
|
||||||
if (!keep_going_flag)
|
if (!keep_going_flag)
|
||||||
|
@ -397,7 +397,7 @@ complain (struct file *file)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Consider a single `struct file' and update it as appropriate. */
|
/* Consider a single 'struct file' and update it as appropriate. */
|
||||||
|
|
||||||
static int
|
static int
|
||||||
update_file_1 (struct file *file, unsigned int depth)
|
update_file_1 (struct file *file, unsigned int depth)
|
||||||
|
@ -410,14 +410,14 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
struct dep amake;
|
struct dep amake;
|
||||||
int running = 0;
|
int running = 0;
|
||||||
|
|
||||||
DBF (DB_VERBOSE, _("Considering target file `%s'.\n"));
|
DBF (DB_VERBOSE, _("Considering target file '%s'.\n"));
|
||||||
|
|
||||||
if (file->updated)
|
if (file->updated)
|
||||||
{
|
{
|
||||||
if (file->update_status > 0)
|
if (file->update_status > 0)
|
||||||
{
|
{
|
||||||
DBF (DB_VERBOSE,
|
DBF (DB_VERBOSE,
|
||||||
_("Recently tried and failed to update file `%s'.\n"));
|
_("Recently tried and failed to update file '%s'.\n"));
|
||||||
|
|
||||||
/* If the file we tried to make is marked no_diag then no message
|
/* If the file we tried to make is marked no_diag then no message
|
||||||
was printed about it when it failed during the makefile rebuild.
|
was printed about it when it failed during the makefile rebuild.
|
||||||
|
@ -429,7 +429,7 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
return file->update_status;
|
return file->update_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
DBF (DB_VERBOSE, _("File `%s' was considered already.\n"));
|
DBF (DB_VERBOSE, _("File '%s' was considered already.\n"));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -439,10 +439,10 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
case cs_deps_running:
|
case cs_deps_running:
|
||||||
break;
|
break;
|
||||||
case cs_running:
|
case cs_running:
|
||||||
DBF (DB_VERBOSE, _("Still updating file `%s'.\n"));
|
DBF (DB_VERBOSE, _("Still updating file '%s'.\n"));
|
||||||
return 0;
|
return 0;
|
||||||
case cs_finished:
|
case cs_finished:
|
||||||
DBF (DB_VERBOSE, _("Finished updating file `%s'.\n"));
|
DBF (DB_VERBOSE, _("Finished updating file '%s'.\n"));
|
||||||
return file->update_status;
|
return file->update_status;
|
||||||
default:
|
default:
|
||||||
abort ();
|
abort ();
|
||||||
|
@ -471,14 +471,14 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
check_renamed (file);
|
check_renamed (file);
|
||||||
noexist = this_mtime == NONEXISTENT_MTIME;
|
noexist = this_mtime == NONEXISTENT_MTIME;
|
||||||
if (noexist)
|
if (noexist)
|
||||||
DBF (DB_BASIC, _("File `%s' does not exist.\n"));
|
DBF (DB_BASIC, _("File '%s' does not exist.\n"));
|
||||||
else if (ORDINARY_MTIME_MIN <= this_mtime && this_mtime <= ORDINARY_MTIME_MAX
|
else if (ORDINARY_MTIME_MIN <= this_mtime && this_mtime <= ORDINARY_MTIME_MAX
|
||||||
&& file->low_resolution_time)
|
&& file->low_resolution_time)
|
||||||
{
|
{
|
||||||
/* Avoid spurious rebuilds due to low resolution time stamps. */
|
/* Avoid spurious rebuilds due to low resolution time stamps. */
|
||||||
int ns = FILE_TIMESTAMP_NS (this_mtime);
|
int ns = FILE_TIMESTAMP_NS (this_mtime);
|
||||||
if (ns != 0)
|
if (ns != 0)
|
||||||
error (NILF, _("*** Warning: .LOW_RESOLUTION_TIME file `%s' has a high resolution time stamp"),
|
error (NILF, _("*** Warning: .LOW_RESOLUTION_TIME file '%s' has a high resolution time stamp"),
|
||||||
file->name);
|
file->name);
|
||||||
this_mtime += FILE_TIMESTAMPS_PER_S - 1 - ns;
|
this_mtime += FILE_TIMESTAMPS_PER_S - 1 - ns;
|
||||||
}
|
}
|
||||||
|
@ -491,15 +491,15 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
if (!file->phony && file->cmds == 0 && !file->tried_implicit)
|
if (!file->phony && file->cmds == 0 && !file->tried_implicit)
|
||||||
{
|
{
|
||||||
if (try_implicit_rule (file, depth))
|
if (try_implicit_rule (file, depth))
|
||||||
DBF (DB_IMPLICIT, _("Found an implicit rule for `%s'.\n"));
|
DBF (DB_IMPLICIT, _("Found an implicit rule for '%s'.\n"));
|
||||||
else
|
else
|
||||||
DBF (DB_IMPLICIT, _("No implicit rule found for `%s'.\n"));
|
DBF (DB_IMPLICIT, _("No implicit rule found for '%s'.\n"));
|
||||||
file->tried_implicit = 1;
|
file->tried_implicit = 1;
|
||||||
}
|
}
|
||||||
if (file->cmds == 0 && !file->is_target
|
if (file->cmds == 0 && !file->is_target
|
||||||
&& default_file != 0 && default_file->cmds != 0)
|
&& default_file != 0 && default_file->cmds != 0)
|
||||||
{
|
{
|
||||||
DBF (DB_IMPLICIT, _("Using default recipe for `%s'.\n"));
|
DBF (DB_IMPLICIT, _("Using default recipe for '%s'.\n"));
|
||||||
file->cmds = default_file->cmds;
|
file->cmds = default_file->cmds;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -648,13 +648,13 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
finish_updating (file);
|
finish_updating (file);
|
||||||
finish_updating (ofile);
|
finish_updating (ofile);
|
||||||
|
|
||||||
DBF (DB_VERBOSE, _("Finished prerequisites of target file `%s'.\n"));
|
DBF (DB_VERBOSE, _("Finished prerequisites of target file '%s'.\n"));
|
||||||
|
|
||||||
if (running)
|
if (running)
|
||||||
{
|
{
|
||||||
set_command_state (file, cs_deps_running);
|
set_command_state (file, cs_deps_running);
|
||||||
--depth;
|
--depth;
|
||||||
DBF (DB_VERBOSE, _("The prerequisites of `%s' are being made.\n"));
|
DBF (DB_VERBOSE, _("The prerequisites of '%s' are being made.\n"));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -667,12 +667,12 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
|
|
||||||
--depth;
|
--depth;
|
||||||
|
|
||||||
DBF (DB_VERBOSE, _("Giving up on target file `%s'.\n"));
|
DBF (DB_VERBOSE, _("Giving up on target file '%s'.\n"));
|
||||||
|
|
||||||
if (depth == 0 && keep_going_flag
|
if (depth == 0 && keep_going_flag
|
||||||
&& !just_print_flag && !question_flag)
|
&& !just_print_flag && !question_flag)
|
||||||
error (NILF,
|
error (NILF,
|
||||||
_("Target `%s' not remade because of errors."), file->name);
|
_("Target '%s' not remade because of errors."), file->name);
|
||||||
|
|
||||||
return dep_status;
|
return dep_status;
|
||||||
}
|
}
|
||||||
|
@ -724,20 +724,20 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
if (d->ignore_mtime)
|
if (d->ignore_mtime)
|
||||||
{
|
{
|
||||||
if (ISDB (DB_VERBOSE))
|
if (ISDB (DB_VERBOSE))
|
||||||
fmt = _("Prerequisite `%s' is order-only for target `%s'.\n");
|
fmt = _("Prerequisite '%s' is order-only for target '%s'.\n");
|
||||||
}
|
}
|
||||||
else if (d_mtime == NONEXISTENT_MTIME)
|
else if (d_mtime == NONEXISTENT_MTIME)
|
||||||
{
|
{
|
||||||
if (ISDB (DB_BASIC))
|
if (ISDB (DB_BASIC))
|
||||||
fmt = _("Prerequisite `%s' of target `%s' does not exist.\n");
|
fmt = _("Prerequisite '%s' of target '%s' does not exist.\n");
|
||||||
}
|
}
|
||||||
else if (d->changed)
|
else if (d->changed)
|
||||||
{
|
{
|
||||||
if (ISDB (DB_BASIC))
|
if (ISDB (DB_BASIC))
|
||||||
fmt = _("Prerequisite `%s' is newer than target `%s'.\n");
|
fmt = _("Prerequisite '%s' is newer than target '%s'.\n");
|
||||||
}
|
}
|
||||||
else if (ISDB (DB_VERBOSE))
|
else if (ISDB (DB_VERBOSE))
|
||||||
fmt = _("Prerequisite `%s' is older than target `%s'.\n");
|
fmt = _("Prerequisite '%s' is older than target '%s'.\n");
|
||||||
|
|
||||||
if (fmt)
|
if (fmt)
|
||||||
{
|
{
|
||||||
|
@ -755,19 +755,19 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
{
|
{
|
||||||
must_make = 1;
|
must_make = 1;
|
||||||
DBF (DB_BASIC,
|
DBF (DB_BASIC,
|
||||||
_("Target `%s' is double-colon and has no prerequisites.\n"));
|
_("Target '%s' is double-colon and has no prerequisites.\n"));
|
||||||
}
|
}
|
||||||
else if (!noexist && file->is_target && !deps_changed && file->cmds == 0
|
else if (!noexist && file->is_target && !deps_changed && file->cmds == 0
|
||||||
&& !always_make_flag)
|
&& !always_make_flag)
|
||||||
{
|
{
|
||||||
must_make = 0;
|
must_make = 0;
|
||||||
DBF (DB_VERBOSE,
|
DBF (DB_VERBOSE,
|
||||||
_("No recipe for `%s' and no prerequisites actually changed.\n"));
|
_("No recipe for '%s' and no prerequisites actually changed.\n"));
|
||||||
}
|
}
|
||||||
else if (!must_make && file->cmds != 0 && always_make_flag)
|
else if (!must_make && file->cmds != 0 && always_make_flag)
|
||||||
{
|
{
|
||||||
must_make = 1;
|
must_make = 1;
|
||||||
DBF (DB_VERBOSE, _("Making `%s' due to always-make flag.\n"));
|
DBF (DB_VERBOSE, _("Making '%s' due to always-make flag.\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!must_make)
|
if (!must_make)
|
||||||
|
@ -775,9 +775,9 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
if (ISDB (DB_VERBOSE))
|
if (ISDB (DB_VERBOSE))
|
||||||
{
|
{
|
||||||
print_spaces (depth);
|
print_spaces (depth);
|
||||||
printf (_("No need to remake target `%s'"), file->name);
|
printf (_("No need to remake target '%s'"), file->name);
|
||||||
if (!streq (file->name, file->hname))
|
if (!streq (file->name, file->hname))
|
||||||
printf (_("; using VPATH name `%s'"), file->hname);
|
printf (_("; using VPATH name '%s'"), file->hname);
|
||||||
puts (".");
|
puts (".");
|
||||||
fflush (stdout);
|
fflush (stdout);
|
||||||
}
|
}
|
||||||
|
@ -797,13 +797,13 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
DBF (DB_BASIC, _("Must remake target `%s'.\n"));
|
DBF (DB_BASIC, _("Must remake target '%s'.\n"));
|
||||||
|
|
||||||
/* It needs to be remade. If it's VPATH and not reset via GPATH, toss the
|
/* It needs to be remade. If it's VPATH and not reset via GPATH, toss the
|
||||||
VPATH. */
|
VPATH. */
|
||||||
if (!streq(file->name, file->hname))
|
if (!streq(file->name, file->hname))
|
||||||
{
|
{
|
||||||
DB (DB_BASIC, (_(" Ignoring VPATH name `%s'.\n"), file->hname));
|
DB (DB_BASIC, (_(" Ignoring VPATH name '%s'.\n"), file->hname));
|
||||||
file->ignore_vpath = 1;
|
file->ignore_vpath = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -812,20 +812,20 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
|
|
||||||
if (file->command_state != cs_finished)
|
if (file->command_state != cs_finished)
|
||||||
{
|
{
|
||||||
DBF (DB_VERBOSE, _("Recipe of `%s' is being run.\n"));
|
DBF (DB_VERBOSE, _("Recipe of '%s' is being run.\n"));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (file->update_status)
|
switch (file->update_status)
|
||||||
{
|
{
|
||||||
case 2:
|
case 2:
|
||||||
DBF (DB_BASIC, _("Failed to remake target file `%s'.\n"));
|
DBF (DB_BASIC, _("Failed to remake target file '%s'.\n"));
|
||||||
break;
|
break;
|
||||||
case 0:
|
case 0:
|
||||||
DBF (DB_BASIC, _("Successfully remade target file `%s'.\n"));
|
DBF (DB_BASIC, _("Successfully remade target file '%s'.\n"));
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
DBF (DB_BASIC, _("Target file `%s' needs remade under -q.\n"));
|
DBF (DB_BASIC, _("Target file '%s' needs remade under -q.\n"));
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
assert (file->update_status >= 0 && file->update_status <= 2);
|
assert (file->update_status >= 0 && file->update_status <= 2);
|
||||||
|
@ -836,8 +836,8 @@ update_file_1 (struct file *file, unsigned int depth)
|
||||||
return file->update_status;
|
return file->update_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set FILE's `updated' flag and re-check its mtime and the mtime's of all
|
/* Set FILE's 'updated' flag and re-check its mtime and the mtime's of all
|
||||||
files listed in its `also_make' member. Under -t, this function also
|
files listed in its 'also_make' member. Under -t, this function also
|
||||||
touches FILE.
|
touches FILE.
|
||||||
|
|
||||||
On return, FILE->update_status will no longer be -1 if it was. */
|
On return, FILE->update_status will no longer be -1 if it was. */
|
||||||
|
@ -882,7 +882,7 @@ notice_finished_file (struct file *file)
|
||||||
file->update_status = touch_file (file);
|
file->update_status = touch_file (file);
|
||||||
|
|
||||||
/* Pretend we ran a real touch command, to suppress the
|
/* Pretend we ran a real touch command, to suppress the
|
||||||
"`foo' is up to date" message. */
|
"'foo' is up to date" message. */
|
||||||
commands_started++;
|
commands_started++;
|
||||||
|
|
||||||
/* Request for the timestamp to be updated (and distributed
|
/* Request for the timestamp to be updated (and distributed
|
||||||
|
@ -1013,15 +1013,15 @@ check_dep (struct file *file, unsigned int depth,
|
||||||
if (!file->phony && file->cmds == 0 && !file->tried_implicit)
|
if (!file->phony && file->cmds == 0 && !file->tried_implicit)
|
||||||
{
|
{
|
||||||
if (try_implicit_rule (file, depth))
|
if (try_implicit_rule (file, depth))
|
||||||
DBF (DB_IMPLICIT, _("Found an implicit rule for `%s'.\n"));
|
DBF (DB_IMPLICIT, _("Found an implicit rule for '%s'.\n"));
|
||||||
else
|
else
|
||||||
DBF (DB_IMPLICIT, _("No implicit rule found for `%s'.\n"));
|
DBF (DB_IMPLICIT, _("No implicit rule found for '%s'.\n"));
|
||||||
file->tried_implicit = 1;
|
file->tried_implicit = 1;
|
||||||
}
|
}
|
||||||
if (file->cmds == 0 && !file->is_target
|
if (file->cmds == 0 && !file->is_target
|
||||||
&& default_file != 0 && default_file->cmds != 0)
|
&& default_file != 0 && default_file->cmds != 0)
|
||||||
{
|
{
|
||||||
DBF (DB_IMPLICIT, _("Using default commands for `%s'.\n"));
|
DBF (DB_IMPLICIT, _("Using default commands for '%s'.\n"));
|
||||||
file->cmds = default_file->cmds;
|
file->cmds = default_file->cmds;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1202,7 +1202,7 @@ remake_file (struct file *file)
|
||||||
notice_finished_file (file);
|
notice_finished_file (file);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Return the mtime of a file, given a `struct file'.
|
/* Return the mtime of a file, given a 'struct file'.
|
||||||
Caches the time in the struct file to avoid excess stat calls.
|
Caches the time in the struct file to avoid excess stat calls.
|
||||||
|
|
||||||
If the file is not found, and SEARCH is nonzero, VPATH searching and
|
If the file is not found, and SEARCH is nonzero, VPATH searching and
|
||||||
|
@ -1358,7 +1358,7 @@ f_mtime (struct file *file, int search)
|
||||||
if (adjusted_now < adjusted_mtime)
|
if (adjusted_now < adjusted_mtime)
|
||||||
{
|
{
|
||||||
#ifdef NO_FLOAT
|
#ifdef NO_FLOAT
|
||||||
error (NILF, _("Warning: File `%s' has modification time in the future"),
|
error (NILF, _("Warning: File '%s' has modification time in the future"),
|
||||||
file->name);
|
file->name);
|
||||||
#else
|
#else
|
||||||
double from_now =
|
double from_now =
|
||||||
|
@ -1371,7 +1371,7 @@ f_mtime (struct file *file, int search)
|
||||||
sprintf (from_now_string, "%lu", (unsigned long) from_now);
|
sprintf (from_now_string, "%lu", (unsigned long) from_now);
|
||||||
else
|
else
|
||||||
sprintf (from_now_string, "%.2g", from_now);
|
sprintf (from_now_string, "%.2g", from_now);
|
||||||
error (NILF, _("Warning: File `%s' has modification time %s s in the future"),
|
error (NILF, _("Warning: File '%s' has modification time %s s in the future"),
|
||||||
file->name, from_now_string);
|
file->name, from_now_string);
|
||||||
#endif
|
#endif
|
||||||
clock_skew_detected = 1;
|
clock_skew_detected = 1;
|
||||||
|
@ -1570,7 +1570,7 @@ library_search (const char *lib, FILE_TIMESTAMP *mtime_ptr)
|
||||||
if (!p3)
|
if (!p3)
|
||||||
{
|
{
|
||||||
/* Give a warning if there is no pattern. */
|
/* Give a warning if there is no pattern. */
|
||||||
error (NILF, _(".LIBPATTERNS element `%s' is not a pattern"), p);
|
error (NILF, _(".LIBPATTERNS element '%s' is not a pattern"), p);
|
||||||
p[len] = c;
|
p[len] = c;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -1580,7 +1580,7 @@ library_search (const char *lib, FILE_TIMESTAMP *mtime_ptr)
|
||||||
p[len] = c;
|
p[len] = c;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Look first for `libNAME.a' in the current directory. */
|
/* Look first for 'libNAME.a' in the current directory. */
|
||||||
mtime = name_mtime (libbuf);
|
mtime = name_mtime (libbuf);
|
||||||
if (mtime != NONEXISTENT_MTIME)
|
if (mtime != NONEXISTENT_MTIME)
|
||||||
{
|
{
|
||||||
|
|
|
@ -34,7 +34,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
char *remote_description = "Customs";
|
char *remote_description = "Customs";
|
||||||
|
|
||||||
/* File name of the Customs `export' client command.
|
/* File name of the Customs 'export' client command.
|
||||||
A full path name can be used to avoid some path-searching overhead. */
|
A full path name can be used to avoid some path-searching overhead. */
|
||||||
#define EXPORT_COMMAND "/usr/local/bin/export"
|
#define EXPORT_COMMAND "/usr/local/bin/export"
|
||||||
|
|
||||||
|
@ -175,7 +175,7 @@ start_remote_job (char **argv, char **envp, int stdin_fd,
|
||||||
len = Customs_MakeWayBill (&permit, normalized_cwd, argv[0], argv,
|
len = Customs_MakeWayBill (&permit, normalized_cwd, argv[0], argv,
|
||||||
envp, retport, waybill);
|
envp, retport, waybill);
|
||||||
|
|
||||||
/* Modify the waybill as if the remote child had done `child_access ()'. */
|
/* Modify the waybill as if the remote child had done 'child_access ()'. */
|
||||||
{
|
{
|
||||||
WayBill *wb = (WayBill *) waybill;
|
WayBill *wb = (WayBill *) waybill;
|
||||||
wb->ruid = wb->euid;
|
wb->ruid = wb->euid;
|
||||||
|
@ -232,7 +232,7 @@ start_remote_job (char **argv, char **envp, int stdin_fd,
|
||||||
}
|
}
|
||||||
else if (pid == 0)
|
else if (pid == 0)
|
||||||
{
|
{
|
||||||
/* Child side. Run `export' to handle the connection. */
|
/* Child side. Run 'export' to handle the connection. */
|
||||||
static char sock_buf[20], retsock_buf[20], id_buf[20];
|
static char sock_buf[20], retsock_buf[20], id_buf[20];
|
||||||
static char *new_argv[6] =
|
static char *new_argv[6] =
|
||||||
{ EXPORT_COMMAND, "-id", sock_buf, retsock_buf, id_buf, 0 };
|
{ EXPORT_COMMAND, "-id", sock_buf, retsock_buf, id_buf, 0 };
|
||||||
|
@ -253,7 +253,7 @@ start_remote_job (char **argv, char **envp, int stdin_fd,
|
||||||
exec_command (new_argv, envp);
|
exec_command (new_argv, envp);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Parent side. Return the `export' process's ID. */
|
/* Parent side. Return the 'export' process's ID. */
|
||||||
(void) close (retsock);
|
(void) close (retsock);
|
||||||
(void) close (sock);
|
(void) close (sock);
|
||||||
*is_remote = 0;
|
*is_remote = 0;
|
||||||
|
|
26
rule.c
26
rule.c
|
@ -126,7 +126,7 @@ count_implicit_rule_limits (void)
|
||||||
memcpy (name, dname, p - dname);
|
memcpy (name, dname, p - dname);
|
||||||
name[p - dname] = '\0';
|
name[p - dname] = '\0';
|
||||||
|
|
||||||
/* In the deps of an implicit rule the `changed' flag
|
/* In the deps of an implicit rule the 'changed' flag
|
||||||
actually indicates that the dependency is in a
|
actually indicates that the dependency is in a
|
||||||
nonexistent subdirectory. */
|
nonexistent subdirectory. */
|
||||||
|
|
||||||
|
@ -151,7 +151,7 @@ count_implicit_rule_limits (void)
|
||||||
/* Create a pattern rule from a suffix rule.
|
/* Create a pattern rule from a suffix rule.
|
||||||
TARGET is the target suffix; SOURCE is the source suffix.
|
TARGET is the target suffix; SOURCE is the source suffix.
|
||||||
CMDS are the commands.
|
CMDS are the commands.
|
||||||
If TARGET is nil, it means the target pattern should be `(%.o)'.
|
If TARGET is nil, it means the target pattern should be '(%.o)'.
|
||||||
If SOURCE is nil, it means there should be no deps. */
|
If SOURCE is nil, it means there should be no deps. */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -166,8 +166,8 @@ convert_suffix_rule (const char *target, const char *source,
|
||||||
|
|
||||||
if (target == 0)
|
if (target == 0)
|
||||||
{
|
{
|
||||||
/* Special case: TARGET being nil means we are defining a `.X.a' suffix
|
/* Special case: TARGET being nil means we are defining a '.X.a' suffix
|
||||||
rule; the target pattern is always `(%.o)'. */
|
rule; the target pattern is always '(%.o)'. */
|
||||||
#ifdef VMS
|
#ifdef VMS
|
||||||
*names = strcache_add_len ("(%.obj)", 7);
|
*names = strcache_add_len ("(%.obj)", 7);
|
||||||
#else
|
#else
|
||||||
|
@ -261,14 +261,14 @@ convert_to_pattern (void)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (s2len == 2 && rulename[slen] == '.' && rulename[slen + 1] == 'a')
|
if (s2len == 2 && rulename[slen] == '.' && rulename[slen + 1] == 'a')
|
||||||
/* A suffix rule `.X.a:' generates the pattern rule `(%.o): %.X'.
|
/* A suffix rule '.X.a:' generates the pattern rule '(%.o): %.X'.
|
||||||
It also generates a normal `%.a: %.X' rule below. */
|
It also generates a normal '%.a: %.X' rule below. */
|
||||||
convert_suffix_rule (NULL, /* Indicates `(%.o)'. */
|
convert_suffix_rule (NULL, /* Indicates '(%.o)'. */
|
||||||
dep_name (d),
|
dep_name (d),
|
||||||
f->cmds);
|
f->cmds);
|
||||||
|
|
||||||
/* The suffix rule `.X.Y:' is converted
|
/* The suffix rule '.X.Y:' is converted
|
||||||
to the pattern rule `%.Y: %.X'. */
|
to the pattern rule '%.Y: %.X'. */
|
||||||
convert_suffix_rule (dep_name (d2), dep_name (d), f->cmds);
|
convert_suffix_rule (dep_name (d2), dep_name (d), f->cmds);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -355,7 +355,7 @@ new_pattern_rule (struct rule *rule, int override)
|
||||||
/* Install an implicit pattern rule based on the three text strings
|
/* Install an implicit pattern rule based on the three text strings
|
||||||
in the structure P points to. These strings come from one of
|
in the structure P points to. These strings come from one of
|
||||||
the arrays of default implicit pattern rules.
|
the arrays of default implicit pattern rules.
|
||||||
TERMINAL specifies what the `terminal' field of the rule should be. */
|
TERMINAL specifies what the 'terminal' field of the rule should be. */
|
||||||
|
|
||||||
void
|
void
|
||||||
install_pattern_rule (struct pspec *p, int terminal)
|
install_pattern_rule (struct pspec *p, int terminal)
|
||||||
|
@ -413,13 +413,13 @@ freerule (struct rule *rule, struct rule *lastrule)
|
||||||
/* We can't free the storage for the commands because there
|
/* We can't free the storage for the commands because there
|
||||||
are ways that they could be in more than one place:
|
are ways that they could be in more than one place:
|
||||||
* If the commands came from a suffix rule, they could also be in
|
* If the commands came from a suffix rule, they could also be in
|
||||||
the `struct file's for other suffix rules or plain targets given
|
the 'struct file's for other suffix rules or plain targets given
|
||||||
on the same makefile line.
|
on the same makefile line.
|
||||||
* If two suffixes that together make a two-suffix rule were each
|
* If two suffixes that together make a two-suffix rule were each
|
||||||
given twice in the .SUFFIXES list, and in the proper order, two
|
given twice in the .SUFFIXES list, and in the proper order, two
|
||||||
identical pattern rules would be created and the second one would
|
identical pattern rules would be created and the second one would
|
||||||
be discarded here, but both would contain the same `struct commands'
|
be discarded here, but both would contain the same 'struct commands'
|
||||||
pointer from the `struct file' for the suffix rule. */
|
pointer from the 'struct file' for the suffix rule. */
|
||||||
|
|
||||||
free (rule);
|
free (rule);
|
||||||
|
|
||||||
|
|
2
rule.h
2
rule.h
|
@ -24,7 +24,7 @@ struct rule
|
||||||
struct rule *next;
|
struct rule *next;
|
||||||
const char **targets; /* Targets of the rule. */
|
const char **targets; /* Targets of the rule. */
|
||||||
unsigned int *lens; /* Lengths of each target. */
|
unsigned int *lens; /* Lengths of each target. */
|
||||||
const char **suffixes; /* Suffixes (after `%') of each target. */
|
const char **suffixes; /* Suffixes (after '%') of each target. */
|
||||||
struct dep *deps; /* Dependencies of the rule. */
|
struct dep *deps; /* Dependencies of the rule. */
|
||||||
struct commands *cmds; /* Commands to execute. */
|
struct commands *cmds; /* Commands to execute. */
|
||||||
unsigned short num; /* Number of targets. */
|
unsigned short num; /* Number of targets. */
|
||||||
|
|
|
@ -28,7 +28,7 @@ esac
|
||||||
dest="$1"
|
dest="$1"
|
||||||
|
|
||||||
if [ ! -d "$dest" ]; then
|
if [ ! -d "$dest" ]; then
|
||||||
echo "Destination directory \`$dest' must exist!"
|
echo "Destination directory '$dest' must exist!"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -55,5 +55,5 @@ done
|
||||||
|
|
||||||
rm -rf work
|
rm -rf work
|
||||||
|
|
||||||
echo "Shadow test suite created in \`$dest/$name'."
|
echo "Shadow test suite created in '$dest/$name'."
|
||||||
exit 0
|
exit 0
|
||||||
|
|
|
@ -318,7 +318,7 @@ sub set_more_defaults
|
||||||
$mk or die "FATAL ERROR: Cannot determine the value of \$(MAKE):\n
|
$mk or die "FATAL ERROR: Cannot determine the value of \$(MAKE):\n
|
||||||
'echo \"all:;\@echo \\\$(MAKE)\" | $make_path -f-' failed!\n";
|
'echo \"all:;\@echo \\\$(MAKE)\" | $make_path -f-' failed!\n";
|
||||||
$make_path = $mk;
|
$make_path = $mk;
|
||||||
print "Make\t= `$make_path'\n" if $debug;
|
print "Make\t= '$make_path'\n" if $debug;
|
||||||
|
|
||||||
$string = `$make_path -v -f /dev/null 2> /dev/null`;
|
$string = `$make_path -v -f /dev/null 2> /dev/null`;
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ run_make_test(undef, '', "ar rv libxx.a a1.o\nr - a1.o\n");
|
||||||
|
|
||||||
# Use wildcards
|
# Use wildcards
|
||||||
run_make_test('all: libxx.a(*.o)',
|
run_make_test('all: libxx.a(*.o)',
|
||||||
'', "#MAKE#: Nothing to be done for `all'.\n");
|
'', "#MAKE#: Nothing to be done for 'all'.\n");
|
||||||
|
|
||||||
# Touch one of the .o's so it's rebuilt
|
# Touch one of the .o's so it's rebuilt
|
||||||
utouch(-30, 'a1.o');
|
utouch(-30, 'a1.o');
|
||||||
|
|
|
@ -50,7 +50,7 @@ $delete_error_code = $? >> 8;
|
||||||
|
|
||||||
$answer = "$rm_command cleanit
|
$answer = "$rm_command cleanit
|
||||||
$cleanit_error
|
$cleanit_error
|
||||||
$makefile:2: recipe for target `clean' failed
|
$makefile:2: recipe for target 'clean' failed
|
||||||
$make_name: [clean] Error $delete_error_code (ignored)
|
$make_name: [clean] Error $delete_error_code (ignored)
|
||||||
$rm_command foo\n";
|
$rm_command foo\n";
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ if (!$vos)
|
||||||
|
|
||||||
$answer = "$rm_command cleanit
|
$answer = "$rm_command cleanit
|
||||||
$cleanit_error
|
$cleanit_error
|
||||||
$makefile:5: recipe for target `clean2' failed
|
$makefile:5: recipe for target 'clean2' failed
|
||||||
$make_name: [clean2] Error $delete_error_code (ignored)
|
$make_name: [clean2] Error $delete_error_code (ignored)
|
||||||
$rm_command foo\n";
|
$rm_command foo\n";
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
$description = "Test various types of escaping in makefiles.";
|
$description = "Test various types of escaping in makefiles.";
|
||||||
|
|
||||||
$details = "\
|
$details = "\
|
||||||
Make sure that escaping of `:' works in target names.
|
Make sure that escaping of ':' works in target names.
|
||||||
Make sure escaping of whitespace works in target names.
|
Make sure escaping of whitespace works in target names.
|
||||||
Make sure that escaping of '#' works.";
|
Make sure that escaping of '#' works.";
|
||||||
|
|
||||||
|
@ -26,7 +26,7 @@ foo\#bar.ext: ; @echo "foo#bar.ext = ($@)"',
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'path=pre:',
|
'path=pre:',
|
||||||
"#MAKEFILE#:2: *** target pattern contains no `%'. Stop.",
|
"#MAKEFILE#:2: *** target pattern contains no '%'. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
# TEST 3: This one should work, since we escape the ":".
|
# TEST 3: This one should work, since we escape the ":".
|
||||||
|
@ -39,7 +39,7 @@ run_make_test(undef,
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
"'path=pre\\\\:'",
|
"'path=pre\\\\:'",
|
||||||
"#MAKEFILE#:2: *** target pattern contains no `%'. Stop.",
|
"#MAKEFILE#:2: *** target pattern contains no '%'. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
# TEST 5: This one should work
|
# TEST 5: This one should work
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
# -*-mode: perl; rm-trailing-spaces: nil-*-
|
# -*-mode: perl; rm-trailing-spaces: nil-*-
|
||||||
|
|
||||||
$description = "Test various forms of the GNU make `include' command.";
|
$description = "Test various forms of the GNU make 'include' command.";
|
||||||
|
|
||||||
$details = "\
|
$details = "\
|
||||||
Test include, -include, sinclude and various regressions involving them.
|
Test include, -include, sinclude and various regressions involving them.
|
||||||
|
@ -60,7 +60,7 @@ run_make_test
|
||||||
error: foo.mk ; @echo $@
|
error: foo.mk ; @echo $@
|
||||||
',
|
',
|
||||||
'',
|
'',
|
||||||
"#MAKE#: *** No rule to make target `foo.mk', needed by `error'. Stop.\n",
|
"#MAKE#: *** No rule to make target 'foo.mk', needed by 'error'. Stop.\n",
|
||||||
512
|
512
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -128,7 +128,7 @@ foo: baz
|
||||||
bar: baz
|
bar: baz
|
||||||
',
|
',
|
||||||
'',
|
'',
|
||||||
"#MAKE#: *** No rule to make target `baz', needed by `bar'. Stop.\n",
|
"#MAKE#: *** No rule to make target 'baz', needed by 'bar'. Stop.\n",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
# Test that the diagnostics is issued even if the target has been
|
# Test that the diagnostics is issued even if the target has been
|
||||||
|
@ -144,7 +144,7 @@ bar: baz
|
||||||
baz: end
|
baz: end
|
||||||
',
|
',
|
||||||
'',
|
'',
|
||||||
"#MAKE#: *** No rule to make target `end', needed by `baz'. Stop.\n",
|
"#MAKE#: *** No rule to make target 'end', needed by 'baz'. Stop.\n",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
# Test that the diagnostics is issued even if the target has been
|
# Test that the diagnostics is issued even if the target has been
|
||||||
|
@ -162,7 +162,7 @@ baz: end
|
||||||
',
|
',
|
||||||
'',
|
'',
|
||||||
"#MAKEFILE#:2: bar: No such file or directory
|
"#MAKEFILE#:2: bar: No such file or directory
|
||||||
#MAKE#: *** No rule to make target `end', needed by `baz'. Stop.\n",
|
#MAKE#: *** No rule to make target 'end', needed by 'baz'. Stop.\n",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
if ($all_tests) {
|
if ($all_tests) {
|
||||||
|
@ -172,7 +172,7 @@ if ($all_tests) {
|
||||||
include foo
|
include foo
|
||||||
foo: ; @echo foo = bar > $@
|
foo: ; @echo foo = bar > $@
|
||||||
!,
|
!,
|
||||||
'', "#MAKE#: `foo' is up to date.\n");
|
'', "#MAKE#: 'foo' is up to date.\n");
|
||||||
rmfiles('foo');
|
rmfiles('foo');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -47,7 +47,7 @@ else
|
||||||
$error_code);
|
$error_code);
|
||||||
|
|
||||||
# Create the answer to what should be produced by this Makefile
|
# Create the answer to what should be produced by this Makefile
|
||||||
$answer = "$make_name: *** No rule to make target `extra.h', needed by `foo.o'. Stop.\n";
|
$answer = "$make_name: *** No rule to make target 'extra.h', needed by 'foo.o'. Stop.\n";
|
||||||
|
|
||||||
&compare_output($answer,&get_logfile(1));
|
&compare_output($answer,&get_logfile(1));
|
||||||
|
|
||||||
|
|
|
@ -99,14 +99,14 @@ ok:
|
||||||
\@sleep 4
|
\@sleep 4
|
||||||
\@echo Ok done",
|
\@echo Ok done",
|
||||||
'-rR -j5', "Fail
|
'-rR -j5', "Fail
|
||||||
#MAKEFILE#:6: recipe for target `fail.1' failed
|
#MAKEFILE#:6: recipe for target 'fail.1' failed
|
||||||
#MAKE#: *** [fail.1] Error 1
|
#MAKE#: *** [fail.1] Error 1
|
||||||
#MAKE#: *** Waiting for unfinished jobs....
|
#MAKE#: *** Waiting for unfinished jobs....
|
||||||
Fail
|
Fail
|
||||||
#MAKEFILE#:6: recipe for target `fail.2' failed
|
#MAKEFILE#:6: recipe for target 'fail.2' failed
|
||||||
#MAKE#: *** [fail.2] Error 1
|
#MAKE#: *** [fail.2] Error 1
|
||||||
Fail
|
Fail
|
||||||
#MAKEFILE#:6: recipe for target `fail.3' failed
|
#MAKEFILE#:6: recipe for target 'fail.3' failed
|
||||||
#MAKE#: *** [fail.3] Error 1
|
#MAKE#: *** [fail.3] Error 1
|
||||||
Ok done",
|
Ok done",
|
||||||
512);
|
512);
|
||||||
|
|
|
@ -110,7 +110,7 @@ $(dir)/foo.bar:
|
||||||
|
|
||||||
',
|
',
|
||||||
"dir=$dir",
|
"dir=$dir",
|
||||||
"#MAKEFILE#:6: recipe for target `$dir/foo.bar' failed
|
"#MAKEFILE#:6: recipe for target '$dir/foo.bar' failed
|
||||||
#MAKE#: *** [$dir/foo.bar] Error 1",
|
#MAKE#: *** [$dir/foo.bar] Error 1",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
|
@ -204,7 +204,7 @@ CWEAVE := :
|
||||||
%.tex : %.w %.ch
|
%.tex : %.w %.ch
|
||||||
!,
|
!,
|
||||||
'foo.tex',
|
'foo.tex',
|
||||||
"#MAKE#: *** No rule to make target `foo.tex'. Stop.", 512);
|
"#MAKE#: *** No rule to make target 'foo.tex'. Stop.", 512);
|
||||||
|
|
||||||
unlink(@f);
|
unlink(@f);
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,7 @@ last:
|
||||||
',
|
',
|
||||||
('CFLAGS=-O -w' . ($parallel_jobs ? ' -j 2' : '')),
|
('CFLAGS=-O -w' . ($parallel_jobs ? ' -j 2' : '')),
|
||||||
($vos
|
($vos
|
||||||
? "#MAKE#: Entering directory `#PWD#'
|
? "#MAKE#: Entering directory '#PWD#'
|
||||||
make 'CFLAGS=-O' -f #MAKEFILE# foo
|
make 'CFLAGS=-O' -f #MAKEFILE# foo
|
||||||
make CFLAGS=-O
|
make CFLAGS=-O
|
||||||
MAKELEVEL = 0
|
MAKELEVEL = 0
|
||||||
|
@ -26,20 +26,20 @@ make 'CFLAGS=-O' -f #MAKEFILE# last
|
||||||
make CFLAGS=-O
|
make CFLAGS=-O
|
||||||
MAKELEVEL = 0
|
MAKELEVEL = 0
|
||||||
THE END
|
THE END
|
||||||
#MAKE#: Leaving directory `#PWD#'"
|
#MAKE#: Leaving directory '#PWD#'"
|
||||||
: "#MAKE#: Entering directory `#PWD#'
|
: "#MAKE#: Entering directory '#PWD#'
|
||||||
#MAKEPATH# -f #MAKEFILE# foo
|
#MAKEPATH# -f #MAKEFILE# foo
|
||||||
#MAKE#[1]: Entering directory `#PWD#'
|
#MAKE#[1]: Entering directory '#PWD#'
|
||||||
#MAKEPATH#
|
#MAKEPATH#
|
||||||
MAKELEVEL = 1
|
MAKELEVEL = 1
|
||||||
#MAKEPATH# -f #MAKEFILE# last
|
#MAKEPATH# -f #MAKEFILE# last
|
||||||
#MAKE#[2]: Entering directory `#PWD#'
|
#MAKE#[2]: Entering directory '#PWD#'
|
||||||
#MAKEPATH#
|
#MAKEPATH#
|
||||||
MAKELEVEL = 2
|
MAKELEVEL = 2
|
||||||
THE END
|
THE END
|
||||||
#MAKE#[2]: Leaving directory `#PWD#'
|
#MAKE#[2]: Leaving directory '#PWD#'
|
||||||
#MAKE#[1]: Leaving directory `#PWD#'
|
#MAKE#[1]: Leaving directory '#PWD#'
|
||||||
#MAKE#: Leaving directory `#PWD#'"));
|
#MAKE#: Leaving directory '#PWD#'"));
|
||||||
|
|
||||||
|
|
||||||
# Test command line overrides.
|
# Test command line overrides.
|
||||||
|
|
|
@ -115,7 +115,7 @@ run_make_test(q!
|
||||||
.SECONDEXPANSION:
|
.SECONDEXPANSION:
|
||||||
all : $$(eval $$(info test))
|
all : $$(eval $$(info test))
|
||||||
!,
|
!,
|
||||||
'', "test\n#MAKE#: Nothing to be done for `all'.\n");
|
'', "test\n#MAKE#: Nothing to be done for 'all'.\n");
|
||||||
|
|
||||||
# TEST #5: (NEGATIVE) catch eval in a prereq list trying to create new
|
# TEST #5: (NEGATIVE) catch eval in a prereq list trying to create new
|
||||||
# target/prereq relationships.
|
# target/prereq relationships.
|
||||||
|
|
|
@ -74,7 +74,7 @@ vpath-d/a: fail.te
|
||||||
vpath-d/b : fail.te
|
vpath-d/b : fail.te
|
||||||
vpath-d/fail.te:
|
vpath-d/fail.te:
|
||||||
!,
|
!,
|
||||||
'', "#MAKE#: Nothing to be done for `default'.\n");
|
'', "#MAKE#: Nothing to be done for 'default'.\n");
|
||||||
|
|
||||||
rmdir('vpath-d');
|
rmdir('vpath-d');
|
||||||
|
|
||||||
|
|
|
@ -57,7 +57,7 @@ sub touchfiles {
|
||||||
|
|
||||||
push(@touchedfiles, "bar.c");
|
push(@touchedfiles, "bar.c");
|
||||||
|
|
||||||
$answer = "$make_name: Nothing to be done for `general'.\n";
|
$answer = "$make_name: Nothing to be done for 'general'.\n";
|
||||||
|
|
||||||
&compare_output($answer,&get_logfile(1));
|
&compare_output($answer,&get_logfile(1));
|
||||||
|
|
||||||
|
|
|
@ -86,7 +86,7 @@ cat ${VP}foo.c bar.c > foo.b 2>/dev/null || exit 1
|
||||||
|
|
||||||
$answer = "not creating notarget.c from notarget.d
|
$answer = "not creating notarget.c from notarget.d
|
||||||
cat notarget.c > notarget.b 2>/dev/null || exit 1
|
cat notarget.c > notarget.b 2>/dev/null || exit 1
|
||||||
$makefile:16: recipe for target `notarget.b' failed
|
$makefile:16: recipe for target 'notarget.b' failed
|
||||||
$make_name: *** [notarget.b] Error 1
|
$make_name: *** [notarget.b] Error 1
|
||||||
";
|
";
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@ print MAKEFILE <<'EOMAKE';
|
||||||
#
|
#
|
||||||
reverse = $2 $1
|
reverse = $2 $1
|
||||||
|
|
||||||
# A complex `map' function, using recursive `call'.
|
# A complex 'map' function, using recursive 'call'.
|
||||||
#
|
#
|
||||||
map = $(foreach a,$2,$(call $1,$a))
|
map = $(foreach a,$2,$(call $1,$a))
|
||||||
|
|
||||||
|
|
|
@ -62,7 +62,7 @@ y = $x
|
||||||
|
|
||||||
all: ; @echo $y',
|
all: ; @echo $y',
|
||||||
'',
|
'',
|
||||||
"#MAKEFILE#:2: *** insufficient number of arguments (1) to function `foreach'. Stop.",
|
"#MAKEFILE#:2: *** insufficient number of arguments (1) to function 'foreach'. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test('
|
run_make_test('
|
||||||
|
@ -71,7 +71,7 @@ y := $x
|
||||||
|
|
||||||
all: ; @echo $y',
|
all: ; @echo $y',
|
||||||
'',
|
'',
|
||||||
"#MAKEFILE#:2: *** insufficient number of arguments (1) to function `foreach'. Stop.",
|
"#MAKEFILE#:2: *** insufficient number of arguments (1) to function 'foreach'. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
|
@ -56,32 +56,32 @@ wordlist-e1: ; @echo $(wordlist ,,$(FOO))
|
||||||
wordlist-e2: ; @echo $(wordlist abc ,,$(FOO))
|
wordlist-e2: ; @echo $(wordlist abc ,,$(FOO))
|
||||||
wordlist-e3: ; @echo $(wordlist 1, 12a ,$(FOO))',
|
wordlist-e3: ; @echo $(wordlist 1, 12a ,$(FOO))',
|
||||||
'word-e1',
|
'word-e1',
|
||||||
"#MAKEFILE#:3: *** non-numeric first argument to `word' function: ''. Stop.",
|
"#MAKEFILE#:3: *** non-numeric first argument to 'word' function: ''. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'word-e2',
|
'word-e2',
|
||||||
"#MAKEFILE#:4: *** non-numeric first argument to `word' function: 'abc '. Stop.",
|
"#MAKEFILE#:4: *** non-numeric first argument to 'word' function: 'abc '. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'word-e3',
|
'word-e3',
|
||||||
"#MAKEFILE#:5: *** non-numeric first argument to `word' function: '1a'. Stop.",
|
"#MAKEFILE#:5: *** non-numeric first argument to 'word' function: '1a'. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'wordlist-e1',
|
'wordlist-e1',
|
||||||
"#MAKEFILE#:7: *** non-numeric first argument to `wordlist' function: ''. Stop.",
|
"#MAKEFILE#:7: *** non-numeric first argument to 'wordlist' function: ''. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'wordlist-e2',
|
'wordlist-e2',
|
||||||
"#MAKEFILE#:8: *** non-numeric first argument to `wordlist' function: 'abc '. Stop.",
|
"#MAKEFILE#:8: *** non-numeric first argument to 'wordlist' function: 'abc '. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'wordlist-e3',
|
'wordlist-e3',
|
||||||
"#MAKEFILE#:9: *** non-numeric second argument to `wordlist' function: ' 12a '. Stop.",
|
"#MAKEFILE#:9: *** non-numeric second argument to 'wordlist' function: ' 12a '. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
# Test error conditions again, but this time in a variable reference
|
# Test error conditions again, but this time in a variable reference
|
||||||
|
@ -94,37 +94,37 @@ WL = $(wordlist $s,$e,$(FOO))
|
||||||
word-e: ; @echo $(W)
|
word-e: ; @echo $(W)
|
||||||
wordlist-e: ; @echo $(WL)',
|
wordlist-e: ; @echo $(WL)',
|
||||||
'word-e x=',
|
'word-e x=',
|
||||||
"#MAKEFILE#:3: *** non-numeric first argument to `word' function: ''. Stop.",
|
"#MAKEFILE#:3: *** non-numeric first argument to 'word' function: ''. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'word-e x=abc',
|
'word-e x=abc',
|
||||||
"#MAKEFILE#:3: *** non-numeric first argument to `word' function: 'abc'. Stop.",
|
"#MAKEFILE#:3: *** non-numeric first argument to 'word' function: 'abc'. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'word-e x=0',
|
'word-e x=0',
|
||||||
"#MAKEFILE#:3: *** first argument to `word' function must be greater than 0. Stop.",
|
"#MAKEFILE#:3: *** first argument to 'word' function must be greater than 0. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'wordlist-e s= e=',
|
'wordlist-e s= e=',
|
||||||
"#MAKEFILE#:4: *** non-numeric first argument to `wordlist' function: ''. Stop.",
|
"#MAKEFILE#:4: *** non-numeric first argument to 'wordlist' function: ''. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'wordlist-e s=abc e=',
|
'wordlist-e s=abc e=',
|
||||||
"#MAKEFILE#:4: *** non-numeric first argument to `wordlist' function: 'abc'. Stop.",
|
"#MAKEFILE#:4: *** non-numeric first argument to 'wordlist' function: 'abc'. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'wordlist-e s=4 e=12a',
|
'wordlist-e s=4 e=12a',
|
||||||
"#MAKEFILE#:4: *** non-numeric second argument to `wordlist' function: '12a'. Stop.",
|
"#MAKEFILE#:4: *** non-numeric second argument to 'wordlist' function: '12a'. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
run_make_test(undef,
|
run_make_test(undef,
|
||||||
'wordlist-e s=0 e=12',
|
'wordlist-e s=0 e=12',
|
||||||
"#MAKEFILE#:4: *** invalid first argument to `wordlist' function: `0'. Stop.",
|
"#MAKEFILE#:4: *** invalid first argument to 'wordlist' function: '0'. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ TAB = \t \# A TAB and some spaces
|
||||||
\$(STR)
|
\$(STR)
|
||||||
|
|
||||||
\$(STR) \$(TAB)",
|
\$(STR) \$(TAB)",
|
||||||
'', "#MAKE#: Nothing to be done for `all'.");
|
'', "#MAKE#: Nothing to be done for 'all'.");
|
||||||
|
|
||||||
# TEST 2
|
# TEST 2
|
||||||
|
|
||||||
|
|
|
@ -22,13 +22,13 @@ foo: bar.x
|
||||||
',
|
',
|
||||||
'', 'cp bar.x foo');
|
'', 'cp bar.x foo');
|
||||||
|
|
||||||
run_make_test(undef, '', "#MAKE#: Nothing to be done for `all'.");
|
run_make_test(undef, '', "#MAKE#: Nothing to be done for 'all'.");
|
||||||
run_make_test(undef, '-B', 'cp bar.x foo');
|
run_make_test(undef, '-B', 'cp bar.x foo');
|
||||||
|
|
||||||
# Put the timestamp for foo into the future; it should still be remade.
|
# Put the timestamp for foo into the future; it should still be remade.
|
||||||
|
|
||||||
utouch(1000, 'foo');
|
utouch(1000, 'foo');
|
||||||
run_make_test(undef, '', "#MAKE#: Nothing to be done for `all'.");
|
run_make_test(undef, '', "#MAKE#: Nothing to be done for 'all'.");
|
||||||
run_make_test(undef, '-B', 'cp bar.x foo');
|
run_make_test(undef, '-B', 'cp bar.x foo');
|
||||||
|
|
||||||
# Clean up
|
# Clean up
|
||||||
|
|
|
@ -34,9 +34,9 @@ if (-f $example) {
|
||||||
}
|
}
|
||||||
|
|
||||||
# Create the answer to what should be produced by this Makefile
|
# Create the answer to what should be produced by this Makefile
|
||||||
$answer = "$make_name: Entering directory `$wpath'\n"
|
$answer = "$make_name: Entering directory '$wpath'\n"
|
||||||
. "$delete_command EXAMPLE\n"
|
. "$delete_command EXAMPLE\n"
|
||||||
. "$make_name: Leaving directory `$wpath'\n";
|
. "$make_name: Leaving directory '$wpath'\n";
|
||||||
|
|
||||||
&compare_output($answer,&get_logfile(1));
|
&compare_output($answer,&get_logfile(1));
|
||||||
|
|
||||||
|
@ -62,9 +62,9 @@ if (-f $example) {
|
||||||
}
|
}
|
||||||
|
|
||||||
# Create the answer to what should be produced by this Makefile
|
# Create the answer to what should be produced by this Makefile
|
||||||
$answer = "$make_name: Entering directory `$wpath'\n"
|
$answer = "$make_name: Entering directory '$wpath'\n"
|
||||||
. "$delete_command EXAMPLEslash\n"
|
. "$delete_command EXAMPLEslash\n"
|
||||||
. "$make_name: Leaving directory `$wpath'\n";
|
. "$make_name: Leaving directory '$wpath'\n";
|
||||||
|
|
||||||
&compare_output($answer,&get_logfile(1));
|
&compare_output($answer,&get_logfile(1));
|
||||||
|
|
||||||
|
|
|
@ -51,9 +51,9 @@ $answer = "This is another included makefile\n";
|
||||||
|
|
||||||
|
|
||||||
$answer = "$mkpath ANOTHER -f $makefile
|
$answer = "$mkpath ANOTHER -f $makefile
|
||||||
${make_name}[1]: Entering directory `$pwd'
|
${make_name}[1]: Entering directory '$pwd'
|
||||||
This is another included makefile
|
This is another included makefile
|
||||||
${make_name}[1]: Leaving directory `$pwd'\n";
|
${make_name}[1]: Leaving directory '$pwd'\n";
|
||||||
|
|
||||||
&run_make_with_options($makefile,"-I $workdir recurse",&get_logfile);
|
&run_make_with_options($makefile,"-I $workdir recurse",&get_logfile);
|
||||||
&compare_output($answer,&get_logfile(1));
|
&compare_output($answer,&get_logfile(1));
|
||||||
|
|
|
@ -12,7 +12,7 @@ a.x b.x: ; echo >> $@
|
||||||
|
|
||||||
# Run it again: nothing should happen
|
# Run it again: nothing should happen
|
||||||
|
|
||||||
run_make_test(undef, '', "#MAKE#: `a.x' is up to date.");
|
run_make_test(undef, '', "#MAKE#: 'a.x' is up to date.");
|
||||||
|
|
||||||
# Now run it with -W b.x: should rebuild a.x
|
# Now run it with -W b.x: should rebuild a.x
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@ run_make_test(undef, '-W b.x', 'echo >> a.x');
|
||||||
# Put the timestamp for a.x into the future; it should still be remade.
|
# Put the timestamp for a.x into the future; it should still be remade.
|
||||||
|
|
||||||
utouch(1000, 'a.x');
|
utouch(1000, 'a.x');
|
||||||
run_make_test(undef, '', "#MAKE#: `a.x' is up to date.");
|
run_make_test(undef, '', "#MAKE#: 'a.x' is up to date.");
|
||||||
run_make_test(undef, '-W b.x', 'echo >> a.x');
|
run_make_test(undef, '-W b.x', 'echo >> a.x');
|
||||||
|
|
||||||
# Clean up
|
# Clean up
|
||||||
|
|
|
@ -57,10 +57,10 @@ else {
|
||||||
|
|
||||||
# Create the answer to what should be produced by this Makefile
|
# Create the answer to what should be produced by this Makefile
|
||||||
$answer = "cc -c main.c
|
$answer = "cc -c main.c
|
||||||
$make_name: *** No rule to make target `kbd.c', needed by `kbd.o'.
|
$make_name: *** No rule to make target 'kbd.c', needed by 'kbd.o'.
|
||||||
cc -c commands.c
|
cc -c commands.c
|
||||||
cc -c display.c
|
cc -c display.c
|
||||||
$make_name: Target `edit' not remade because of errors.\n";
|
$make_name: Target 'edit' not remade because of errors.\n";
|
||||||
|
|
||||||
# COMPARE RESULTS
|
# COMPARE RESULTS
|
||||||
|
|
||||||
|
@ -92,9 +92,9 @@ close(MAKEFILE);
|
||||||
&run_make_with_options($makefile2, "-k", &get_logfile, $error_code);
|
&run_make_with_options($makefile2, "-k", &get_logfile, $error_code);
|
||||||
|
|
||||||
$answer = "exit 1
|
$answer = "exit 1
|
||||||
$makefile2:9: recipe for target `foo.o' failed
|
$makefile2:9: recipe for target 'foo.o' failed
|
||||||
$make_name: *** [foo.o] Error 1
|
$make_name: *** [foo.o] Error 1
|
||||||
$make_name: Target `all' not remade because of errors.\n";
|
$make_name: Target 'all' not remade because of errors.\n";
|
||||||
|
|
||||||
&compare_output($answer, &get_logfile(1));
|
&compare_output($answer, &get_logfile(1));
|
||||||
|
|
||||||
|
@ -107,8 +107,8 @@ ifile: no-such-file; @false
|
||||||
',
|
',
|
||||||
'-k',
|
'-k',
|
||||||
"#MAKEFILE#:2: ifile: No such file or directory
|
"#MAKEFILE#:2: ifile: No such file or directory
|
||||||
#MAKE#: *** No rule to make target `no-such-file', needed by `ifile'.
|
#MAKE#: *** No rule to make target 'no-such-file', needed by 'ifile'.
|
||||||
#MAKE#: Failed to remake makefile `ifile'.
|
#MAKE#: Failed to remake makefile 'ifile'.
|
||||||
hi\n",
|
hi\n",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
|
|
|
@ -56,13 +56,13 @@ close(MAKEFILE);
|
||||||
# TEST 2
|
# TEST 2
|
||||||
|
|
||||||
&run_make_with_options($makefile2, "", &get_logfile);
|
&run_make_with_options($makefile2, "", &get_logfile);
|
||||||
$answer = "$make_name: `a' is up to date.\n";
|
$answer = "$make_name: 'a' is up to date.\n";
|
||||||
&compare_output($answer, &get_logfile(1));
|
&compare_output($answer, &get_logfile(1));
|
||||||
|
|
||||||
# TEST 3
|
# TEST 3
|
||||||
|
|
||||||
&run_make_with_options($makefile2, "-n", &get_logfile);
|
&run_make_with_options($makefile2, "-n", &get_logfile);
|
||||||
$answer = "$make_name: `a' is up to date.\n";
|
$answer = "$make_name: 'a' is up to date.\n";
|
||||||
&compare_output($answer, &get_logfile(1));
|
&compare_output($answer, &get_logfile(1));
|
||||||
|
|
||||||
# TEST 4
|
# TEST 4
|
||||||
|
|
|
@ -26,7 +26,7 @@ if ($port_type eq 'W32' || !( eval { symlink("",""); 1 })) {
|
||||||
# Without -L, nothing should happen
|
# Without -L, nothing should happen
|
||||||
# With -L, it should update targ
|
# With -L, it should update targ
|
||||||
run_make_test('targ: sym ; @echo make $@ from $<', '',
|
run_make_test('targ: sym ; @echo make $@ from $<', '',
|
||||||
"#MAKE#: `targ' is up to date.");
|
"#MAKE#: 'targ' is up to date.");
|
||||||
run_make_test(undef, '-L', "make targ from sym");
|
run_make_test(undef, '-L', "make targ from sym");
|
||||||
|
|
||||||
# Now update dep; in all cases targ should be out of date.
|
# Now update dep; in all cases targ should be out of date.
|
||||||
|
@ -36,8 +36,8 @@ if ($port_type eq 'W32' || !( eval { symlink("",""); 1 })) {
|
||||||
|
|
||||||
# Now update targ; in all cases targ should be up to date.
|
# Now update targ; in all cases targ should be up to date.
|
||||||
&touch('targ');
|
&touch('targ');
|
||||||
run_make_test(undef, '', "#MAKE#: `targ' is up to date.");
|
run_make_test(undef, '', "#MAKE#: 'targ' is up to date.");
|
||||||
run_make_test(undef, '-L', "#MAKE#: `targ' is up to date.");
|
run_make_test(undef, '-L', "#MAKE#: 'targ' is up to date.");
|
||||||
|
|
||||||
# Add in a new link between sym and dep. Be sure it's newer than targ.
|
# Add in a new link between sym and dep. Be sure it's newer than targ.
|
||||||
sleep(1);
|
sleep(1);
|
||||||
|
@ -46,7 +46,7 @@ if ($port_type eq 'W32' || !( eval { symlink("",""); 1 })) {
|
||||||
|
|
||||||
# Without -L, nothing should happen
|
# Without -L, nothing should happen
|
||||||
# With -L, it should update targ
|
# With -L, it should update targ
|
||||||
run_make_test(undef, '', "#MAKE#: `targ' is up to date.");
|
run_make_test(undef, '', "#MAKE#: 'targ' is up to date.");
|
||||||
run_make_test(undef, '-L', "make targ from sym");
|
run_make_test(undef, '-L', "make targ from sym");
|
||||||
|
|
||||||
rmfiles('targ', 'dep', 'sym', 'dep1');
|
rmfiles('targ', 'dep', 'sym', 'dep1');
|
||||||
|
@ -56,7 +56,7 @@ if ($port_type eq 'W32' || !( eval { symlink("",""); 1 })) {
|
||||||
|
|
||||||
symlink("../$dirname/dep", 'sym');
|
symlink("../$dirname/dep", 'sym');
|
||||||
run_make_test('targ: sym ; @echo make $@ from $<', '',
|
run_make_test('targ: sym ; @echo make $@ from $<', '',
|
||||||
"#MAKE#: *** No rule to make target `sym', needed by `targ'. Stop.", 512);
|
"#MAKE#: *** No rule to make target 'sym', needed by 'targ'. Stop.", 512);
|
||||||
|
|
||||||
run_make_test('targ: sym ; @echo make $@ from $<', '-L',
|
run_make_test('targ: sym ; @echo make $@ from $<', '-L',
|
||||||
'make targ from sym');
|
'make targ from sym');
|
||||||
|
|
|
@ -18,8 +18,8 @@ all: ; @echo ref $(EREF) $(UREF)',
|
||||||
|
|
||||||
# With --warn-undefined-variables, it should warn me
|
# With --warn-undefined-variables, it should warn me
|
||||||
run_make_test(undef, '--warn-undefined-variables',
|
run_make_test(undef, '--warn-undefined-variables',
|
||||||
"#MAKEFILE#:7: warning: undefined variable `UNDEFINED'
|
"#MAKEFILE#:7: warning: undefined variable 'UNDEFINED'
|
||||||
#MAKEFILE#:9: warning: undefined variable `UNDEFINED'
|
#MAKEFILE#:9: warning: undefined variable 'UNDEFINED'
|
||||||
ref");
|
ref");
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
|
@ -35,9 +35,9 @@ close(MAKEFILE);
|
||||||
&run_make_with_options($makefile,'bar',&get_logfile);
|
&run_make_with_options($makefile,'bar',&get_logfile);
|
||||||
|
|
||||||
# Create the answer to what should be produced by this Makefile
|
# Create the answer to what should be produced by this Makefile
|
||||||
$answer = "${make_name}[1]: Entering directory `$pwd'\n"
|
$answer = "${make_name}[1]: Entering directory '$pwd'\n"
|
||||||
. "Executing rule BAR\n"
|
. "Executing rule BAR\n"
|
||||||
. "${make_name}[1]: Leaving directory `$pwd'\n";
|
. "${make_name}[1]: Leaving directory '$pwd'\n";
|
||||||
|
|
||||||
# COMPARE RESULTS
|
# COMPARE RESULTS
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ $answer = "cp foo.f foo.e\ncp foo.e foo.d\nrm foo.e\n";
|
||||||
# TEST #1
|
# TEST #1
|
||||||
|
|
||||||
&run_make_with_options($makefile,'foo.d',&get_logfile);
|
&run_make_with_options($makefile,'foo.d',&get_logfile);
|
||||||
$answer = "$make_name: `foo.d' is up to date.\n";
|
$answer = "$make_name: 'foo.d' is up to date.\n";
|
||||||
&compare_output($answer, &get_logfile(1));
|
&compare_output($answer, &get_logfile(1));
|
||||||
|
|
||||||
# TEST #2
|
# TEST #2
|
||||||
|
@ -63,7 +63,7 @@ $answer = "cp foo.f foo.e\ncp bar.f bar.e\ncat foo.e bar.e > foo.c\nrm bar.e foo
|
||||||
# TEST #4
|
# TEST #4
|
||||||
|
|
||||||
&run_make_with_options($makefile,'foo.c',&get_logfile);
|
&run_make_with_options($makefile,'foo.c',&get_logfile);
|
||||||
$answer = "$make_name: `foo.c' is up to date.\n";
|
$answer = "$make_name: 'foo.c' is up to date.\n";
|
||||||
&compare_output($answer, &get_logfile(1));
|
&compare_output($answer, &get_logfile(1));
|
||||||
|
|
||||||
# TEST #5
|
# TEST #5
|
||||||
|
|
|
@ -17,7 +17,7 @@ run_make_test(qq!
|
||||||
.POSIX:
|
.POSIX:
|
||||||
all: ; \@$script
|
all: ; \@$script
|
||||||
!,
|
!,
|
||||||
'', "#MAKEFILE#:3: recipe for target `all' failed
|
'', "#MAKEFILE#:3: recipe for target 'all' failed
|
||||||
#MAKE#: *** [all] Error $err\n", 512);
|
#MAKE#: *** [all] Error $err\n", 512);
|
||||||
|
|
||||||
# User settings must override .POSIX
|
# User settings must override .POSIX
|
||||||
|
|
|
@ -44,7 +44,7 @@ $answer = "cp foo.f foo.e\ncp foo.e foo.d\n";
|
||||||
unlink('foo.e');
|
unlink('foo.e');
|
||||||
|
|
||||||
&run_make_with_options($makefile,'foo.d',&get_logfile);
|
&run_make_with_options($makefile,'foo.d',&get_logfile);
|
||||||
$answer = "$make_name: `foo.d' is up to date.\n";
|
$answer = "$make_name: 'foo.d' is up to date.\n";
|
||||||
&compare_output($answer, &get_logfile(1));
|
&compare_output($answer, &get_logfile(1));
|
||||||
|
|
||||||
# TEST #3
|
# TEST #3
|
||||||
|
@ -67,7 +67,7 @@ $answer = "cp foo.e foo.c\n";
|
||||||
unlink('foo.e');
|
unlink('foo.e');
|
||||||
|
|
||||||
&run_make_with_options($makefile,'foo.c',&get_logfile);
|
&run_make_with_options($makefile,'foo.c',&get_logfile);
|
||||||
$answer = "$make_name: `foo.c' is up to date.\n";
|
$answer = "$make_name: 'foo.c' is up to date.\n";
|
||||||
&compare_output($answer, &get_logfile(1));
|
&compare_output($answer, &get_logfile(1));
|
||||||
|
|
||||||
# TEST #6
|
# TEST #6
|
||||||
|
@ -103,7 +103,7 @@ close(MAKEFILE);
|
||||||
touch('final');
|
touch('final');
|
||||||
|
|
||||||
&run_make_with_options($makefile2, '', &get_logfile);
|
&run_make_with_options($makefile2, '', &get_logfile);
|
||||||
$answer = "$make_name: `final' is up to date.\n";
|
$answer = "$make_name: 'final' is up to date.\n";
|
||||||
&compare_output($answer, &get_logfile(1));
|
&compare_output($answer, &get_logfile(1));
|
||||||
|
|
||||||
unlink('source', 'final', 'intermediate');
|
unlink('source', 'final', 'intermediate');
|
||||||
|
|
|
@ -42,7 +42,7 @@ run_make_test('
|
||||||
.DEFAULT_GOAL = foo
|
.DEFAULT_GOAL = foo
|
||||||
',
|
',
|
||||||
'',
|
'',
|
||||||
'#MAKE#: *** No rule to make target `foo\'. Stop.',
|
"#MAKE#: *** No rule to make target 'foo'. Stop.",
|
||||||
512);
|
512);
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ run_make_test('
|
||||||
.LIBPATTERNS = mtest_foo.a mtest_%.a
|
.LIBPATTERNS = mtest_foo.a mtest_%.a
|
||||||
all: -lfoo ; @echo "build $@ from $<"
|
all: -lfoo ; @echo "build $@ from $<"
|
||||||
',
|
',
|
||||||
'', "#MAKE#: .LIBPATTERNS element `mtest_foo.a' is not a pattern
|
'', "#MAKE#: .LIBPATTERNS element 'mtest_foo.a' is not a pattern
|
||||||
build all from mtest_foo.a\n");
|
build all from mtest_foo.a\n");
|
||||||
|
|
||||||
# TEST 2: target-specific override
|
# TEST 2: target-specific override
|
||||||
|
|
|
@ -16,8 +16,8 @@ foo:
|
||||||
!,
|
!,
|
||||||
'',
|
'',
|
||||||
"#MAKEPATH#\n#MAKEPATH# -f #MAKEFILE# foo\n"
|
"#MAKEPATH#\n#MAKEPATH# -f #MAKEFILE# foo\n"
|
||||||
. "#MAKE#[1]: Entering directory `#PWD#'\n"
|
. "#MAKE#[1]: Entering directory '#PWD#'\n"
|
||||||
. "#MAKEPATH#\n#MAKE#[1]: Leaving directory `#PWD#'\n");
|
. "#MAKEPATH#\n#MAKE#[1]: Leaving directory '#PWD#'\n");
|
||||||
|
|
||||||
rmfiles("foo");
|
rmfiles("foo");
|
||||||
|
|
||||||
|
|
|
@ -53,9 +53,9 @@ foo.x:1: bar.x: No such file or directory
|
||||||
MAKE_RESTARTS=2
|
MAKE_RESTARTS=2
|
||||||
recurse MAKE_RESTARTS=
|
recurse MAKE_RESTARTS=
|
||||||
MAKE_RESTARTS=
|
MAKE_RESTARTS=
|
||||||
#MAKE#[1]: Entering directory `#PWD#'
|
#MAKE#[1]: Entering directory '#PWD#'
|
||||||
all MAKE_RESTARTS=
|
all MAKE_RESTARTS=
|
||||||
#MAKE#[1]: Leaving directory `#PWD#'");
|
#MAKE#[1]: Leaving directory '#PWD#'");
|
||||||
|
|
||||||
rmfiles('foo.x', 'bar.x');
|
rmfiles('foo.x', 'bar.x');
|
||||||
|
|
||||||
|
|
|
@ -89,7 +89,7 @@ run_make_test(qq!
|
||||||
.SHELLFLAGS = $flags
|
.SHELLFLAGS = $flags
|
||||||
all: ; \@$script
|
all: ; \@$script
|
||||||
!,
|
!,
|
||||||
'', "$out#MAKEFILE#:3: recipe for target `all' failed
|
'', "$out#MAKEFILE#:3: recipe for target 'all' failed
|
||||||
#MAKE#: *** [all] Error $err\n", 512);
|
#MAKE#: *** [all] Error $err\n", 512);
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
|
@ -160,7 +160,7 @@ ouch
|
||||||
endef
|
endef
|
||||||
all: ; @echo ok
|
all: ; @echo ok
|
||||||
',
|
',
|
||||||
'', "#MAKEFILE#:3: extraneous text after `define' directive\nok\n");
|
'', "#MAKEFILE#:3: extraneous text after 'define' directive\nok\n");
|
||||||
|
|
||||||
# TEST 7: NEGATIVE: extra text after endef
|
# TEST 7: NEGATIVE: extra text after endef
|
||||||
|
|
||||||
|
@ -171,7 +171,7 @@ ouch
|
||||||
endef $(NAME)
|
endef $(NAME)
|
||||||
all: ; @echo ok
|
all: ; @echo ok
|
||||||
',
|
',
|
||||||
'', "#MAKEFILE#:5: extraneous text after `endef' directive\nok\n");
|
'', "#MAKEFILE#:5: extraneous text after 'endef' directive\nok\n");
|
||||||
|
|
||||||
# TEST 8: NEGATIVE: missing endef
|
# TEST 8: NEGATIVE: missing endef
|
||||||
|
|
||||||
|
@ -182,7 +182,7 @@ define NAME =
|
||||||
ouch
|
ouch
|
||||||
endef$(NAME)
|
endef$(NAME)
|
||||||
',
|
',
|
||||||
'', "#MAKEFILE#:4: *** missing `endef', unterminated `define'. Stop.\n", 512);
|
'', "#MAKEFILE#:4: *** missing 'endef', unterminated 'define'. Stop.\n", 512);
|
||||||
|
|
||||||
# -------------------------
|
# -------------------------
|
||||||
# Make sure that prefix characters apply properly to define/endef values.
|
# Make sure that prefix characters apply properly to define/endef values.
|
||||||
|
|
|
@ -132,7 +132,7 @@ sub toplevel
|
||||||
|
|
||||||
&parse_command_line (@ARGV);
|
&parse_command_line (@ARGV);
|
||||||
|
|
||||||
print "OS name = `$osname'\n" if $debug;
|
print "OS name = '$osname'\n" if $debug;
|
||||||
|
|
||||||
$workpath = "$cwdslash$workdir";
|
$workpath = "$cwdslash$workdir";
|
||||||
$scriptpath = "$cwdslash$scriptdir";
|
$scriptpath = "$cwdslash$scriptdir";
|
||||||
|
|
18
variable.c
18
variable.c
|
@ -412,7 +412,7 @@ lookup_special_var (struct variable *var)
|
||||||
|
|
||||||
/* Lookup a variable whose name is a string starting at NAME
|
/* Lookup a variable whose name is a string starting at NAME
|
||||||
and with LENGTH chars. NAME need not be null-terminated.
|
and with LENGTH chars. NAME need not be null-terminated.
|
||||||
Returns address of the `struct variable' containing all info
|
Returns address of the 'struct variable' containing all info
|
||||||
on the variable, or nil if no such variable is defined. */
|
on the variable, or nil if no such variable is defined. */
|
||||||
|
|
||||||
struct variable *
|
struct variable *
|
||||||
|
@ -499,7 +499,7 @@ lookup_variable (const char *name, unsigned int length)
|
||||||
|
|
||||||
/* Lookup a variable whose name is a string starting at NAME
|
/* Lookup a variable whose name is a string starting at NAME
|
||||||
and with LENGTH chars in set SET. NAME need not be null-terminated.
|
and with LENGTH chars in set SET. NAME need not be null-terminated.
|
||||||
Returns address of the `struct variable' containing all info
|
Returns address of the 'struct variable' containing all info
|
||||||
on the variable, or nil if no such variable is defined. */
|
on the variable, or nil if no such variable is defined. */
|
||||||
|
|
||||||
struct variable *
|
struct variable *
|
||||||
|
@ -954,7 +954,7 @@ define_automatic_variables (void)
|
||||||
int export_all_variables;
|
int export_all_variables;
|
||||||
|
|
||||||
/* Create a new environment for FILE's commands.
|
/* Create a new environment for FILE's commands.
|
||||||
If FILE is nil, this is for the `shell' function.
|
If FILE is nil, this is for the 'shell' function.
|
||||||
The child's MAKELEVEL variable is incremented. */
|
The child's MAKELEVEL variable is incremented. */
|
||||||
|
|
||||||
char **
|
char **
|
||||||
|
@ -1250,7 +1250,7 @@ do_variable_definition (const struct floc *flocp, const char *varname,
|
||||||
#ifdef __MSDOS__
|
#ifdef __MSDOS__
|
||||||
/* Many Unix Makefiles include a line saying "SHELL=/bin/sh", but
|
/* Many Unix Makefiles include a line saying "SHELL=/bin/sh", but
|
||||||
non-Unix systems don't conform to this default configuration (in
|
non-Unix systems don't conform to this default configuration (in
|
||||||
fact, most of them don't even have `/bin'). On the other hand,
|
fact, most of them don't even have '/bin'). On the other hand,
|
||||||
$SHELL in the environment, if set, points to the real pathname of
|
$SHELL in the environment, if set, points to the real pathname of
|
||||||
the shell.
|
the shell.
|
||||||
Therefore, we generally won't let lines like "SHELL=/bin/sh" from
|
Therefore, we generally won't let lines like "SHELL=/bin/sh" from
|
||||||
|
@ -1536,7 +1536,7 @@ parse_variable_definition (const char *p, struct variable *var)
|
||||||
|
|
||||||
/* Try to interpret LINE (a null-terminated string) as a variable definition.
|
/* Try to interpret LINE (a null-terminated string) as a variable definition.
|
||||||
|
|
||||||
If LINE was recognized as a variable definition, a pointer to its `struct
|
If LINE was recognized as a variable definition, a pointer to its 'struct
|
||||||
variable' is returned. If LINE is not a variable definition, NULL is
|
variable' is returned. If LINE is not a variable definition, NULL is
|
||||||
returned. */
|
returned. */
|
||||||
|
|
||||||
|
@ -1569,7 +1569,7 @@ assign_variable_definition (struct variable *v, char *line)
|
||||||
|
|
||||||
See the comments for assign_variable_definition().
|
See the comments for assign_variable_definition().
|
||||||
|
|
||||||
If LINE was recognized as a variable definition, a pointer to its `struct
|
If LINE was recognized as a variable definition, a pointer to its 'struct
|
||||||
variable' is returned. If LINE is not a variable definition, NULL is
|
variable' is returned. If LINE is not a variable definition, NULL is
|
||||||
returned. */
|
returned. */
|
||||||
|
|
||||||
|
@ -1626,7 +1626,7 @@ print_variable (const void *item, void *arg)
|
||||||
origin = _("command line");
|
origin = _("command line");
|
||||||
break;
|
break;
|
||||||
case o_override:
|
case o_override:
|
||||||
origin = _("`override' directive");
|
origin = _("'override' directive");
|
||||||
break;
|
break;
|
||||||
case o_invalid:
|
case o_invalid:
|
||||||
default:
|
default:
|
||||||
|
@ -1637,12 +1637,12 @@ print_variable (const void *item, void *arg)
|
||||||
if (v->private_var)
|
if (v->private_var)
|
||||||
fputs (" private", stdout);
|
fputs (" private", stdout);
|
||||||
if (v->fileinfo.filenm)
|
if (v->fileinfo.filenm)
|
||||||
printf (_(" (from `%s', line %lu)"),
|
printf (_(" (from '%s', line %lu)"),
|
||||||
v->fileinfo.filenm, v->fileinfo.lineno);
|
v->fileinfo.filenm, v->fileinfo.lineno);
|
||||||
putchar ('\n');
|
putchar ('\n');
|
||||||
fputs (prefix, stdout);
|
fputs (prefix, stdout);
|
||||||
|
|
||||||
/* Is this a `define'? */
|
/* Is this a 'define'? */
|
||||||
if (v->recursive && strchr (v->value, '\n') != 0)
|
if (v->recursive && strchr (v->value, '\n') != 0)
|
||||||
printf ("define %s\n%s\nendef\n", v->name, v->value);
|
printf ("define %s\n%s\nendef\n", v->name, v->value);
|
||||||
else
|
else
|
||||||
|
|
|
@ -27,7 +27,7 @@ enum variable_origin
|
||||||
o_file, /* Variable given in a makefile. */
|
o_file, /* Variable given in a makefile. */
|
||||||
o_env_override, /* Variable from environment, if -e. */
|
o_env_override, /* Variable from environment, if -e. */
|
||||||
o_command, /* Variable given by user. */
|
o_command, /* Variable given by user. */
|
||||||
o_override, /* Variable from an `override' directive. */
|
o_override, /* Variable from an 'override' directive. */
|
||||||
o_automatic, /* Automatic variable -- cannot be set. */
|
o_automatic, /* Automatic variable -- cannot be set. */
|
||||||
o_invalid /* Core dump time. */
|
o_invalid /* Core dump time. */
|
||||||
};
|
};
|
||||||
|
@ -44,7 +44,7 @@ enum variable_flavor
|
||||||
|
|
||||||
/* Structure that represents one variable definition.
|
/* Structure that represents one variable definition.
|
||||||
Each bucket of the hash table is a chain of these,
|
Each bucket of the hash table is a chain of these,
|
||||||
chained through `next'. */
|
chained through 'next'. */
|
||||||
|
|
||||||
#define EXP_COUNT_BITS 15 /* This gets all the bitfields into 32 bits */
|
#define EXP_COUNT_BITS 15 /* This gets all the bitfields into 32 bits */
|
||||||
#define EXP_COUNT_MAX ((1<<EXP_COUNT_BITS)-1)
|
#define EXP_COUNT_MAX ((1<<EXP_COUNT_BITS)-1)
|
||||||
|
@ -223,7 +223,7 @@ void undefine_variable_in_set (const char *name, unsigned int length,
|
||||||
#define warn_undefined(n,l) do{\
|
#define warn_undefined(n,l) do{\
|
||||||
if (warn_undefined_variables_flag) \
|
if (warn_undefined_variables_flag) \
|
||||||
error (reading_file, \
|
error (reading_file, \
|
||||||
_("warning: undefined variable `%.*s'"), \
|
_("warning: undefined variable '%.*s'"), \
|
||||||
(int)(l), (n)); \
|
(int)(l), (n)); \
|
||||||
}while(0)
|
}while(0)
|
||||||
|
|
||||||
|
|
|
@ -181,7 +181,7 @@ vmsHandleChildTerm(struct child *child)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
error (NILF, _("internal error: `%s' command_state"),
|
error (NILF, _("internal error: '%s' command_state"),
|
||||||
c->file->name);
|
c->file->name);
|
||||||
abort ();
|
abort ();
|
||||||
break;
|
break;
|
||||||
|
|
14
vpath.c
14
vpath.c
|
@ -30,7 +30,7 @@ struct vpath
|
||||||
{
|
{
|
||||||
struct vpath *next; /* Pointer to next struct in the linked list. */
|
struct vpath *next; /* Pointer to next struct in the linked list. */
|
||||||
const char *pattern;/* The pattern to match. */
|
const char *pattern;/* The pattern to match. */
|
||||||
const char *percent;/* Pointer into `pattern' where the `%' is. */
|
const char *percent;/* Pointer into 'pattern' where the '%' is. */
|
||||||
unsigned int patlen;/* Length of the pattern. */
|
unsigned int patlen;/* Length of the pattern. */
|
||||||
const char **searchpath; /* Null-terminated list of directories. */
|
const char **searchpath; /* Null-terminated list of directories. */
|
||||||
unsigned int maxlen;/* Maximum length of any entry in the list. */
|
unsigned int maxlen;/* Maximum length of any entry in the list. */
|
||||||
|
@ -90,7 +90,7 @@ build_vpath_lists ()
|
||||||
struct vpath *save_vpaths = vpaths;
|
struct vpath *save_vpaths = vpaths;
|
||||||
char gp[] = "%";
|
char gp[] = "%";
|
||||||
|
|
||||||
/* Empty `vpaths' so the new one will have no next, and `vpaths'
|
/* Empty 'vpaths' so the new one will have no next, and 'vpaths'
|
||||||
will still be nil if P contains no existing directories. */
|
will still be nil if P contains no existing directories. */
|
||||||
vpaths = 0;
|
vpaths = 0;
|
||||||
|
|
||||||
|
@ -123,7 +123,7 @@ build_vpath_lists ()
|
||||||
struct vpath *save_vpaths = vpaths;
|
struct vpath *save_vpaths = vpaths;
|
||||||
char gp[] = "%";
|
char gp[] = "%";
|
||||||
|
|
||||||
/* Empty `vpaths' so the new one will have no next, and `vpaths'
|
/* Empty 'vpaths' so the new one will have no next, and 'vpaths'
|
||||||
will still be nil if P contains no existing directories. */
|
will still be nil if P contains no existing directories. */
|
||||||
vpaths = 0;
|
vpaths = 0;
|
||||||
|
|
||||||
|
@ -600,18 +600,18 @@ print_vpath_data_base (void)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vpaths == 0)
|
if (vpaths == 0)
|
||||||
puts (_("# No `vpath' search paths."));
|
puts (_("# No 'vpath' search paths."));
|
||||||
else
|
else
|
||||||
printf (_("\n# %u `vpath' search paths.\n"), nvpaths);
|
printf (_("\n# %u 'vpath' search paths.\n"), nvpaths);
|
||||||
|
|
||||||
if (general_vpath == 0)
|
if (general_vpath == 0)
|
||||||
puts (_("\n# No general (`VPATH' variable) search path."));
|
puts (_("\n# No general ('VPATH' variable) search path."));
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const char **path = general_vpath->searchpath;
|
const char **path = general_vpath->searchpath;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
fputs (_("\n# General (`VPATH' variable) search path:\n# "), stdout);
|
fputs (_("\n# General ('VPATH' variable) search path:\n# "), stdout);
|
||||||
|
|
||||||
for (i = 0; path[i] != 0; ++i)
|
for (i = 0; path[i] != 0; ++i)
|
||||||
printf ("%s%c", path[i],
|
printf ("%s%c", path[i],
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
# NOTE: If you have no `make' program at all to process this makefile, run
|
# NOTE: If you have no 'make' program at all to process this makefile, run
|
||||||
# `build.bat' instead.
|
# 'build.bat' instead.
|
||||||
#
|
#
|
||||||
# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
|
# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
|
||||||
# 2006, 2007, 2008, 2009, 2010, 2011, 2012 Free Software Foundation, Inc.
|
# 2006, 2007, 2008, 2009, 2010, 2011, 2012 Free Software Foundation, Inc.
|
||||||
|
|
|
@ -31,7 +31,7 @@ this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
const char *
|
const char *
|
||||||
map_windows32_error_to_string (DWORD ercode) {
|
map_windows32_error_to_string (DWORD ercode) {
|
||||||
/*
|
/*
|
||||||
* We used to have an MSVC-specific `__declspec (thread)' qualifier
|
* We used to have an MSVC-specific '__declspec (thread)' qualifier
|
||||||
* here, with the following comment:
|
* here, with the following comment:
|
||||||
*
|
*
|
||||||
* __declspec (thread) necessary if you will use multiple threads on MSVC
|
* __declspec (thread) necessary if you will use multiple threads on MSVC
|
||||||
|
@ -43,7 +43,7 @@ map_windows32_error_to_string (DWORD ercode) {
|
||||||
* never used, and are now #ifdef'ed away. Until we need more than
|
* never used, and are now #ifdef'ed away. Until we need more than
|
||||||
* one thread, we have no problems with the following buffer being
|
* one thread, we have no problems with the following buffer being
|
||||||
* static. (If and when we do need it to be in thread-local storage,
|
* static. (If and when we do need it to be in thread-local storage,
|
||||||
* the corresponding GCC qualifier is `__thread'.)
|
* the corresponding GCC qualifier is '__thread'.)
|
||||||
*/
|
*/
|
||||||
static char szMessageBuffer[128];
|
static char szMessageBuffer[128];
|
||||||
/* Fill message buffer with a default message in
|
/* Fill message buffer with a default message in
|
||||||
|
|
Loading…
Reference in a new issue