Update to bmake-20140620
Main change is detection of malformed variable references. Reviewed by: obrien
This commit is contained in:
commit
5bcb74248e
@ -1,3 +1,28 @@
|
|||||||
|
2014-06-20 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* Makefile (MAKE_VERSION): 20140620
|
||||||
|
Merge with NetBSD make, pick up
|
||||||
|
o var.c return varNoError rather than var_Error for ::= modidiers.
|
||||||
|
|
||||||
|
2014-05-22 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* Makefile (MAKE_VERSION): 20140522
|
||||||
|
Merge with NetBSD make, pick up
|
||||||
|
o var.c detect some parse errors.
|
||||||
|
|
||||||
|
2014-04-05 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* Fix spelling errors - patch from Pedro Giffuni
|
||||||
|
|
||||||
|
2014-02-14 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* Makefile (MAKE_VERSION): 20140214
|
||||||
|
Merge with NetBSD make, pick up
|
||||||
|
o .INCLUDEFROM*
|
||||||
|
o use Var_Value to get MAKEOBJDIR[PREFIX]
|
||||||
|
o reduced realloc'ign in brk_string.
|
||||||
|
* configure.in: add a check for compiler supporting __func__
|
||||||
|
|
||||||
2014-01-03 Simon J. Gerraty <sjg@bad.crufty.net>
|
2014-01-03 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
* boot-strap: ignore mksrc=none
|
* boot-strap: ignore mksrc=none
|
||||||
@ -64,7 +89,7 @@
|
|||||||
|
|
||||||
* Makefile (MAKE_VERSION): 20130716
|
* Makefile (MAKE_VERSION): 20130716
|
||||||
Merge with NetBSD make, pick up
|
Merge with NetBSD make, pick up
|
||||||
o number of gmake compatability tweaks
|
o number of gmake compatibility tweaks
|
||||||
-w for gmake style entering/leaving messages
|
-w for gmake style entering/leaving messages
|
||||||
if .MAKE.LEVEL > 0 indicate it in progname "make[1]" etc.
|
if .MAKE.LEVEL > 0 indicate it in progname "make[1]" etc.
|
||||||
handle MAKEFLAGS containing only letters.
|
handle MAKEFLAGS containing only letters.
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# $Id: Makefile,v 1.23 2014/01/02 22:20:52 sjg Exp $
|
# $Id: Makefile,v 1.27 2014/06/20 14:51:54 sjg Exp $
|
||||||
|
|
||||||
# Base version on src date
|
# Base version on src date
|
||||||
MAKE_VERSION= 20140101
|
MAKE_VERSION= 20140620
|
||||||
|
|
||||||
PROG= bmake
|
PROG= bmake
|
||||||
|
|
||||||
@ -117,7 +117,7 @@ MANTARGET?= man
|
|||||||
# turn this on by default - ignored if we are root
|
# turn this on by default - ignored if we are root
|
||||||
WITH_INSTALL_AS_USER=
|
WITH_INSTALL_AS_USER=
|
||||||
|
|
||||||
# supress with -DWITHOUT_*
|
# suppress with -DWITHOUT_*
|
||||||
OPTIONS_DEFAULT_YES+= \
|
OPTIONS_DEFAULT_YES+= \
|
||||||
AUTOCONF_MK \
|
AUTOCONF_MK \
|
||||||
INSTALL_MK \
|
INSTALL_MK \
|
||||||
|
@ -18,7 +18,7 @@ interesting changes, so that bmake tracks it very closely.
|
|||||||
|
|
||||||
Building:
|
Building:
|
||||||
|
|
||||||
The prefered way to bootstrap bmake is:
|
The preferred way to bootstrap bmake is:
|
||||||
|
|
||||||
./bmake/boot-strap
|
./bmake/boot-strap
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: make.1,v 1.226 2013/11/07 18:50:46 dholland Exp $
|
.\" $NetBSD: make.1,v 1.229 2014/01/19 10:23:29 apb Exp $
|
||||||
.\"
|
.\"
|
||||||
.\" Copyright (c) 1990, 1993
|
.\" Copyright (c) 1990, 1993
|
||||||
.\" The Regents of the University of California. All rights reserved.
|
.\" The Regents of the University of California. All rights reserved.
|
||||||
@ -29,7 +29,7 @@
|
|||||||
.\"
|
.\"
|
||||||
.\" from: @(#)make.1 8.4 (Berkeley) 3/19/94
|
.\" from: @(#)make.1 8.4 (Berkeley) 3/19/94
|
||||||
.\"
|
.\"
|
||||||
.Dd October 25, 2013
|
.Dd February 14, 2014
|
||||||
.Dt MAKE 1
|
.Dt MAKE 1
|
||||||
.Os
|
.Os
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
@ -706,6 +706,10 @@ was executed.
|
|||||||
Refer to the description of
|
Refer to the description of
|
||||||
.Ql Ev PWD
|
.Ql Ev PWD
|
||||||
for more details.
|
for more details.
|
||||||
|
.It Va .INCLUDEDFROMDIR
|
||||||
|
The directory of the file this Makefile was included from.
|
||||||
|
.It Va .INCLUDEDFROMFILE
|
||||||
|
The filename of the file this Makefile was included from.
|
||||||
.It Ev MAKE
|
.It Ev MAKE
|
||||||
The name that
|
The name that
|
||||||
.Nm
|
.Nm
|
||||||
@ -1246,6 +1250,15 @@ and
|
|||||||
are orthogonal; the former specifies whether multiple words are
|
are orthogonal; the former specifies whether multiple words are
|
||||||
potentially affected, the latter whether multiple substitutions can
|
potentially affected, the latter whether multiple substitutions can
|
||||||
potentially occur within each affected word.
|
potentially occur within each affected word.
|
||||||
|
.Pp
|
||||||
|
As for the
|
||||||
|
.Cm \&:S
|
||||||
|
modifier, the
|
||||||
|
.Ar pattern
|
||||||
|
and
|
||||||
|
.Ar replacement
|
||||||
|
are subjected to variable expansion before being parsed as
|
||||||
|
regular expressions.
|
||||||
.It Cm \&:T
|
.It Cm \&:T
|
||||||
Replaces each word in the variable with its last component.
|
Replaces each word in the variable with its last component.
|
||||||
.It Cm \&:u
|
.It Cm \&:u
|
||||||
|
@ -450,6 +450,13 @@ VVAARRIIAABBLLEE AASSSSIIGGNNMMEENNTTSS
|
|||||||
_._C_U_R_D_I_R A path to the directory where bbmmaakkee was executed. Refer
|
_._C_U_R_D_I_R A path to the directory where bbmmaakkee was executed. Refer
|
||||||
to the description of `PWD' for more details.
|
to the description of `PWD' for more details.
|
||||||
|
|
||||||
|
_._I_N_C_L_U_D_E_D_F_R_O_M_D_I_R
|
||||||
|
The directory of the file this Makefile was included
|
||||||
|
from.
|
||||||
|
|
||||||
|
_._I_N_C_L_U_D_E_D_F_R_O_M_F_I_L_E
|
||||||
|
The filename of the file this Makefile was included from.
|
||||||
|
|
||||||
MAKE The name that bbmmaakkee was executed with (_a_r_g_v_[_0_]). For
|
MAKE The name that bbmmaakkee was executed with (_a_r_g_v_[_0_]). For
|
||||||
compatibility bbmmaakkee also sets _._M_A_K_E with the same value.
|
compatibility bbmmaakkee also sets _._M_A_K_E with the same value.
|
||||||
The preferred variable to use is the environment variable
|
The preferred variable to use is the environment variable
|
||||||
@ -796,6 +803,9 @@ VVAARRIIAABBLLEE AASSSSIIGGNNMMEENNTTSS
|
|||||||
multiple words are potentially affected, the latter whether multiple
|
multiple words are potentially affected, the latter whether multiple
|
||||||
substitutions can potentially occur within each affected word.
|
substitutions can potentially occur within each affected word.
|
||||||
|
|
||||||
|
As for the ::SS modifier, the _p_a_t_t_e_r_n and _r_e_p_l_a_c_e_m_e_n_t are subjected to
|
||||||
|
variable expansion before being parsed as regular expressions.
|
||||||
|
|
||||||
::TT Replaces each word in the variable with its last component.
|
::TT Replaces each word in the variable with its last component.
|
||||||
|
|
||||||
::uu Remove adjacent duplicate words (like uniq(1)).
|
::uu Remove adjacent duplicate words (like uniq(1)).
|
||||||
@ -1384,4 +1394,4 @@ BBUUGGSS
|
|||||||
|
|
||||||
There is no way of escaping a space character in a filename.
|
There is no way of escaping a space character in a filename.
|
||||||
|
|
||||||
NetBSD 5.1 October 25, 2013 NetBSD 5.1
|
NetBSD 5.1 February 14, 2014 NetBSD 5.1
|
||||||
|
@ -111,7 +111,7 @@
|
|||||||
# Simon J. Gerraty <sjg@crufty.net>
|
# Simon J. Gerraty <sjg@crufty.net>
|
||||||
|
|
||||||
# RCSid:
|
# RCSid:
|
||||||
# $Id: boot-strap,v 1.44 2014/01/08 14:49:10 sjg Exp $
|
# $Id: boot-strap,v 1.45 2014/04/05 22:56:54 sjg Exp $
|
||||||
#
|
#
|
||||||
# @(#) Copyright (c) 2001 Simon J. Gerraty
|
# @(#) Copyright (c) 2001 Simon J. Gerraty
|
||||||
#
|
#
|
||||||
@ -197,7 +197,7 @@ get_optarg() {
|
|||||||
|
|
||||||
here=`'pwd'`
|
here=`'pwd'`
|
||||||
if [ $here = $Mydir ]; then
|
if [ $here = $Mydir ]; then
|
||||||
# avoid polution
|
# avoid pollution
|
||||||
OBJROOT=../
|
OBJROOT=../
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -453,7 +453,7 @@ op_all() {
|
|||||||
echo "Use --install-destdir=/somewhere to set DESTDIR during install"
|
echo "Use --install-destdir=/somewhere to set DESTDIR during install"
|
||||||
echo "Use --install-host-target to use INSTALL_BIN=$HOST_TARGET/bin"
|
echo "Use --install-host-target to use INSTALL_BIN=$HOST_TARGET/bin"
|
||||||
echo "Use -DWITH_PROG_VERSION to install as bmake-$MAKE_VERSION"
|
echo "Use -DWITH_PROG_VERSION to install as bmake-$MAKE_VERSION"
|
||||||
echo "Use -DWITHOUT_PROG_LINK to supress bmake -> bmake-$MAKE_VERSION symlink"
|
echo "Use -DWITHOUT_PROG_LINK to suppress bmake -> bmake-$MAKE_VERSION symlink"
|
||||||
echo "Use -DWITHOUT_INSTALL_MK to skip installing files to $prefix/share/mk"
|
echo "Use -DWITHOUT_INSTALL_MK to skip installing files to $prefix/share/mk"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $Id: bsd.after-import.mk,v 1.11 2012/12/29 19:32:25 sjg Exp $
|
# $Id: bsd.after-import.mk,v 1.12 2014/02/14 23:45:49 sjg Exp $
|
||||||
|
|
||||||
# This makefile is for use when integrating bmake into a BSD build
|
# This makefile is for use when integrating bmake into a BSD build
|
||||||
# system. Use this makefile after importing bmake.
|
# system. Use this makefile after importing bmake.
|
||||||
@ -41,15 +41,13 @@ SRCTOP := ${srctop}
|
|||||||
HOST_OS!= uname
|
HOST_OS!= uname
|
||||||
.endif
|
.endif
|
||||||
|
|
||||||
# .../share/mk will find ${SRCTOP}/share/mk
|
|
||||||
# if we are within ${SRCTOP}
|
|
||||||
DEFAULT_SYS_PATH= .../share/mk:/usr/share/mk
|
|
||||||
|
|
||||||
BOOTSTRAP_ARGS = \
|
BOOTSTRAP_ARGS = \
|
||||||
--with-default-sys-path='${DEFAULT_SYS_PATH}' \
|
|
||||||
--prefix /usr \
|
--prefix /usr \
|
||||||
--share /usr/share
|
--share /usr/share
|
||||||
|
|
||||||
|
.if !empty(DEFAULT_SYS_PATH)
|
||||||
|
BOOTSTRAP_ARGS += --with-default-sys-path='${DEFAULT_SYS_PATH}'
|
||||||
|
.endif
|
||||||
|
|
||||||
# run boot-strap with minimal influence
|
# run boot-strap with minimal influence
|
||||||
bootstrap: ${BMAKE_SRC}/boot-strap ${MAKEFILE}
|
bootstrap: ${BMAKE_SRC}/boot-strap ${MAKEFILE}
|
||||||
|
@ -144,6 +144,9 @@
|
|||||||
`HAVE_STRUCT_STAT_ST_RDEV' instead. */
|
`HAVE_STRUCT_STAT_ST_RDEV' instead. */
|
||||||
#undef HAVE_ST_RDEV
|
#undef HAVE_ST_RDEV
|
||||||
|
|
||||||
|
/* Define to 1 if you have the `sysctl' function. */
|
||||||
|
#undef HAVE_SYSCTL
|
||||||
|
|
||||||
/* 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
|
||||||
@ -164,6 +167,9 @@
|
|||||||
/* Define to 1 if you have the <sys/stat.h> header file. */
|
/* Define to 1 if you have the <sys/stat.h> header file. */
|
||||||
#undef HAVE_SYS_STAT_H
|
#undef HAVE_SYS_STAT_H
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <sys/sysctl.h> header file. */
|
||||||
|
#undef HAVE_SYS_SYSCTL_H
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/time.h> header file. */
|
/* Define to 1 if you have the <sys/time.h> header file. */
|
||||||
#undef HAVE_SYS_TIME_H
|
#undef HAVE_SYS_TIME_H
|
||||||
|
|
||||||
@ -298,6 +304,9 @@
|
|||||||
/* 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
|
||||||
|
|
||||||
|
/* C99 function name */
|
||||||
|
#undef __func__
|
||||||
|
|
||||||
/* 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
|
||||||
|
|
||||||
|
44
contrib/bmake/configure
vendored
44
contrib/bmake/configure
vendored
@ -1,6 +1,6 @@
|
|||||||
#! /bin/sh
|
#! /bin/sh
|
||||||
# Guess values for system-dependent variables and create Makefiles.
|
# Guess values for system-dependent variables and create Makefiles.
|
||||||
# Generated by GNU Autoconf 2.64 for bmake 20140101.
|
# Generated by GNU Autoconf 2.64 for bmake 20140214.
|
||||||
#
|
#
|
||||||
# Report bugs to <sjg@NetBSD.org>.
|
# Report bugs to <sjg@NetBSD.org>.
|
||||||
#
|
#
|
||||||
@ -549,8 +549,8 @@ MAKEFLAGS=
|
|||||||
# Identity of this package.
|
# Identity of this package.
|
||||||
PACKAGE_NAME='bmake'
|
PACKAGE_NAME='bmake'
|
||||||
PACKAGE_TARNAME='bmake'
|
PACKAGE_TARNAME='bmake'
|
||||||
PACKAGE_VERSION='20140101'
|
PACKAGE_VERSION='20140214'
|
||||||
PACKAGE_STRING='bmake 20140101'
|
PACKAGE_STRING='bmake 20140214'
|
||||||
PACKAGE_BUGREPORT='sjg@NetBSD.org'
|
PACKAGE_BUGREPORT='sjg@NetBSD.org'
|
||||||
PACKAGE_URL=''
|
PACKAGE_URL=''
|
||||||
|
|
||||||
@ -1221,7 +1221,7 @@ if test "$ac_init_help" = "long"; then
|
|||||||
# Omit some internal or obsolete options to make the list less imposing.
|
# Omit some internal or obsolete options to make the list less imposing.
|
||||||
# This message is too long to be a string in the A/UX 3.1 sh.
|
# This message is too long to be a string in the A/UX 3.1 sh.
|
||||||
cat <<_ACEOF
|
cat <<_ACEOF
|
||||||
\`configure' configures bmake 20140101 to adapt to many kinds of systems.
|
\`configure' configures bmake 20140214 to adapt to many kinds of systems.
|
||||||
|
|
||||||
Usage: $0 [OPTION]... [VAR=VALUE]...
|
Usage: $0 [OPTION]... [VAR=VALUE]...
|
||||||
|
|
||||||
@ -1282,7 +1282,7 @@ fi
|
|||||||
|
|
||||||
if test -n "$ac_init_help"; then
|
if test -n "$ac_init_help"; then
|
||||||
case $ac_init_help in
|
case $ac_init_help in
|
||||||
short | recursive ) echo "Configuration of bmake 20140101:";;
|
short | recursive ) echo "Configuration of bmake 20140214:";;
|
||||||
esac
|
esac
|
||||||
cat <<\_ACEOF
|
cat <<\_ACEOF
|
||||||
|
|
||||||
@ -1387,7 +1387,7 @@ fi
|
|||||||
test -n "$ac_init_help" && exit $ac_status
|
test -n "$ac_init_help" && exit $ac_status
|
||||||
if $ac_init_version; then
|
if $ac_init_version; then
|
||||||
cat <<\_ACEOF
|
cat <<\_ACEOF
|
||||||
bmake configure 20140101
|
bmake configure 20140214
|
||||||
generated by GNU Autoconf 2.64
|
generated by GNU Autoconf 2.64
|
||||||
|
|
||||||
Copyright (C) 2009 Free Software Foundation, Inc.
|
Copyright (C) 2009 Free Software Foundation, Inc.
|
||||||
@ -1908,7 +1908,7 @@ cat >config.log <<_ACEOF
|
|||||||
This file contains any messages produced by compilers while
|
This file contains any messages produced by compilers while
|
||||||
running configure, to aid debugging if configure makes a mistake.
|
running configure, to aid debugging if configure makes a mistake.
|
||||||
|
|
||||||
It was created by bmake $as_me 20140101, which was
|
It was created by bmake $as_me 20140214, which was
|
||||||
generated by GNU Autoconf 2.64. Invocation command line was
|
generated by GNU Autoconf 2.64. Invocation command line was
|
||||||
|
|
||||||
$ $0 $@
|
$ $0 $@
|
||||||
@ -5708,6 +5708,32 @@ $as_echo "#define HAVE_ST_RDEV 1" >>confdefs.h
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
echo "checking if compiler supports __func__" >&6
|
||||||
|
ac_ext=c
|
||||||
|
ac_cpp='$CPP $CPPFLAGS'
|
||||||
|
ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
|
||||||
|
ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
|
||||||
|
ac_compiler_gnu=$ac_cv_c_compiler_gnu
|
||||||
|
|
||||||
|
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
||||||
|
/* end confdefs.h. */
|
||||||
|
|
||||||
|
int
|
||||||
|
main ()
|
||||||
|
{
|
||||||
|
const char *func = __func__;
|
||||||
|
;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
_ACEOF
|
||||||
|
if ac_fn_c_try_compile "$LINENO"; then :
|
||||||
|
|
||||||
|
else
|
||||||
|
|
||||||
|
$as_echo "#define __func__ __FUNCTION__" >>confdefs.h
|
||||||
|
|
||||||
|
fi
|
||||||
|
rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
|
||||||
echo $ECHO_N "checking if diff -u works... $ECHO_C" >&6
|
echo $ECHO_N "checking if diff -u works... $ECHO_C" >&6
|
||||||
if diff -u /dev/null /dev/null > /dev/null 2>&1; then
|
if diff -u /dev/null /dev/null > /dev/null 2>&1; then
|
||||||
diff_u=-u
|
diff_u=-u
|
||||||
@ -6378,7 +6404,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
|
|||||||
# report actual input values of CONFIG_FILES etc. instead of their
|
# report actual input values of CONFIG_FILES etc. instead of their
|
||||||
# values after options handling.
|
# values after options handling.
|
||||||
ac_log="
|
ac_log="
|
||||||
This file was extended by bmake $as_me 20140101, which was
|
This file was extended by bmake $as_me 20140214, which was
|
||||||
generated by GNU Autoconf 2.64. Invocation command line was
|
generated by GNU Autoconf 2.64. Invocation command line was
|
||||||
|
|
||||||
CONFIG_FILES = $CONFIG_FILES
|
CONFIG_FILES = $CONFIG_FILES
|
||||||
@ -6438,7 +6464,7 @@ Report bugs to <sjg@NetBSD.org>."
|
|||||||
_ACEOF
|
_ACEOF
|
||||||
cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
|
cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
|
||||||
ac_cs_version="\\
|
ac_cs_version="\\
|
||||||
bmake config.status 20140101
|
bmake config.status 20140214
|
||||||
configured by $0, generated by GNU Autoconf 2.64,
|
configured by $0, generated by GNU Autoconf 2.64,
|
||||||
with options \\"`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`\\"
|
with options \\"`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`\\"
|
||||||
|
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
dnl
|
dnl
|
||||||
dnl RCSid:
|
dnl RCSid:
|
||||||
dnl $Id: configure.in,v 1.51 2014/01/02 22:20:52 sjg Exp $
|
dnl $Id: configure.in,v 1.52 2014/02/15 22:27:59 sjg Exp $
|
||||||
dnl
|
dnl
|
||||||
dnl Process this file with autoconf to produce a configure script
|
dnl Process this file with autoconf to produce a configure script
|
||||||
dnl
|
dnl
|
||||||
AC_PREREQ(2.50)
|
AC_PREREQ(2.50)
|
||||||
AC_INIT([bmake], [20140101], [sjg@NetBSD.org])
|
AC_INIT([bmake], [20140214], [sjg@NetBSD.org])
|
||||||
AC_CONFIG_HEADER(config.h)
|
AC_CONFIG_HEADERS(config.h)
|
||||||
|
|
||||||
dnl make srcdir absolute
|
dnl make srcdir absolute
|
||||||
case "$srcdir" in
|
case "$srcdir" in
|
||||||
@ -203,6 +203,11 @@ dnl
|
|||||||
AC_HEADER_STAT
|
AC_HEADER_STAT
|
||||||
AC_STRUCT_ST_RDEV
|
AC_STRUCT_ST_RDEV
|
||||||
dnl
|
dnl
|
||||||
|
echo "checking if compiler supports __func__" >&6
|
||||||
|
AC_LANG(C)
|
||||||
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([],[[const char *func = __func__;]])],,
|
||||||
|
AC_DEFINE(__func__, __FUNCTION__, C99 function name))
|
||||||
|
dnl
|
||||||
dnl we want this for unit-tests/Makefile
|
dnl we want this for unit-tests/Makefile
|
||||||
echo $ECHO_N "checking if diff -u works... $ECHO_C" >&6
|
echo $ECHO_N "checking if diff -u works... $ECHO_C" >&6
|
||||||
if diff -u /dev/null /dev/null > /dev/null 2>&1; then
|
if diff -u /dev/null /dev/null > /dev/null 2>&1; then
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: main.c,v 1.225 2013/09/14 15:09:34 matt Exp $ */
|
/* $NetBSD: main.c,v 1.226 2014/02/07 17:23:35 pooka Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1988, 1989, 1990, 1993
|
* Copyright (c) 1988, 1989, 1990, 1993
|
||||||
@ -69,7 +69,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef MAKE_NATIVE
|
#ifndef MAKE_NATIVE
|
||||||
static char rcsid[] = "$NetBSD: main.c,v 1.225 2013/09/14 15:09:34 matt Exp $";
|
static char rcsid[] = "$NetBSD: main.c,v 1.226 2014/02/07 17:23:35 pooka Exp $";
|
||||||
#else
|
#else
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
#ifndef lint
|
#ifndef lint
|
||||||
@ -81,7 +81,7 @@ __COPYRIGHT("@(#) Copyright (c) 1988, 1989, 1990, 1993\
|
|||||||
#if 0
|
#if 0
|
||||||
static char sccsid[] = "@(#)main.c 8.3 (Berkeley) 3/19/94";
|
static char sccsid[] = "@(#)main.c 8.3 (Berkeley) 3/19/94";
|
||||||
#else
|
#else
|
||||||
__RCSID("$NetBSD: main.c,v 1.225 2013/09/14 15:09:34 matt Exp $");
|
__RCSID("$NetBSD: main.c,v 1.226 2014/02/07 17:23:35 pooka Exp $");
|
||||||
#endif
|
#endif
|
||||||
#endif /* not lint */
|
#endif /* not lint */
|
||||||
#endif
|
#endif
|
||||||
@ -1102,11 +1102,12 @@ main(int argc, char **argv)
|
|||||||
*/
|
*/
|
||||||
#ifndef NO_PWD_OVERRIDE
|
#ifndef NO_PWD_OVERRIDE
|
||||||
if (!ignorePWD) {
|
if (!ignorePWD) {
|
||||||
char *pwd;
|
char *pwd, *ptmp1 = NULL, *ptmp2 = NULL;
|
||||||
|
|
||||||
if ((pwd = getenv("PWD")) != NULL &&
|
if ((pwd = getenv("PWD")) != NULL &&
|
||||||
getenv("MAKEOBJDIRPREFIX") == NULL) {
|
Var_Value("MAKEOBJDIRPREFIX", VAR_CMD, &ptmp1) == NULL) {
|
||||||
const char *makeobjdir = getenv("MAKEOBJDIR");
|
const char *makeobjdir = Var_Value("MAKEOBJDIR",
|
||||||
|
VAR_CMD, &ptmp2);
|
||||||
|
|
||||||
if (makeobjdir == NULL || !strchr(makeobjdir, '$')) {
|
if (makeobjdir == NULL || !strchr(makeobjdir, '$')) {
|
||||||
if (stat(pwd, &sb) == 0 &&
|
if (stat(pwd, &sb) == 0 &&
|
||||||
@ -1115,6 +1116,8 @@ main(int argc, char **argv)
|
|||||||
(void)strncpy(curdir, pwd, MAXPATHLEN);
|
(void)strncpy(curdir, pwd, MAXPATHLEN);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
free(ptmp1);
|
||||||
|
free(ptmp2);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
Var_Set(".CURDIR", curdir, VAR_GLOBAL, 0);
|
Var_Set(".CURDIR", curdir, VAR_GLOBAL, 0);
|
||||||
@ -1131,11 +1134,13 @@ main(int argc, char **argv)
|
|||||||
Dir_Init(curdir);
|
Dir_Init(curdir);
|
||||||
(void)Main_SetObjdir(curdir);
|
(void)Main_SetObjdir(curdir);
|
||||||
|
|
||||||
if ((path = getenv("MAKEOBJDIRPREFIX")) != NULL) {
|
if ((path = Var_Value("MAKEOBJDIRPREFIX", VAR_CMD, &p1)) != NULL) {
|
||||||
(void)snprintf(mdpath, MAXPATHLEN, "%s%s", path, curdir);
|
(void)snprintf(mdpath, MAXPATHLEN, "%s%s", path, curdir);
|
||||||
(void)Main_SetObjdir(mdpath);
|
(void)Main_SetObjdir(mdpath);
|
||||||
} else if ((path = getenv("MAKEOBJDIR")) != NULL) {
|
free(p1);
|
||||||
|
} else if ((path = Var_Value("MAKEOBJDIR", VAR_CMD, &p1)) != NULL) {
|
||||||
(void)Main_SetObjdir(path);
|
(void)Main_SetObjdir(path);
|
||||||
|
free(p1);
|
||||||
} else {
|
} else {
|
||||||
(void)snprintf(mdpath, MAXPATHLEN, "%s.%s", _PATH_OBJDIR, machine);
|
(void)snprintf(mdpath, MAXPATHLEN, "%s.%s", _PATH_OBJDIR, machine);
|
||||||
if (!Main_SetObjdir(mdpath) && !Main_SetObjdir(_PATH_OBJDIR)) {
|
if (!Main_SetObjdir(mdpath) && !Main_SetObjdir(_PATH_OBJDIR)) {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: make.1,v 1.226 2013/11/07 18:50:46 dholland Exp $
|
.\" $NetBSD: make.1,v 1.230 2014/02/15 18:55:30 sjg Exp $
|
||||||
.\"
|
.\"
|
||||||
.\" Copyright (c) 1990, 1993
|
.\" Copyright (c) 1990, 1993
|
||||||
.\" The Regents of the University of California. All rights reserved.
|
.\" The Regents of the University of California. All rights reserved.
|
||||||
@ -29,7 +29,7 @@
|
|||||||
.\"
|
.\"
|
||||||
.\" from: @(#)make.1 8.4 (Berkeley) 3/19/94
|
.\" from: @(#)make.1 8.4 (Berkeley) 3/19/94
|
||||||
.\"
|
.\"
|
||||||
.Dd October 25, 2013
|
.Dd February 14, 2014
|
||||||
.Dt MAKE 1
|
.Dt MAKE 1
|
||||||
.Os
|
.Os
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
@ -706,6 +706,10 @@ was executed.
|
|||||||
Refer to the description of
|
Refer to the description of
|
||||||
.Ql Ev PWD
|
.Ql Ev PWD
|
||||||
for more details.
|
for more details.
|
||||||
|
.It Va .INCLUDEDFROMDIR
|
||||||
|
The directory of the file this Makefile was included from.
|
||||||
|
.It Va .INCLUDEDFROMFILE
|
||||||
|
The filename of the file this Makefile was included from.
|
||||||
.It Ev MAKE
|
.It Ev MAKE
|
||||||
The name that
|
The name that
|
||||||
.Nm
|
.Nm
|
||||||
@ -1257,6 +1261,15 @@ and
|
|||||||
are orthogonal; the former specifies whether multiple words are
|
are orthogonal; the former specifies whether multiple words are
|
||||||
potentially affected, the latter whether multiple substitutions can
|
potentially affected, the latter whether multiple substitutions can
|
||||||
potentially occur within each affected word.
|
potentially occur within each affected word.
|
||||||
|
.Pp
|
||||||
|
As for the
|
||||||
|
.Cm \&:S
|
||||||
|
modifier, the
|
||||||
|
.Ar pattern
|
||||||
|
and
|
||||||
|
.Ar replacement
|
||||||
|
are subjected to variable expansion before being parsed as
|
||||||
|
regular expressions.
|
||||||
.It Cm \&:T
|
.It Cm \&:T
|
||||||
Replaces each word in the variable with its last component.
|
Replaces each word in the variable with its last component.
|
||||||
.It Cm \&:u
|
.It Cm \&:u
|
||||||
|
@ -1,3 +1,60 @@
|
|||||||
|
2014-05-22 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* install-mk (MK_VERSION): 20140522
|
||||||
|
|
||||||
|
* lib.mk: use CC to link shlib for linux too
|
||||||
|
patch from Brendan MacDonell
|
||||||
|
|
||||||
|
2014-05-05 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* meta.autodep.mk: add _reldir_{finish,failed} for gathering stats
|
||||||
|
if WITH_META_STATS is defined.
|
||||||
|
|
||||||
|
2014-05-02 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* dirdeps.mk: accept -DWITHOUT_DIRDEPS (same a as -DNO_DIRDEPS)
|
||||||
|
to supress dirdeps outside of .CURDIR.
|
||||||
|
|
||||||
|
2014-04-05 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* Fix spelling errors - patch from Pedro Giffuni
|
||||||
|
|
||||||
|
2014-03-14 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* install-mk (MK_VERSION): 20140314
|
||||||
|
|
||||||
|
* dirdeps.mk (beforedirdeps): a handy hook
|
||||||
|
|
||||||
|
* dirdeps.mk (DIRDEP_MAKE): allow the actual command we run
|
||||||
|
to visit leaf dirs to be intercepted (eg. for distributed
|
||||||
|
build).
|
||||||
|
|
||||||
|
* dirdeps.mk (__depdirs): ensure // don't sneak in
|
||||||
|
|
||||||
|
* gendirdeps.mk (DIRDEPS): ensure // don't sneak in
|
||||||
|
|
||||||
|
|
||||||
|
2014-02-21 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* rst2htm.mk (RST2PDF): add support for rst2pdf
|
||||||
|
|
||||||
|
2014-02-14 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* install-mk (MK_VERSION): bump version
|
||||||
|
* dirdeps.mk (_last_dependfile): use .INCLUDEDFROMFILE if
|
||||||
|
available.
|
||||||
|
|
||||||
|
2014-02-10 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* options.mk: avoid :U so this isn't bmake dependent
|
||||||
|
|
||||||
|
2014-02-09 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
|
* options.mk: cleanup and simplify semanitcs
|
||||||
|
NO_* dominates all, if both WITH_* and WITHOUT_*
|
||||||
|
are defined then result is DOMINATE_* which defaults to "no".
|
||||||
|
Ie. WITHOUT_ normally wins.
|
||||||
|
|
||||||
2013-12-12 Simon J. Gerraty <sjg@bad.crufty.net>
|
2013-12-12 Simon J. Gerraty <sjg@bad.crufty.net>
|
||||||
|
|
||||||
* install-mk (MK_VERSION): bump version
|
* install-mk (MK_VERSION): bump version
|
||||||
@ -490,7 +547,7 @@
|
|||||||
* dep.mk: auto.dep.mk does not do 'make depend' so ignore it if
|
* dep.mk: auto.dep.mk does not do 'make depend' so ignore it if
|
||||||
asked to do that.
|
asked to do that.
|
||||||
fix/simplify the tests for when to run mkdep.
|
fix/simplify the tests for when to run mkdep.
|
||||||
* auto.dep.mk: add some explaination of how/what we do.
|
* auto.dep.mk: add some explanation of how/what we do.
|
||||||
* autodep.mk: skip the .OPTIONAL frobbing of .depend
|
* autodep.mk: skip the .OPTIONAL frobbing of .depend
|
||||||
bmake's FROM_DEPEND flag makes it redundant.
|
bmake's FROM_DEPEND flag makes it redundant.
|
||||||
|
|
||||||
@ -640,7 +697,7 @@
|
|||||||
2006-12-30 Simon J. Gerraty <sjg@void.crufty.net>
|
2006-12-30 Simon J. Gerraty <sjg@void.crufty.net>
|
||||||
|
|
||||||
* install-mk (MK_VERSION): bump version
|
* install-mk (MK_VERSION): bump version
|
||||||
* added libs.mk - analagous to progs.mk
|
* added libs.mk - analogous to progs.mk
|
||||||
make both of them always inlcude {lib,prog}.mk
|
make both of them always inlcude {lib,prog}.mk
|
||||||
|
|
||||||
2006-12-28 Simon J. Gerraty <sjg@void.crufty.net>
|
2006-12-28 Simon J. Gerraty <sjg@void.crufty.net>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#
|
#
|
||||||
# RCSid:
|
# RCSid:
|
||||||
# $Id: autodep.mk,v 1.32 2010/04/19 17:37:56 sjg Exp $
|
# $Id: autodep.mk,v 1.33 2014/04/05 22:56:54 sjg Exp $
|
||||||
#
|
#
|
||||||
# @(#) Copyright (c) 1999-2010, Simon J. Gerraty
|
# @(#) Copyright (c) 1999-2010, Simon J. Gerraty
|
||||||
#
|
#
|
||||||
@ -16,7 +16,7 @@
|
|||||||
|
|
||||||
# This module provides automagic dependency generation along the
|
# This module provides automagic dependency generation along the
|
||||||
# lines suggested in the GNU make.info
|
# lines suggested in the GNU make.info
|
||||||
# The depend target is mainly for backwards compatability,
|
# The depend target is mainly for backwards compatibility,
|
||||||
# dependencies are normally updated as part of compilation.
|
# dependencies are normally updated as part of compilation.
|
||||||
|
|
||||||
# set MKDEP=autodep and dep.mk will include us
|
# set MKDEP=autodep and dep.mk will include us
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $Id: dirdeps.mk,v 1.29 2013/10/13 18:43:53 sjg Exp $
|
# $Id: dirdeps.mk,v 1.35 2014/05/03 06:27:56 sjg Exp $
|
||||||
|
|
||||||
# Copyright (c) 2010-2013, Juniper Networks, Inc.
|
# Copyright (c) 2010-2013, Juniper Networks, Inc.
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
@ -44,7 +44,7 @@
|
|||||||
# All unqualified entries end up being qualified with .${TARGET_SPEC}
|
# All unqualified entries end up being qualified with .${TARGET_SPEC}
|
||||||
# and partially qualified (if TARGET_SPEC_VARS has multiple
|
# and partially qualified (if TARGET_SPEC_VARS has multiple
|
||||||
# entries) are also expanded to a full .<target_spec>.
|
# entries) are also expanded to a full .<target_spec>.
|
||||||
# The _DIRDEPS_USE target uses the suffix to set TARGET_SPEC
|
# The _DIRDEP_USE target uses the suffix to set TARGET_SPEC
|
||||||
# correctly when visiting each entry.
|
# correctly when visiting each entry.
|
||||||
#
|
#
|
||||||
# The fully qualified directory entries are used to construct a
|
# The fully qualified directory entries are used to construct a
|
||||||
@ -71,7 +71,7 @@
|
|||||||
#
|
#
|
||||||
# TARGET_SPEC_VARS
|
# TARGET_SPEC_VARS
|
||||||
# The default value is just MACHINE, and for most environments
|
# The default value is just MACHINE, and for most environments
|
||||||
# this is sufficient. The _DIRDEPS_USE target actually sets
|
# this is sufficient. The _DIRDEP_USE target actually sets
|
||||||
# both MACHINE and TARGET_SPEC to the suffix of the current
|
# both MACHINE and TARGET_SPEC to the suffix of the current
|
||||||
# target so that in the general case TARGET_SPEC can be ignored.
|
# target so that in the general case TARGET_SPEC can be ignored.
|
||||||
#
|
#
|
||||||
@ -196,7 +196,11 @@ N_notmachine := ${.MAKE.DEPENDFILE_PREFERENCE:E:N*${MACHINE}*:${M_ListToSkip}}
|
|||||||
# if we were included recursively _DEP_TARGET_SPEC should be valid.
|
# if we were included recursively _DEP_TARGET_SPEC should be valid.
|
||||||
.if empty(_DEP_TARGET_SPEC)
|
.if empty(_DEP_TARGET_SPEC)
|
||||||
# we may or may not have included a dependfile yet
|
# we may or may not have included a dependfile yet
|
||||||
|
.if defined(.INCLUDEDFROMFILE)
|
||||||
|
_last_dependfile := ${.INCLUDEDFROMFILE:M${.MAKE.DEPENDFILE_PREFIX}*}
|
||||||
|
.else
|
||||||
_last_dependfile := ${.MAKE.MAKEFILES:M*/${.MAKE.DEPENDFILE_PREFIX}*:[-1]}
|
_last_dependfile := ${.MAKE.MAKEFILES:M*/${.MAKE.DEPENDFILE_PREFIX}*:[-1]}
|
||||||
|
.endif
|
||||||
.if !empty(_debug_reldir)
|
.if !empty(_debug_reldir)
|
||||||
.info ${DEP_RELDIR}.${DEP_TARGET_SPEC}: _last_dependfile='${_last_dependfile}'
|
.info ${DEP_RELDIR}.${DEP_TARGET_SPEC}: _last_dependfile='${_last_dependfile}'
|
||||||
.endif
|
.endif
|
||||||
@ -239,7 +243,8 @@ DEP_MACHINE := ${_DEP_TARGET_SPEC}
|
|||||||
# we can use this as a clue to do initialization and other one time things.
|
# we can use this as a clue to do initialization and other one time things.
|
||||||
.if !target(_DIRDEP_USE)
|
.if !target(_DIRDEP_USE)
|
||||||
# make sure this target exists
|
# make sure this target exists
|
||||||
dirdeps:
|
dirdeps: beforedirdeps .WAIT
|
||||||
|
beforedirdeps:
|
||||||
|
|
||||||
# We normally expect to be included by Makefile.depend.*
|
# We normally expect to be included by Makefile.depend.*
|
||||||
# which sets the DEP_* macros below.
|
# which sets the DEP_* macros below.
|
||||||
@ -269,12 +274,15 @@ DEP_SKIP_DIR = ${SKIP_DIR} \
|
|||||||
|
|
||||||
NSkipDir = ${DEP_SKIP_DIR:${M_ListToSkip}}
|
NSkipDir = ${DEP_SKIP_DIR:${M_ListToSkip}}
|
||||||
|
|
||||||
.if defined(NO_DIRDEPS) || defined(NODIRDEPS)
|
.if defined(NO_DIRDEPS) || defined(NODIRDEPS) || defined(WITHOUT_DIRDEPS)
|
||||||
# confine ourselves to the original dir
|
# confine ourselves to the original dir
|
||||||
DIRDEPS_FILTER += M${_DEP_RELDIR}*
|
DIRDEPS_FILTER += M${_DEP_RELDIR}*
|
||||||
.endif
|
.endif
|
||||||
|
|
||||||
# we supress SUBDIR when visiting the leaves
|
# this is what we run below
|
||||||
|
DIRDEP_MAKE?= ${.MAKE}
|
||||||
|
|
||||||
|
# we suppress SUBDIR when visiting the leaves
|
||||||
# we assume sys.mk will set MACHINE_ARCH
|
# we assume sys.mk will set MACHINE_ARCH
|
||||||
# you can add extras to DIRDEP_USE_ENV
|
# you can add extras to DIRDEP_USE_ENV
|
||||||
# if there is no makefile in the target directory, we skip it.
|
# if there is no makefile in the target directory, we skip it.
|
||||||
@ -285,7 +293,7 @@ _DIRDEP_USE: .USE .MAKE
|
|||||||
MACHINE_ARCH= NO_SUBDIR=1 ${DIRDEP_USE_ENV} \
|
MACHINE_ARCH= NO_SUBDIR=1 ${DIRDEP_USE_ENV} \
|
||||||
TARGET_SPEC=${.TARGET:E} \
|
TARGET_SPEC=${.TARGET:E} \
|
||||||
MACHINE=${.TARGET:E} \
|
MACHINE=${.TARGET:E} \
|
||||||
${.MAKE} -C ${.TARGET:R} || exit 1; \
|
${DIRDEP_MAKE} -C ${.TARGET:R} || exit 1; \
|
||||||
break; \
|
break; \
|
||||||
done
|
done
|
||||||
|
|
||||||
@ -397,7 +405,7 @@ DEP_DIRDEPS_FILTER = U
|
|||||||
.endif
|
.endif
|
||||||
|
|
||||||
# this is what we start with
|
# this is what we start with
|
||||||
__depdirs := ${DIRDEPS:${NSkipDir}:${DEP_DIRDEPS_FILTER:ts:}:O:u:@d@${SRCTOP}/$d@}
|
__depdirs := ${DIRDEPS:${NSkipDir}:${DEP_DIRDEPS_FILTER:ts:}:C,//+,/,g:O:u:@d@${SRCTOP}/$d@}
|
||||||
|
|
||||||
# some entries may be qualified with .<machine>
|
# some entries may be qualified with .<machine>
|
||||||
# the :M*/*/*.* just tries to limit the dirs we check to likely ones.
|
# the :M*/*/*.* just tries to limit the dirs we check to likely ones.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $Id: dpadd.mk,v 1.18 2011/11/10 05:13:37 sjg Exp $
|
# $Id: dpadd.mk,v 1.19 2014/04/05 22:56:54 sjg Exp $
|
||||||
#
|
#
|
||||||
# @(#) Copyright (c) 2004, Simon J. Gerraty
|
# @(#) Copyright (c) 2004, Simon J. Gerraty
|
||||||
#
|
#
|
||||||
@ -68,7 +68,7 @@ DPLIBS+= ${LIBDMALLOC}
|
|||||||
.endif
|
.endif
|
||||||
.endif
|
.endif
|
||||||
|
|
||||||
# Order -L's to seach ours first.
|
# Order -L's to search ours first.
|
||||||
# Avoids picking up old versions already installed.
|
# Avoids picking up old versions already installed.
|
||||||
__dpadd_libdirs := ${__dpadd_libs:R:H:S/^/-L/g:O:u:N-L}
|
__dpadd_libdirs := ${__dpadd_libs:R:H:S/^/-L/g:O:u:N-L}
|
||||||
LDADD += ${__dpadd_libdirs:M-L${OBJTOP}/*}
|
LDADD += ${__dpadd_libdirs:M-L${OBJTOP}/*}
|
||||||
@ -99,9 +99,9 @@ SRC_LIBS+= ${_OBJDIR}/lib${LIB}.a
|
|||||||
# This little bit of magic, assumes that SRC_libfoo will be
|
# This little bit of magic, assumes that SRC_libfoo will be
|
||||||
# set if it cannot be correctly derrived from ${LIBFOO}
|
# set if it cannot be correctly derrived from ${LIBFOO}
|
||||||
# Note that SRC_libfoo and INCLUDES_libfoo should be named for the
|
# Note that SRC_libfoo and INCLUDES_libfoo should be named for the
|
||||||
# actual libary name not the variable name that might refer to it.
|
# actual library name not the variable name that might refer to it.
|
||||||
# 99% of the time the two are the same, but the DPADD logic
|
# 99% of the time the two are the same, but the DPADD logic
|
||||||
# only has the libary name available, so stick to that.
|
# only has the library name available, so stick to that.
|
||||||
#
|
#
|
||||||
|
|
||||||
SRC_LIBS?=
|
SRC_LIBS?=
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $Id: gendirdeps.mk,v 1.23 2013/09/04 17:49:20 sjg Exp $
|
# $Id: gendirdeps.mk,v 1.25 2014/03/14 21:28:37 sjg Exp $
|
||||||
|
|
||||||
# Copyright (c) 2010-2013, Juniper Networks, Inc.
|
# Copyright (c) 2010-2013, Juniper Networks, Inc.
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
@ -229,7 +229,7 @@ DIRDEPS = \
|
|||||||
${qualdir_list:N${RELDIR}.*:N${RELDIR}/*}
|
${qualdir_list:N${RELDIR}.*:N${RELDIR}/*}
|
||||||
|
|
||||||
# We only consider things below $RELDIR/ if they have a makefile.
|
# We only consider things below $RELDIR/ if they have a makefile.
|
||||||
# This is the same test that _DIRDEPS_USE applies.
|
# This is the same test that _DIRDEP_USE applies.
|
||||||
# We have do a double test with dirdep_list as it _may_ contain
|
# We have do a double test with dirdep_list as it _may_ contain
|
||||||
# qualified dirs - if we got anything from a stage dir.
|
# qualified dirs - if we got anything from a stage dir.
|
||||||
# qualdir_list we know are all qualified.
|
# qualdir_list we know are all qualified.
|
||||||
@ -240,7 +240,7 @@ DIRDEPS += \
|
|||||||
${dirdep_list:M${RELDIR}/*:@d@${.MAKE.MAKEFILE_PREFERENCE:@m@${exists(${SRCTOP}/$d/$m):?$d:${exists(${SRCTOP}/${d:R}/$m):?$d:}}@}@} \
|
${dirdep_list:M${RELDIR}/*:@d@${.MAKE.MAKEFILE_PREFERENCE:@m@${exists(${SRCTOP}/$d/$m):?$d:${exists(${SRCTOP}/${d:R}/$m):?$d:}}@}@} \
|
||||||
${qualdir_list:M${RELDIR}/*:@d@${.MAKE.MAKEFILE_PREFERENCE:@m@${exists(${SRCTOP}/${d:R}/$m):?$d:}@}@}
|
${qualdir_list:M${RELDIR}/*:@d@${.MAKE.MAKEFILE_PREFERENCE:@m@${exists(${SRCTOP}/${d:R}/$m):?$d:}@}@}
|
||||||
|
|
||||||
DIRDEPS := ${DIRDEPS:${GENDIRDEPS_FILTER:UNno:ts:}:O:u}
|
DIRDEPS := ${DIRDEPS:${GENDIRDEPS_FILTER:UNno:ts:}:C,//+,/,g:O:u}
|
||||||
|
|
||||||
.if ${DEBUG_GENDIRDEPS:Uno:@x@${RELDIR:M$x}@} != ""
|
.if ${DEBUG_GENDIRDEPS:Uno:@x@${RELDIR:M$x}@} != ""
|
||||||
.info ${RELDIR}: M2D_OBJROOTS=${M2D_OBJROOTS}
|
.info ${RELDIR}: M2D_OBJROOTS=${M2D_OBJROOTS}
|
||||||
@ -261,7 +261,7 @@ src_dirdep_list = \
|
|||||||
SRC_DIRDEPS = \
|
SRC_DIRDEPS = \
|
||||||
${src_dirdep_list:N${RELDIR}:N${RELDIR}/*:C,(/h)/.*,,}
|
${src_dirdep_list:N${RELDIR}:N${RELDIR}/*:C,(/h)/.*,,}
|
||||||
|
|
||||||
SRC_DIRDEPS := ${SRC_DIRDEPS:${GENDIRDEPS_SRC_FILTER:UN/*:ts:}:O:u}
|
SRC_DIRDEPS := ${SRC_DIRDEPS:${GENDIRDEPS_SRC_FILTER:UN/*:ts:}:C,//+,/,g:O:u}
|
||||||
|
|
||||||
# if you want to capture SRC_DIRDEPS in .MAKE.DEPENDFILE put
|
# if you want to capture SRC_DIRDEPS in .MAKE.DEPENDFILE put
|
||||||
# SRC_DIRDEPS_FILE = ${_DEPENDFILE}
|
# SRC_DIRDEPS_FILE = ${_DEPENDFILE}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# RCSid:
|
# RCSid:
|
||||||
# $Id: host-target.mk,v 1.6 2011/03/02 05:05:21 sjg Exp $
|
# $Id: host-target.mk,v 1.7 2014/05/16 17:54:52 sjg Exp $
|
||||||
|
|
||||||
# Host platform information; may be overridden
|
# Host platform information; may be overridden
|
||||||
.if !defined(_HOST_OSNAME)
|
.if !defined(_HOST_OSNAME)
|
||||||
@ -18,6 +18,10 @@ _HOST_ARCH != uname -m
|
|||||||
.endif
|
.endif
|
||||||
.export _HOST_ARCH
|
.export _HOST_ARCH
|
||||||
.endif
|
.endif
|
||||||
|
.if !defined(HOST_MACHINE)
|
||||||
|
HOST_MACHINE != uname -m
|
||||||
|
.export HOST_MACHINE
|
||||||
|
.endif
|
||||||
|
|
||||||
HOST_OSMAJOR := ${_HOST_OSREL:C/[^0-9].*//}
|
HOST_OSMAJOR := ${_HOST_OSREL:C/[^0-9].*//}
|
||||||
HOST_OSTYPE := ${_HOST_OSNAME}-${_HOST_OSREL:C/\([^\)]*\)//}-${_HOST_ARCH}
|
HOST_OSTYPE := ${_HOST_OSNAME}-${_HOST_OSREL:C/\([^\)]*\)//}-${_HOST_ARCH}
|
||||||
|
@ -55,7 +55,7 @@
|
|||||||
# Simon J. Gerraty <sjg@crufty.net>
|
# Simon J. Gerraty <sjg@crufty.net>
|
||||||
|
|
||||||
# RCSid:
|
# RCSid:
|
||||||
# $Id: install-mk,v 1.95 2013/12/20 06:08:52 sjg Exp $
|
# $Id: install-mk,v 1.100 2014/05/23 01:30:36 sjg Exp $
|
||||||
#
|
#
|
||||||
# @(#) Copyright (c) 1994 Simon J. Gerraty
|
# @(#) Copyright (c) 1994 Simon J. Gerraty
|
||||||
#
|
#
|
||||||
@ -70,7 +70,7 @@
|
|||||||
# sjg@crufty.net
|
# sjg@crufty.net
|
||||||
#
|
#
|
||||||
|
|
||||||
MK_VERSION=20131212
|
MK_VERSION=20140522
|
||||||
OWNER=
|
OWNER=
|
||||||
GROUP=
|
GROUP=
|
||||||
MODE=444
|
MODE=444
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $Id: lib.mk,v 1.49 2013/07/18 05:46:24 sjg Exp $
|
# $Id: lib.mk,v 1.51 2014/05/23 01:30:36 sjg Exp $
|
||||||
|
|
||||||
.if !target(__${.PARSEFILE}__)
|
.if !target(__${.PARSEFILE}__)
|
||||||
__${.PARSEFILE}__:
|
__${.PARSEFILE}__:
|
||||||
@ -55,7 +55,7 @@ CFLAGS+= ${COPTS}
|
|||||||
# are built for different platforms and object formats.
|
# are built for different platforms and object formats.
|
||||||
# OBJECT_FMT: currently either "ELF" or "a.out", from <bsd.own.mk>
|
# OBJECT_FMT: currently either "ELF" or "a.out", from <bsd.own.mk>
|
||||||
# SHLIB_SOVERSION: version number to be compiled into a shared library
|
# SHLIB_SOVERSION: version number to be compiled into a shared library
|
||||||
# via -soname. Usualy ${SHLIB_MAJOR} on ELF.
|
# via -soname. Usually ${SHLIB_MAJOR} on ELF.
|
||||||
# NetBSD/pmax used to use ${SHLIB_MAJOR}[.${SHLIB_MINOR}
|
# NetBSD/pmax used to use ${SHLIB_MAJOR}[.${SHLIB_MINOR}
|
||||||
# [.${SHLIB_TEENY}]]
|
# [.${SHLIB_TEENY}]]
|
||||||
# SHLIB_SHFLAGS: Flags to tell ${LD} to emit shared library.
|
# SHLIB_SHFLAGS: Flags to tell ${LD} to emit shared library.
|
||||||
@ -123,7 +123,7 @@ SHLIB_LDSTARTFILE?= /usr/lib/crtbeginS.o
|
|||||||
SHLIB_LDENDFILE?= /usr/lib/crtendS.o
|
SHLIB_LDENDFILE?= /usr/lib/crtendS.o
|
||||||
.endif
|
.endif
|
||||||
|
|
||||||
# for compatability with the following
|
# for compatibility with the following
|
||||||
CC_PIC?= ${CPICFLAGS}
|
CC_PIC?= ${CPICFLAGS}
|
||||||
LD_shared=${SHLIB_SHFLAGS}
|
LD_shared=${SHLIB_SHFLAGS}
|
||||||
|
|
||||||
@ -175,9 +175,10 @@ AR_cq= -cqs
|
|||||||
.elif ${TARGET_OSNAME} == "FreeBSD"
|
.elif ${TARGET_OSNAME} == "FreeBSD"
|
||||||
LD_solib= lib${LIB}_pic.a
|
LD_solib= lib${LIB}_pic.a
|
||||||
.elif ${TARGET_OSNAME} == "Linux"
|
.elif ${TARGET_OSNAME} == "Linux"
|
||||||
|
SHLIB_LD = ${CC}
|
||||||
# this is ambiguous of course
|
# this is ambiguous of course
|
||||||
LD_shared=-shared -h lib${LIB}.so.${SHLIB_MAJOR}
|
LD_shared=-shared -Wl,"-h lib${LIB}.so.${SHLIB_MAJOR}"
|
||||||
LD_solib= --whole-archive lib${LIB}_pic.a
|
LD_solib= -Wl,--whole-archive lib${LIB}_pic.a -Wl,--no-whole-archive
|
||||||
# Linux uses GNU ld, which is a multi-pass linker
|
# Linux uses GNU ld, which is a multi-pass linker
|
||||||
# so we don't need to use lorder or tsort
|
# so we don't need to use lorder or tsort
|
||||||
LD_objs = ${OBJS}
|
LD_objs = ${OBJS}
|
||||||
@ -259,7 +260,7 @@ OPTIMIZE_OBJECT_META_FILES ?= yes
|
|||||||
|
|
||||||
|
|
||||||
.if ${MK_LIBTOOL} == "yes"
|
.if ${MK_LIBTOOL} == "yes"
|
||||||
# because libtool is so facist about naming the object files,
|
# because libtool is so fascist about naming the object files,
|
||||||
# we cannot (yet) build profiled libs
|
# we cannot (yet) build profiled libs
|
||||||
MK_PROFILE=no
|
MK_PROFILE=no
|
||||||
_LIBS=lib${LIB}.a
|
_LIBS=lib${LIB}.a
|
||||||
@ -413,7 +414,7 @@ SHLIB_AGE?=0
|
|||||||
.s.o .S.o .c.o:
|
.s.o .S.o .c.o:
|
||||||
${LIBTOOL} --mode=compile ${CC} ${LT_STATIC} ${CFLAGS} ${CPPFLAGS} ${IMPFLAGS} -c ${.IMPSRC}
|
${LIBTOOL} --mode=compile ${CC} ${LT_STATIC} ${CFLAGS} ${CPPFLAGS} ${IMPFLAGS} -c ${.IMPSRC}
|
||||||
|
|
||||||
# can't really do profiled libs with libtool - its too facist about
|
# can't really do profiled libs with libtool - its too fascist about
|
||||||
# naming the output...
|
# naming the output...
|
||||||
lib${LIB}.a:: ${OBJS}
|
lib${LIB}.a:: ${OBJS}
|
||||||
@rm -f ${.TARGET}
|
@rm -f ${.TARGET}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $Id: meta.autodep.mk,v 1.32 2012/11/13 00:44:26 sjg Exp $
|
# $Id: meta.autodep.mk,v 1.35 2014/05/09 00:05:46 sjg Exp $
|
||||||
|
|
||||||
#
|
#
|
||||||
# @(#) Copyright (c) 2010, Simon J. Gerraty
|
# @(#) Copyright (c) 2010, Simon J. Gerraty
|
||||||
@ -120,7 +120,7 @@ FORCE_DPADD += ${_nonlibs:@x@${DPADD:M*/$x}@}
|
|||||||
# some makefiles and/or targets contain
|
# some makefiles and/or targets contain
|
||||||
# circular dependencies if you dig too deep
|
# circular dependencies if you dig too deep
|
||||||
# (as meta mode is apt to do)
|
# (as meta mode is apt to do)
|
||||||
# so we provide a means of supressing them.
|
# so we provide a means of suppressing them.
|
||||||
# the input to the loop below is target: dependency
|
# the input to the loop below is target: dependency
|
||||||
# with just one dependency per line.
|
# with just one dependency per line.
|
||||||
# Also some targets are not really local, or use random names.
|
# Also some targets are not really local, or use random names.
|
||||||
@ -137,7 +137,7 @@ SUPPRESS_DEPEND += \
|
|||||||
# the double $$ defers initial evaluation
|
# the double $$ defers initial evaluation
|
||||||
# if necessary, we fake .po dependencies, just so the result
|
# if necessary, we fake .po dependencies, just so the result
|
||||||
# in Makefile.depend* is stable
|
# in Makefile.depend* is stable
|
||||||
# The current objdir may be refered to in various ways
|
# The current objdir may be referred to in various ways
|
||||||
OBJDIR_REFS += ${.OBJDIR} ${.OBJDIR:tA} ${_OBJDIR} ${RELOBJTOP}/${RELDIR}
|
OBJDIR_REFS += ${.OBJDIR} ${.OBJDIR:tA} ${_OBJDIR} ${RELOBJTOP}/${RELDIR}
|
||||||
_depend = .depend
|
_depend = .depend
|
||||||
# it would be nice to be able to get .SUFFIXES as ${.SUFFIXES}
|
# it would be nice to be able to get .SUFFIXES as ${.SUFFIXES}
|
||||||
@ -176,7 +176,9 @@ _depend =
|
|||||||
.info ${_DEPENDFILE:S,${SRCTOP}/,,} _depend=${_depend}
|
.info ${_DEPENDFILE:S,${SRCTOP}/,,} _depend=${_depend}
|
||||||
.endif
|
.endif
|
||||||
|
|
||||||
|
.if ${UPDATE_DEPENDFILE} == "yes"
|
||||||
gendirdeps: ${_DEPENDFILE}
|
gendirdeps: ${_DEPENDFILE}
|
||||||
|
.endif
|
||||||
|
|
||||||
.if !target(${_DEPENDFILE})
|
.if !target(${_DEPENDFILE})
|
||||||
.if ${_bootstrap_dirdeps} == "yes"
|
.if ${_bootstrap_dirdeps} == "yes"
|
||||||
@ -259,4 +261,28 @@ ${_DEPENDFILE}: .PRECIOUS
|
|||||||
.endif
|
.endif
|
||||||
|
|
||||||
CLEANFILES += *.meta filemon.* *.db
|
CLEANFILES += *.meta filemon.* *.db
|
||||||
|
|
||||||
|
# these make it easy to gather some stats
|
||||||
|
now_utc = ${%s:L:gmtime}
|
||||||
|
start_utc := ${now_utc}
|
||||||
|
|
||||||
|
meta_stats= meta=${empty(.MAKE.META.FILES):?0:${.MAKE.META.FILES:[#]}} \
|
||||||
|
created=${empty(.MAKE.META.CREATED):?0:${.MAKE.META.CREATED:[#]}}
|
||||||
|
|
||||||
|
#.END: _reldir_finish
|
||||||
|
.if target(gendirdeps)
|
||||||
|
_reldir_finish: gendirdeps
|
||||||
|
.endif
|
||||||
|
_reldir_finish: .NOMETA
|
||||||
|
@echo "${TIME_STAMP} Finished ${RELDIR}.${TARGET_SPEC} seconds=$$(( ${now_utc} - ${start_utc} )) ${meta_stats}"
|
||||||
|
|
||||||
|
#.ERROR: _reldir_failed
|
||||||
|
_reldir_failed: .NOMETA
|
||||||
|
@echo "${TIME_STAMP} Failed ${RELDIR}.${TARGET_SPEC} seconds=$$(( ${now_utc} - ${start_utc} )) ${meta_stats}"
|
||||||
|
|
||||||
|
.if defined(WITH_META_STATS) && ${.MAKE.LEVEL} > 0
|
||||||
|
.END: _reldir_finish
|
||||||
|
.ERROR: _reldir_failed
|
||||||
|
.endif
|
||||||
|
|
||||||
.endif
|
.endif
|
||||||
|
@ -37,7 +37,7 @@ We only pay attention to a subset of the information in the
|
|||||||
|
|
||||||
"""
|
"""
|
||||||
RCSid:
|
RCSid:
|
||||||
$Id: meta2deps.py,v 1.16 2013/12/20 06:08:52 sjg Exp $
|
$Id: meta2deps.py,v 1.17 2014/04/05 22:56:54 sjg Exp $
|
||||||
|
|
||||||
Copyright (c) 2011-2013, Juniper Networks, Inc.
|
Copyright (c) 2011-2013, Juniper Networks, Inc.
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
@ -166,7 +166,7 @@ class MetaFile:
|
|||||||
Sometimes MACHINE isn't enough.
|
Sometimes MACHINE isn't enough.
|
||||||
|
|
||||||
HOST_TARGET
|
HOST_TARGET
|
||||||
when we build for the psuedo machine 'host'
|
when we build for the pseudo machine 'host'
|
||||||
the object tree uses HOST_TARGET rather than MACHINE.
|
the object tree uses HOST_TARGET rather than MACHINE.
|
||||||
|
|
||||||
OBJROOTS a list of the common prefix for all obj dirs it might
|
OBJROOTS a list of the common prefix for all obj dirs it might
|
||||||
@ -296,7 +296,7 @@ class MetaFile:
|
|||||||
print("%s: %sAdd: %s" % (self.name, clue, data), file=self.debug_out)
|
print("%s: %sAdd: %s" % (self.name, clue, data), file=self.debug_out)
|
||||||
|
|
||||||
def find_top(self, path, list):
|
def find_top(self, path, list):
|
||||||
"""the logical tree may be split accross multiple trees"""
|
"""the logical tree may be split across multiple trees"""
|
||||||
for top in list:
|
for top in list:
|
||||||
if path.startswith(top):
|
if path.startswith(top):
|
||||||
if self.debug > 2:
|
if self.debug > 2:
|
||||||
|
@ -77,7 +77,7 @@
|
|||||||
|
|
||||||
|
|
||||||
# RCSid:
|
# RCSid:
|
||||||
# $Id: meta2deps.sh,v 1.6 2013/05/11 05:16:26 sjg Exp $
|
# $Id: meta2deps.sh,v 1.7 2014/04/05 22:56:54 sjg Exp $
|
||||||
|
|
||||||
# Copyright (c) 2010-2013, Juniper Networks, Inc.
|
# Copyright (c) 2010-2013, Juniper Networks, Inc.
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
@ -348,7 +348,7 @@ meta2deps() {
|
|||||||
[ -s $f ] || continue
|
[ -s $f ] || continue
|
||||||
case $f in
|
case $f in
|
||||||
*qual) # a list of .dirdep files
|
*qual) # a list of .dirdep files
|
||||||
# we can prefix everthing with $OBJTOP to
|
# we can prefix everything with $OBJTOP to
|
||||||
# tell gendirdeps.mk that these are
|
# tell gendirdeps.mk that these are
|
||||||
# DIRDEP entries, since they are already
|
# DIRDEP entries, since they are already
|
||||||
# qualified with .<machine> as needed.
|
# qualified with .<machine> as needed.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $Id: options.mk,v 1.7 2013/04/17 20:32:38 sjg Exp $
|
# $Id: options.mk,v 1.10 2014/02/11 18:34:48 sjg Exp $
|
||||||
#
|
#
|
||||||
# @(#) Copyright (c) 2012, Simon J. Gerraty
|
# @(#) Copyright (c) 2012, Simon J. Gerraty
|
||||||
#
|
#
|
||||||
@ -30,15 +30,27 @@ OPTIONS_DEFAULT_VALUES += \
|
|||||||
${OPTIONS_DEFAULT_YES:O:u:S,$,/yes,}
|
${OPTIONS_DEFAULT_YES:O:u:S,$,/yes,}
|
||||||
|
|
||||||
OPTION_PREFIX ?= MK_
|
OPTION_PREFIX ?= MK_
|
||||||
|
|
||||||
|
# NO_* takes precedence
|
||||||
|
# If both WITH_* and WITHOUT_* are defined, WITHOUT_ wins unless
|
||||||
|
# DOMINANT_* is set to "yes"
|
||||||
|
# Otherwise WITH_* and WITHOUT_* override the default.
|
||||||
.for o in ${OPTIONS_DEFAULT_VALUES:M*/*}
|
.for o in ${OPTIONS_DEFAULT_VALUES:M*/*}
|
||||||
.if ${o:T:tl} == "no"
|
.if defined(NO_${o:H}) || defined(NO${o:H})
|
||||||
.if defined(WITH_${o:H}) && !defined(NO_${o:H}) && !defined(NO${o:H})
|
# we cannot do it
|
||||||
|
${OPTION_PREFIX}${o:H} ?= no
|
||||||
|
.elif defined(WITH_${o:H}) && defined(WITHOUT_${o:H})
|
||||||
|
# normally WITHOUT_ wins
|
||||||
|
DOMINANT_${o:H} ?= no
|
||||||
|
${OPTION_PREFIX}${o:H} ?= ${DOMINANT_${o:H}}
|
||||||
|
.elif ${o:T:tl} == "no"
|
||||||
|
.if defined(WITH_${o:H})
|
||||||
${OPTION_PREFIX}${o:H} ?= yes
|
${OPTION_PREFIX}${o:H} ?= yes
|
||||||
.else
|
.else
|
||||||
${OPTION_PREFIX}${o:H} ?= no
|
${OPTION_PREFIX}${o:H} ?= no
|
||||||
.endif
|
.endif
|
||||||
.else
|
.else
|
||||||
.if defined(WITHOUT_${o:H}) || defined(NO_${o:H}) || defined(NO${o:H})
|
.if defined(WITHOUT_${o:H})
|
||||||
${OPTION_PREFIX}${o:H} ?= no
|
${OPTION_PREFIX}${o:H} ?= no
|
||||||
.else
|
.else
|
||||||
${OPTION_PREFIX}${o:H} ?= yes
|
${OPTION_PREFIX}${o:H} ?= yes
|
||||||
@ -47,11 +59,19 @@ ${OPTION_PREFIX}${o:H} ?= yes
|
|||||||
.endfor
|
.endfor
|
||||||
|
|
||||||
# OPTIONS_DEFAULT_DEPENDENT += FOO_UTILS/FOO
|
# OPTIONS_DEFAULT_DEPENDENT += FOO_UTILS/FOO
|
||||||
# if neither WITH[OUT]_FOO_UTILS is set, use value of ${OPTION_PREFIX}FOO
|
# If neither WITH[OUT]_FOO_UTILS is set, (see rules above)
|
||||||
|
# use the value of ${OPTION_PREFIX}FOO
|
||||||
.for o in ${OPTIONS_DEFAULT_DEPENDENT:M*/*:O:u}
|
.for o in ${OPTIONS_DEFAULT_DEPENDENT:M*/*:O:u}
|
||||||
.if defined(WITH_${o:H}) && !defined(NO_${o:H}) && !defined(NO${o:H})
|
.if defined(NO_${o:H}) || defined(NO${o:H})
|
||||||
|
# we cannot do it
|
||||||
|
${OPTION_PREFIX}${o:H} ?= no
|
||||||
|
.elif defined(WITH_${o:H}) && defined(WITHOUT_${o:H})
|
||||||
|
# normally WITHOUT_ wins
|
||||||
|
DOMINANT_${o:H} ?= no
|
||||||
|
${OPTION_PREFIX}${o:H} ?= ${DOMINANT_${o:H}}
|
||||||
|
.elif defined(WITH_${o:H})
|
||||||
${OPTION_PREFIX}${o:H} ?= yes
|
${OPTION_PREFIX}${o:H} ?= yes
|
||||||
.elif defined(WITHOUT_${o:H}) || defined(NO_${o:H}) || defined(NO${o:H})
|
.elif defined(WITHOUT_${o:H})
|
||||||
${OPTION_PREFIX}${o:H} ?= no
|
${OPTION_PREFIX}${o:H} ?= no
|
||||||
.else
|
.else
|
||||||
${OPTION_PREFIX}${o:H} ?= ${${OPTION_PREFIX}${o:T}}
|
${OPTION_PREFIX}${o:H} ?= ${${OPTION_PREFIX}${o:T}}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $Id: rst2htm.mk,v 1.8 2011/04/03 21:39:25 sjg Exp $
|
# $Id: rst2htm.mk,v 1.9 2014/02/22 01:52:41 sjg Exp $
|
||||||
#
|
#
|
||||||
# @(#) Copyright (c) 2009, Simon J. Gerraty
|
# @(#) Copyright (c) 2009, Simon J. Gerraty
|
||||||
#
|
#
|
||||||
@ -22,6 +22,7 @@ TXTSRCS != 'ls' -1t ${.CURDIR}/*.txt ${.CURDIR}/*.rst 2>/dev/null; echo
|
|||||||
RSTSRCS ?= ${TXTSRCS}
|
RSTSRCS ?= ${TXTSRCS}
|
||||||
HTMFILES ?= ${RSTSRCS:R:T:O:u:%=%.htm}
|
HTMFILES ?= ${RSTSRCS:R:T:O:u:%=%.htm}
|
||||||
RST2HTML ?= rst2html.py
|
RST2HTML ?= rst2html.py
|
||||||
|
RST2PDF ?= rst2pdf
|
||||||
RST2S5 ?= rst2s5.py
|
RST2S5 ?= rst2s5.py
|
||||||
# the following will run RST2S5 if the target name contains the word 'slides'
|
# the following will run RST2S5 if the target name contains the word 'slides'
|
||||||
# otherwise it uses RST2HTML
|
# otherwise it uses RST2HTML
|
||||||
@ -33,11 +34,15 @@ CLEANFILES += ${HTMFILES}
|
|||||||
|
|
||||||
html: ${HTMFILES}
|
html: ${HTMFILES}
|
||||||
|
|
||||||
.SUFFIXES: ${RST_SUFFIXES} .htm
|
.SUFFIXES: ${RST_SUFFIXES} .htm .pdf
|
||||||
|
|
||||||
${RST_SUFFIXES:@s@$s.htm@}:
|
${RST_SUFFIXES:@s@$s.htm@}:
|
||||||
${RST2HTM} ${.IMPSRC} ${.TARGET}
|
${RST2HTM} ${.IMPSRC} ${.TARGET}
|
||||||
|
|
||||||
|
${RST_SUFFIXES:@s@$s.pdf@}:
|
||||||
|
${RST2PDF} ${.IMPSRC} ${.TARGET}
|
||||||
|
|
||||||
.for s in ${RSTSRCS:O:u}
|
.for s in ${RSTSRCS:O:u}
|
||||||
${s:R:T}.htm: $s
|
${s:R:T}.htm: $s
|
||||||
|
${s:R:T}.pdf: $s
|
||||||
.endfor
|
.endfor
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $Id: sys.mk,v 1.35 2012/11/12 06:27:51 sjg Exp $
|
# $Id: sys.mk,v 1.36 2014/05/11 00:30:19 sjg Exp $
|
||||||
#
|
#
|
||||||
# @(#) Copyright (c) 2003-2009, Simon J. Gerraty
|
# @(#) Copyright (c) 2003-2009, Simon J. Gerraty
|
||||||
#
|
#
|
||||||
@ -77,7 +77,7 @@ M_ListToSkip= O:u:ts::S,:,:N,g:S,^,N,
|
|||||||
# type should be a builtin in any sh since about 1980,
|
# type should be a builtin in any sh since about 1980,
|
||||||
# AUTOCONF := ${autoconf:L:${M_whence}}
|
# AUTOCONF := ${autoconf:L:${M_whence}}
|
||||||
M_type = @x@(type $$x 2> /dev/null); echo;@:sh:[0]:N* found*:[@]:C,[()],,g
|
M_type = @x@(type $$x 2> /dev/null); echo;@:sh:[0]:N* found*:[@]:C,[()],,g
|
||||||
M_whence = ${M_type}:M/*
|
M_whence = ${M_type}:M/*:[1]
|
||||||
|
|
||||||
# convert a path to a valid shell variable
|
# convert a path to a valid shell variable
|
||||||
M_P2V = tu:C,[./-],_,g
|
M_P2V = tu:C,[./-],_,g
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $Id: SunOS.mk,v 1.5 2010/01/11 23:02:05 sjg Exp $
|
# $Id: SunOS.mk,v 1.6 2014/04/05 22:56:54 sjg Exp $
|
||||||
|
|
||||||
.if ${.PARSEFILE} == "sys.mk"
|
.if ${.PARSEFILE} == "sys.mk"
|
||||||
.include <host-target.mk>
|
.include <host-target.mk>
|
||||||
@ -12,7 +12,7 @@ ROOT_GROUP= root
|
|||||||
|
|
||||||
SHLIB_FULLVERSION = ${SHLIB_MAJOR}
|
SHLIB_FULLVERSION = ${SHLIB_MAJOR}
|
||||||
|
|
||||||
# supress the dependency
|
# suppress the dependency
|
||||||
LIBCRT0= /dev/null
|
LIBCRT0= /dev/null
|
||||||
|
|
||||||
.ifndef CC
|
.ifndef CC
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#
|
#
|
||||||
# DESCRIPTION:
|
# DESCRIPTION:
|
||||||
# Include this macro file after all others in a makefile and
|
# Include this macro file after all others in a makefile and
|
||||||
# follow it with any target specfic flag settings.
|
# follow it with any target specific flag settings.
|
||||||
# For each such variable v in TARGET_FLAG_VARS we set:
|
# For each such variable v in TARGET_FLAG_VARS we set:
|
||||||
#.nf
|
#.nf
|
||||||
#
|
#
|
||||||
@ -37,7 +37,7 @@
|
|||||||
|
|
||||||
|
|
||||||
# RCSid:
|
# RCSid:
|
||||||
# $Id: target-flags.mk,v 1.8 2002/05/08 06:01:00 sjg Exp $
|
# $Id: target-flags.mk,v 1.9 2014/04/05 22:56:54 sjg Exp $
|
||||||
#
|
#
|
||||||
# @(#) Copyright (c) 1998-2002, Simon J. Gerraty
|
# @(#) Copyright (c) 1998-2002, Simon J. Gerraty
|
||||||
#
|
#
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# RCSid:
|
# RCSid:
|
||||||
# $Id: warnings.mk,v 1.7 2009/12/11 17:06:03 sjg Exp $
|
# $Id: warnings.mk,v 1.8 2014/04/02 19:20:23 sjg Exp $
|
||||||
#
|
#
|
||||||
# @(#) Copyright (c) 2002, Simon J. Gerraty
|
# @(#) Copyright (c) 2002, Simon J. Gerraty
|
||||||
#
|
#
|
||||||
@ -42,24 +42,30 @@ HIGH_WARNINGS?= ${MEDIUM_WARNINGS} \
|
|||||||
-Wswitch \
|
-Wswitch \
|
||||||
-Wwrite-strings
|
-Wwrite-strings
|
||||||
|
|
||||||
|
EXTRA_WARNINGS?= ${HIGH_WARNINGS} -Wextra
|
||||||
|
|
||||||
# The two step default makes it easier to test build with different defaults.
|
# The two step default makes it easier to test build with different defaults.
|
||||||
DEFAULT_WARNINGS_SET?= MIN
|
DEFAULT_WARNINGS_SET?= MIN
|
||||||
WARNINGS_SET?= ${DEFAULT_WARNINGS_SET}
|
WARNINGS_SET?= ${DEFAULT_WARNINGS_SET}
|
||||||
|
|
||||||
# If you add sets, besure to list them (you don't have to touch this list).
|
# If you add sets, besure to list them (you don't have to touch this list).
|
||||||
ALL_WARNINGS_SETS+= MIN LOW MEDIUM HIGH
|
ALL_WARNINGS_SETS+= MIN LOW MEDIUM HIGH EXTRA
|
||||||
|
|
||||||
.if empty(${WARNINGS_SET}_WARNINGS)
|
.if !empty(WARNINGS_SET)
|
||||||
.if ${MAKE_VERSION:U0:[1]:C/.*-//} >= 20050530
|
.for ws in ${WARNINGS_SET}
|
||||||
|
.if empty(${ws}_WARNINGS)
|
||||||
|
.if ${MAKE_VERSION:[1]:C/.*-//} >= 20050530
|
||||||
.BEGIN: _empty_warnings
|
.BEGIN: _empty_warnings
|
||||||
_empty_warnings: .PHONY
|
_empty_warnings: .PHONY
|
||||||
.else
|
.else
|
||||||
.BEGIN:
|
.BEGIN:
|
||||||
.endif
|
.endif
|
||||||
@echo "ERROR: Invalid: WARNINGS_SET=${WARNINGS_SET}"
|
@echo "ERROR: Invalid: WARNINGS_SET=${ws}"
|
||||||
@echo "ERROR: Try one of: ${ALL_WARNINGS_SETS:O:u}"; exit 1
|
@echo "ERROR: Try one of: ${ALL_WARNINGS_SETS:O:u}"; exit 1
|
||||||
|
|
||||||
.endif
|
.endif
|
||||||
|
.endfor
|
||||||
|
.endif
|
||||||
|
|
||||||
# Without -O or if we've set -O0 somewhere - to make debugging more effective,
|
# Without -O or if we've set -O0 somewhere - to make debugging more effective,
|
||||||
# we need to turn off -Wuninitialized as otherwise we get a warning that
|
# we need to turn off -Wuninitialized as otherwise we get a warning that
|
||||||
@ -69,40 +75,6 @@ _w_cflags:= ${CFLAGS} ${CPPFLAGS}
|
|||||||
W_uninitialized=
|
W_uninitialized=
|
||||||
.endif
|
.endif
|
||||||
|
|
||||||
.if ${MAKE_VERSION:U0:[1]:C/.*-//} <= 20040118
|
|
||||||
# This version uses .for loops to avoid a double free bug in old bmake's
|
|
||||||
# but the .for loops are sensitive to when this file is read.
|
|
||||||
|
|
||||||
# first, make a list of all the warning flags - doesn't matter if
|
|
||||||
# its redundant - we'll sort -u
|
|
||||||
_all_sets= ${WARNINGS_SET_${MACHINE_ARCH}} ${WARNINGS_SET} ${ALL_WARNINGS_SETS}
|
|
||||||
_all_warnings= ${WARNINGS} ${_all_sets:O:u:@s@${$s_WARNINGS}@}
|
|
||||||
|
|
||||||
# we want to set W_* for each warning so they are easy to turn off.
|
|
||||||
# :O:u does a sort -u
|
|
||||||
# using :C allows us to handle -f* -w* etc as well as -W*
|
|
||||||
.for w in ${_all_warnings:O:u}
|
|
||||||
${w:C/-(.)/\1_/} ?= $w
|
|
||||||
.endfor
|
|
||||||
|
|
||||||
# Allow for per-target warnings
|
|
||||||
# Warning: the WARNINGS+= line below,
|
|
||||||
# may make your brain hurt - trust me; it works --sjg
|
|
||||||
# the idea is that you can set WARNINGS_SET[_${MACHINE_ARCH}]=HIGH
|
|
||||||
# and use one of
|
|
||||||
# W_format_mips_foo.o=
|
|
||||||
# W_format_foo.o=
|
|
||||||
# to turn off -Wformat for foo.o (on mips only in the first case), or
|
|
||||||
# W_format_foo.o=-Wformat=2
|
|
||||||
# for stricter checking.
|
|
||||||
#
|
|
||||||
# NOTE: that we force the target extension to be .o
|
|
||||||
#
|
|
||||||
.for w in ${WARNINGS_SET_${MACHINE_ARCH}:U${WARNINGS_SET}:@s@${$s_WARNINGS}@:O:u}
|
|
||||||
WARNINGS+= ${${w:C/-(.)/\1_/}_${MACHINE_ARCH}_${.TARGET:T:R}.o:U${${w:C/-(.)/\1_/}_${.TARGET:T:R}.o:U${${w:C/-(.)/\1_/}_${MACHINE_ARCH}:U${${w:C/-(.)/\1_/}}}}}
|
|
||||||
.endfor
|
|
||||||
|
|
||||||
.else
|
|
||||||
|
|
||||||
# .for loops have the [dis]advantage of being evaluated when read,
|
# .for loops have the [dis]advantage of being evaluated when read,
|
||||||
# so adding to WARNINGS_SET[_${MACHINE_ARCH}] after this file is
|
# so adding to WARNINGS_SET[_${MACHINE_ARCH}] after this file is
|
||||||
@ -123,9 +95,19 @@ WARNINGS+= ${${w:C/-(.)/\1_/}_${MACHINE_ARCH}_${.TARGET:T:R}.o:U${${w:C/-(.)/\1_
|
|||||||
#
|
#
|
||||||
# NOTE: that we force the target extension to be .o
|
# NOTE: that we force the target extension to be .o
|
||||||
#
|
#
|
||||||
WARNINGS+= ${WARNINGS_SET_${MACHINE_ARCH}:U${WARNINGS_SET}:@s@${$s_WARNINGS}@:O:u:@w@${${w:C/-(.)/\1_/}::?=$w} ${${w:C/-(.)/\1_/}_${MACHINE_ARCH}_${.TARGET:T:R}.o:U${${w:C/-(.)/\1_/}_${.TARGET:T:R}.o:U${${w:C/-(.)/\1_/}_${MACHINE_ARCH}:U${${w:C/-(.)/\1_/}}}}}@}
|
|
||||||
|
|
||||||
.endif
|
# define this once, we use it a couple of times below (hence the doubled $$).
|
||||||
|
M_warnings_list = @s@$${$$s_WARNINGS}@:O:u:@w@$${$${w:C/-(.)/\1_/}::?=$$w} $${$${w:C/-(.)/\1_/}_${MACHINE_ARCH}_${.TARGET:T:R}.o:U$${$${w:C/-(.)/\1_/}_${.TARGET:T:R}.o:U$${$${w:C/-(.)/\1_/}_${MACHINE_ARCH}:U$${$${w:C/-(.)/\1_/}}}}}@
|
||||||
|
|
||||||
|
# first a list of warnings from the chosen set
|
||||||
|
_warnings = ${WARNINGS_SET_${MACHINE_ARCH}:U${WARNINGS_SET}:${M_warnings_list}}
|
||||||
|
# now a list of all -Wno-* overrides not just those defined by WARNINGS_SET
|
||||||
|
# since things like -Wall imply lots of others.
|
||||||
|
# this should be a super-set of the -Wno-* in _warnings, but
|
||||||
|
# just in case...
|
||||||
|
_no_warnings = ${_warnings:M-Wno-*} ${ALL_WARNINGS_SETS:${M_warnings_list}:M-Wno-*}
|
||||||
|
# -Wno-* must follow any others
|
||||||
|
WARNINGS += ${_warnings:N-Wno-*} ${_no_warnings:O:u}
|
||||||
|
|
||||||
.ifndef NO_CFLAGS_WARNINGS
|
.ifndef NO_CFLAGS_WARNINGS
|
||||||
# Just ${WARNINGS} should do, but this is more flexible?
|
# Just ${WARNINGS} should do, but this is more flexible?
|
||||||
@ -137,9 +119,10 @@ NO_CXX_WARNINGS+= \
|
|||||||
missing-declarations \
|
missing-declarations \
|
||||||
missing-prototypes \
|
missing-prototypes \
|
||||||
nested-externs \
|
nested-externs \
|
||||||
|
shadow \
|
||||||
strict-prototypes
|
strict-prototypes
|
||||||
|
|
||||||
.for s in ${SRCS:M*.cc}
|
.for s in ${SRCS:M*.c*:N*.c:N*h}
|
||||||
.for w in ${NO_CXX_WARNINGS}
|
.for w in ${NO_CXX_WARNINGS}
|
||||||
W_$w_${s:T:R}.o=
|
W_$w_${s:T:R}.o=
|
||||||
.endfor
|
.endfor
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
# Simon J. Gerraty <sjg@crufty.net>
|
# Simon J. Gerraty <sjg@crufty.net>
|
||||||
|
|
||||||
# RCSid:
|
# RCSid:
|
||||||
# $Id: os.sh,v 1.44 2010/06/29 15:37:21 sjg Exp $
|
# $Id: os.sh,v 1.46 2014/05/19 16:38:09 sjg Exp $
|
||||||
#
|
#
|
||||||
# @(#) Copyright (c) 1994 Simon J. Gerraty
|
# @(#) Copyright (c) 1994 Simon J. Gerraty
|
||||||
#
|
#
|
||||||
@ -128,11 +128,13 @@ SunOS)
|
|||||||
K=-k
|
K=-k
|
||||||
MAILER=/usr/bin/Mail
|
MAILER=/usr/bin/Mail
|
||||||
LOCAL_FS=local
|
LOCAL_FS=local
|
||||||
case "$-" in
|
: $-,$ENV
|
||||||
*i*) ;;
|
case "$-,$ENV" in
|
||||||
|
*i*,*) ;;
|
||||||
|
*,|*ENVFILE*) ;;
|
||||||
*) ENV=;;
|
*) ENV=;;
|
||||||
esac
|
esac
|
||||||
# NetBSD at least has good backward compatability
|
# NetBSD at least has good backward compatibility
|
||||||
# so NetBSD/i386 is good enough
|
# so NetBSD/i386 is good enough
|
||||||
case $OS in
|
case $OS in
|
||||||
NetBSD) SHARE_ARCH=$OS/${MACHINE_ARCH:-$MACHINE};;
|
NetBSD) SHARE_ARCH=$OS/${MACHINE_ARCH:-$MACHINE};;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: parse.c,v 1.192 2013/10/18 20:47:06 christos Exp $ */
|
/* $NetBSD: parse.c,v 1.194 2014/02/15 00:17:17 christos Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1988, 1989, 1990, 1993
|
* Copyright (c) 1988, 1989, 1990, 1993
|
||||||
@ -69,14 +69,14 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef MAKE_NATIVE
|
#ifndef MAKE_NATIVE
|
||||||
static char rcsid[] = "$NetBSD: parse.c,v 1.192 2013/10/18 20:47:06 christos Exp $";
|
static char rcsid[] = "$NetBSD: parse.c,v 1.194 2014/02/15 00:17:17 christos Exp $";
|
||||||
#else
|
#else
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
#ifndef lint
|
#ifndef lint
|
||||||
#if 0
|
#if 0
|
||||||
static char sccsid[] = "@(#)parse.c 8.3 (Berkeley) 3/19/94";
|
static char sccsid[] = "@(#)parse.c 8.3 (Berkeley) 3/19/94";
|
||||||
#else
|
#else
|
||||||
__RCSID("$NetBSD: parse.c,v 1.192 2013/10/18 20:47:06 christos Exp $");
|
__RCSID("$NetBSD: parse.c,v 1.194 2014/02/15 00:17:17 christos Exp $");
|
||||||
#endif
|
#endif
|
||||||
#endif /* not lint */
|
#endif /* not lint */
|
||||||
#endif
|
#endif
|
||||||
@ -364,6 +364,7 @@ static int ParseAddCmd(void *, void *);
|
|||||||
static void ParseHasCommands(void *);
|
static void ParseHasCommands(void *);
|
||||||
static void ParseDoInclude(char *);
|
static void ParseDoInclude(char *);
|
||||||
static void ParseSetParseFile(const char *);
|
static void ParseSetParseFile(const char *);
|
||||||
|
static void ParseSetIncludedFile(void);
|
||||||
#ifdef SYSVINCLUDE
|
#ifdef SYSVINCLUDE
|
||||||
static void ParseTraditionalInclude(char *);
|
static void ParseTraditionalInclude(char *);
|
||||||
#endif
|
#endif
|
||||||
@ -855,7 +856,8 @@ ParseLinkSrc(void *pgnp, void *cgnp)
|
|||||||
(void)Lst_AtEnd(cgn->parents, pgn);
|
(void)Lst_AtEnd(cgn->parents, pgn);
|
||||||
pgn->unmade += 1;
|
pgn->unmade += 1;
|
||||||
if (DEBUG(PARSE)) {
|
if (DEBUG(PARSE)) {
|
||||||
fprintf(debug_file, "# ParseLinkSrc: added child %s - %s\n", pgn->name, cgn->name);
|
fprintf(debug_file, "# %s: added child %s - %s\n", __func__,
|
||||||
|
pgn->name, cgn->name);
|
||||||
Targ_PrintNode(pgn, 0);
|
Targ_PrintNode(pgn, 0);
|
||||||
Targ_PrintNode(cgn, 0);
|
Targ_PrintNode(cgn, 0);
|
||||||
}
|
}
|
||||||
@ -1030,8 +1032,8 @@ ParseDoSrc(int tOp, const char *src)
|
|||||||
(void)Lst_AtEnd(predecessor->order_succ, gn);
|
(void)Lst_AtEnd(predecessor->order_succ, gn);
|
||||||
(void)Lst_AtEnd(gn->order_pred, predecessor);
|
(void)Lst_AtEnd(gn->order_pred, predecessor);
|
||||||
if (DEBUG(PARSE)) {
|
if (DEBUG(PARSE)) {
|
||||||
fprintf(debug_file, "# ParseDoSrc: added Order dependency %s - %s\n",
|
fprintf(debug_file, "# %s: added Order dependency %s - %s\n",
|
||||||
predecessor->name, gn->name);
|
__func__, predecessor->name, gn->name);
|
||||||
Targ_PrintNode(predecessor, 0);
|
Targ_PrintNode(predecessor, 0);
|
||||||
Targ_PrintNode(gn, 0);
|
Targ_PrintNode(gn, 0);
|
||||||
}
|
}
|
||||||
@ -2174,6 +2176,7 @@ Parse_include_file(char *file, Boolean isSystem, int silent)
|
|||||||
/* load it */
|
/* load it */
|
||||||
lf = loadfile(fullname, fd);
|
lf = loadfile(fullname, fd);
|
||||||
|
|
||||||
|
ParseSetIncludedFile();
|
||||||
/* Start reading from this file next */
|
/* Start reading from this file next */
|
||||||
Parse_SetInput(fullname, 0, -1, loadedfile_nextbuf, lf);
|
Parse_SetInput(fullname, 0, -1, loadedfile_nextbuf, lf);
|
||||||
curFile->lf = lf;
|
curFile->lf = lf;
|
||||||
@ -2231,6 +2234,41 @@ ParseDoInclude(char *line)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*-
|
||||||
|
*---------------------------------------------------------------------
|
||||||
|
* ParseSetIncludedFile --
|
||||||
|
* Set the .INCLUDEDFROMFILE variable to the contents of .PARSEFILE
|
||||||
|
* and the .INCLUDEDFROMDIR variable to the contents of .PARSEDIR
|
||||||
|
*
|
||||||
|
* Results:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Side Effects:
|
||||||
|
* The .INCLUDEDFROMFILE variable is overwritten by the contents
|
||||||
|
* of .PARSEFILE and the .INCLUDEDFROMDIR variable is overwriten
|
||||||
|
* by the contents of .PARSEDIR
|
||||||
|
*---------------------------------------------------------------------
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
ParseSetIncludedFile(void)
|
||||||
|
{
|
||||||
|
char *pf, *fp = NULL;
|
||||||
|
char *pd, *dp = NULL;
|
||||||
|
|
||||||
|
pf = Var_Value(".PARSEFILE", VAR_GLOBAL, &fp);
|
||||||
|
Var_Set(".INCLUDEDFROMFILE", pf, VAR_GLOBAL, 0);
|
||||||
|
pd = Var_Value(".PARSEDIR", VAR_GLOBAL, &dp);
|
||||||
|
Var_Set(".INCLUDEDFROMDIR", pd, VAR_GLOBAL, 0);
|
||||||
|
|
||||||
|
if (DEBUG(PARSE))
|
||||||
|
fprintf(debug_file, "%s: ${.INCLUDEDFROMDIR} = `%s' "
|
||||||
|
"${.INCLUDEDFROMFILE} = `%s'\n", __func__, pd, pf);
|
||||||
|
|
||||||
|
if (fp)
|
||||||
|
free(fp);
|
||||||
|
if (dp)
|
||||||
|
free(dp);
|
||||||
|
}
|
||||||
/*-
|
/*-
|
||||||
*---------------------------------------------------------------------
|
*---------------------------------------------------------------------
|
||||||
* ParseSetParseFile --
|
* ParseSetParseFile --
|
||||||
@ -2266,8 +2304,8 @@ ParseSetParseFile(const char *filename)
|
|||||||
Var_Set(".PARSEFILE", pf = slash + 1, VAR_GLOBAL, 0);
|
Var_Set(".PARSEFILE", pf = slash + 1, VAR_GLOBAL, 0);
|
||||||
}
|
}
|
||||||
if (DEBUG(PARSE))
|
if (DEBUG(PARSE))
|
||||||
fprintf(debug_file, "ParseSetParseFile: ${.PARSEDIR} = `%s' "
|
fprintf(debug_file, "%s: ${.PARSEDIR} = `%s' ${.PARSEFILE} = `%s'\n",
|
||||||
"${.PARSEFILE} = `%s'\n", pd, pf);
|
__func__, pd, pf);
|
||||||
free(dirname);
|
free(dirname);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2329,8 +2367,8 @@ Parse_SetInput(const char *name, int line, int fd,
|
|||||||
ParseTrackInput(name);
|
ParseTrackInput(name);
|
||||||
|
|
||||||
if (DEBUG(PARSE))
|
if (DEBUG(PARSE))
|
||||||
fprintf(debug_file, "Parse_SetInput: file %s, line %d, fd %d, nextbuf %p, arg %p\n",
|
fprintf(debug_file, "%s: file %s, line %d, fd %d, nextbuf %p, arg %p\n",
|
||||||
name, line, fd, nextbuf, arg);
|
__func__, name, line, fd, nextbuf, arg);
|
||||||
|
|
||||||
if (fd == -1 && nextbuf == NULL)
|
if (fd == -1 && nextbuf == NULL)
|
||||||
/* sanity */
|
/* sanity */
|
||||||
@ -2402,7 +2440,7 @@ ParseTraditionalInclude(char *line)
|
|||||||
char *all_files;
|
char *all_files;
|
||||||
|
|
||||||
if (DEBUG(PARSE)) {
|
if (DEBUG(PARSE)) {
|
||||||
fprintf(debug_file, "ParseTraditionalInclude: %s\n", file);
|
fprintf(debug_file, "%s: %s\n", __func__, file);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2461,7 +2499,7 @@ ParseGmakeExport(char *line)
|
|||||||
char *value;
|
char *value;
|
||||||
|
|
||||||
if (DEBUG(PARSE)) {
|
if (DEBUG(PARSE)) {
|
||||||
fprintf(debug_file, "ParseGmakeExport: %s\n", variable);
|
fprintf(debug_file, "%s: %s\n", __func__, variable);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2541,6 +2579,8 @@ ParseEOF(void)
|
|||||||
/* We've run out of input */
|
/* We've run out of input */
|
||||||
Var_Delete(".PARSEDIR", VAR_GLOBAL);
|
Var_Delete(".PARSEDIR", VAR_GLOBAL);
|
||||||
Var_Delete(".PARSEFILE", VAR_GLOBAL);
|
Var_Delete(".PARSEFILE", VAR_GLOBAL);
|
||||||
|
Var_Delete(".INCLUDEDFROMDIR", VAR_GLOBAL);
|
||||||
|
Var_Delete(".INCLUDEDFROMFILE", VAR_GLOBAL);
|
||||||
return DONE;
|
return DONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: str.c,v 1.34 2012/03/03 23:16:47 dholland Exp $ */
|
/* $NetBSD: str.c,v 1.35 2014/02/12 01:35:56 sjg Exp $ */
|
||||||
|
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1988, 1989, 1990, 1993
|
* Copyright (c) 1988, 1989, 1990, 1993
|
||||||
@ -69,14 +69,14 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef MAKE_NATIVE
|
#ifndef MAKE_NATIVE
|
||||||
static char rcsid[] = "$NetBSD: str.c,v 1.34 2012/03/03 23:16:47 dholland Exp $";
|
static char rcsid[] = "$NetBSD: str.c,v 1.35 2014/02/12 01:35:56 sjg Exp $";
|
||||||
#else
|
#else
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
#ifndef lint
|
#ifndef lint
|
||||||
#if 0
|
#if 0
|
||||||
static char sccsid[] = "@(#)str.c 5.8 (Berkeley) 6/1/90";
|
static char sccsid[] = "@(#)str.c 5.8 (Berkeley) 6/1/90";
|
||||||
#else
|
#else
|
||||||
__RCSID("$NetBSD: str.c,v 1.34 2012/03/03 23:16:47 dholland Exp $");
|
__RCSID("$NetBSD: str.c,v 1.35 2014/02/12 01:35:56 sjg Exp $");
|
||||||
#endif
|
#endif
|
||||||
#endif /* not lint */
|
#endif /* not lint */
|
||||||
#endif
|
#endif
|
||||||
@ -145,7 +145,7 @@ brk_string(const char *str, int *store_argc, Boolean expand, char **buffer)
|
|||||||
const char *p;
|
const char *p;
|
||||||
int len;
|
int len;
|
||||||
int argmax = 50, curlen = 0;
|
int argmax = 50, curlen = 0;
|
||||||
char **argv = bmake_malloc((argmax + 1) * sizeof(char *));
|
char **argv;
|
||||||
|
|
||||||
/* skip leading space chars. */
|
/* skip leading space chars. */
|
||||||
for (; *str == ' ' || *str == '\t'; ++str)
|
for (; *str == ' ' || *str == '\t'; ++str)
|
||||||
@ -155,6 +155,12 @@ brk_string(const char *str, int *store_argc, Boolean expand, char **buffer)
|
|||||||
if ((len = strlen(str) + 1) > curlen)
|
if ((len = strlen(str) + 1) > curlen)
|
||||||
*buffer = bmake_malloc(curlen = len);
|
*buffer = bmake_malloc(curlen = len);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* initial argmax based on len
|
||||||
|
*/
|
||||||
|
argmax = MAX((len / 5), 50);
|
||||||
|
argv = bmake_malloc((argmax + 1) * sizeof(char *));
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* copy the string; at the same time, parse backslashes,
|
* copy the string; at the same time, parse backslashes,
|
||||||
* quotes and build the argument list.
|
* quotes and build the argument list.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: var.c,v 1.184 2013/09/04 15:38:26 sjg Exp $ */
|
/* $NetBSD: var.c,v 1.186 2014/06/20 06:13:45 sjg Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1988, 1989, 1990, 1993
|
* Copyright (c) 1988, 1989, 1990, 1993
|
||||||
@ -69,14 +69,14 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef MAKE_NATIVE
|
#ifndef MAKE_NATIVE
|
||||||
static char rcsid[] = "$NetBSD: var.c,v 1.184 2013/09/04 15:38:26 sjg Exp $";
|
static char rcsid[] = "$NetBSD: var.c,v 1.186 2014/06/20 06:13:45 sjg Exp $";
|
||||||
#else
|
#else
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
#ifndef lint
|
#ifndef lint
|
||||||
#if 0
|
#if 0
|
||||||
static char sccsid[] = "@(#)var.c 8.3 (Berkeley) 3/19/94";
|
static char sccsid[] = "@(#)var.c 8.3 (Berkeley) 3/19/94";
|
||||||
#else
|
#else
|
||||||
__RCSID("$NetBSD: var.c,v 1.184 2013/09/04 15:38:26 sjg Exp $");
|
__RCSID("$NetBSD: var.c,v 1.186 2014/06/20 06:13:45 sjg Exp $");
|
||||||
#endif
|
#endif
|
||||||
#endif /* not lint */
|
#endif /* not lint */
|
||||||
#endif
|
#endif
|
||||||
@ -2637,7 +2637,7 @@ ApplyModifiers(char *nstr, const char *tstr,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
free(UNCONST(pattern.rhs));
|
free(UNCONST(pattern.rhs));
|
||||||
newStr = var_Error;
|
newStr = varNoError;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
goto default_case; /* "::<unrecognised>" */
|
goto default_case; /* "::<unrecognised>" */
|
||||||
@ -3661,6 +3661,7 @@ Var_Parse(const char *str, GNode *ctxt, Boolean errnum, int *lengthPtr,
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Buffer buf; /* Holds the variable name */
|
Buffer buf; /* Holds the variable name */
|
||||||
|
int depth = 1;
|
||||||
|
|
||||||
endc = startc == PROPEN ? PRCLOSE : BRCLOSE;
|
endc = startc == PROPEN ? PRCLOSE : BRCLOSE;
|
||||||
Buf_Init(&buf, 0);
|
Buf_Init(&buf, 0);
|
||||||
@ -3668,10 +3669,21 @@ Var_Parse(const char *str, GNode *ctxt, Boolean errnum, int *lengthPtr,
|
|||||||
/*
|
/*
|
||||||
* Skip to the end character or a colon, whichever comes first.
|
* Skip to the end character or a colon, whichever comes first.
|
||||||
*/
|
*/
|
||||||
for (tstr = str + 2;
|
for (tstr = str + 2; *tstr != '\0'; tstr++)
|
||||||
*tstr != '\0' && *tstr != endc && *tstr != ':';
|
|
||||||
tstr++)
|
|
||||||
{
|
{
|
||||||
|
/*
|
||||||
|
* Track depth so we can spot parse errors.
|
||||||
|
*/
|
||||||
|
if (*tstr == startc) {
|
||||||
|
depth++;
|
||||||
|
}
|
||||||
|
if (*tstr == endc) {
|
||||||
|
if (--depth == 0)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (depth == 1 && *tstr == ':') {
|
||||||
|
break;
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
* A variable inside a variable, expand
|
* A variable inside a variable, expand
|
||||||
*/
|
*/
|
||||||
@ -3691,7 +3703,7 @@ Var_Parse(const char *str, GNode *ctxt, Boolean errnum, int *lengthPtr,
|
|||||||
}
|
}
|
||||||
if (*tstr == ':') {
|
if (*tstr == ':') {
|
||||||
haveModifier = TRUE;
|
haveModifier = TRUE;
|
||||||
} else if (*tstr != '\0') {
|
} else if (*tstr == endc) {
|
||||||
haveModifier = FALSE;
|
haveModifier = FALSE;
|
||||||
} else {
|
} else {
|
||||||
/*
|
/*
|
||||||
@ -4041,7 +4053,7 @@ Var_Subst(const char *var, const char *str, GNode *ctxt, Boolean undefErr)
|
|||||||
*/
|
*/
|
||||||
if (oldVars) {
|
if (oldVars) {
|
||||||
str += length;
|
str += length;
|
||||||
} else if (undefErr) {
|
} else if (undefErr || val == var_Error) {
|
||||||
/*
|
/*
|
||||||
* If variable is undefined, complain and skip the
|
* If variable is undefined, complain and skip the
|
||||||
* variable. The complaint will stop us from doing anything
|
* variable. The complaint will stop us from doing anything
|
||||||
|
@ -14,10 +14,10 @@ CFLAGS+= -I${.CURDIR}
|
|||||||
CLEANDIRS+= FreeBSD
|
CLEANDIRS+= FreeBSD
|
||||||
CLEANFILES+= bootstrap
|
CLEANFILES+= bootstrap
|
||||||
|
|
||||||
# $Id: Makefile,v 1.23 2014/01/02 22:20:52 sjg Exp $
|
# $Id: Makefile,v 1.27 2014/06/20 14:51:54 sjg Exp $
|
||||||
|
|
||||||
# Base version on src date
|
# Base version on src date
|
||||||
MAKE_VERSION= 20140101
|
MAKE_VERSION= 20140620
|
||||||
|
|
||||||
PROG?= ${.CURDIR:T}
|
PROG?= ${.CURDIR:T}
|
||||||
|
|
||||||
@ -106,6 +106,7 @@ COPTS.meta.c += -DHAVE_FILEMON_H -I${FILEMON_H:H}
|
|||||||
SUBDIR+= unit-tests
|
SUBDIR+= unit-tests
|
||||||
.endif
|
.endif
|
||||||
|
|
||||||
|
|
||||||
MAN= ${PROG}.1
|
MAN= ${PROG}.1
|
||||||
MAN1= ${MAN}
|
MAN1= ${MAN}
|
||||||
|
|
||||||
|
@ -146,6 +146,9 @@
|
|||||||
`HAVE_STRUCT_STAT_ST_RDEV' instead. */
|
`HAVE_STRUCT_STAT_ST_RDEV' instead. */
|
||||||
#define HAVE_ST_RDEV 1
|
#define HAVE_ST_RDEV 1
|
||||||
|
|
||||||
|
/* Define to 1 if you have the `sysctl' function. */
|
||||||
|
#define HAVE_SYSCTL 1
|
||||||
|
|
||||||
/* 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 */
|
||||||
@ -166,6 +169,9 @@
|
|||||||
/* Define to 1 if you have the <sys/stat.h> header file. */
|
/* Define to 1 if you have the <sys/stat.h> header file. */
|
||||||
#define HAVE_SYS_STAT_H 1
|
#define HAVE_SYS_STAT_H 1
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <sys/sysctl.h> header file. */
|
||||||
|
#define HAVE_SYS_SYSCTL_H 1
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/time.h> header file. */
|
/* Define to 1 if you have the <sys/time.h> header file. */
|
||||||
#define HAVE_SYS_TIME_H 1
|
#define HAVE_SYS_TIME_H 1
|
||||||
|
|
||||||
@ -230,7 +236,7 @@
|
|||||||
#define PACKAGE_NAME "bmake"
|
#define PACKAGE_NAME "bmake"
|
||||||
|
|
||||||
/* Define to the full name and version of this package. */
|
/* Define to the full name and version of this package. */
|
||||||
#define PACKAGE_STRING "bmake 20140101"
|
#define PACKAGE_STRING "bmake 20140214"
|
||||||
|
|
||||||
/* Define to the one symbol short name of this package. */
|
/* Define to the one symbol short name of this package. */
|
||||||
#define PACKAGE_TARNAME "bmake"
|
#define PACKAGE_TARNAME "bmake"
|
||||||
@ -239,7 +245,7 @@
|
|||||||
#define PACKAGE_URL ""
|
#define PACKAGE_URL ""
|
||||||
|
|
||||||
/* Define to the version of this package. */
|
/* Define to the version of this package. */
|
||||||
#define PACKAGE_VERSION "20140101"
|
#define PACKAGE_VERSION "20140214"
|
||||||
|
|
||||||
/* 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
|
||||||
@ -300,6 +306,9 @@
|
|||||||
/* 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 */
|
||||||
|
|
||||||
|
/* C99 function name */
|
||||||
|
/* #undef __func__ */
|
||||||
|
|
||||||
/* 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 */
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user