No description
Find a file
Dmitry Goncharov 07187db947 [SV 64822, SV 36486] Fix appending to a pattern specific variable
Appending to a pattern specific variable produces an incorrect value
in the presence of a command line definition or an env override of
the variable.  Also, fix pattern/target-specific appending to a
variable with origin override.

* At parse time record_target_var sets the value of a pattern
  specific variable to the value defined on command line or to the
  value of the env override.
* Later, at build time, recursively_expand_for_file appends this
  value of the variable (set in record_target_var) to the command
  line value again, regardless of the origin of the variable.

This patch modifies recursively_expand_for_file to avoid appending,
unless the origin of the variable beats or equals the origin of one
of the parent definitions of this variable.

Reported by Rob <robw9739@gmail.com>,
Brian Vandenberg <phantall@gmail.com>,
Markus Oberhumer <markus@oberhumer.com>.

* NEWS: Note the change.
* src/variable.c (do_variable_definition): Avoid merging a
pattern-specific variable with the parent definition when a command
line or env override is present.
* src/expand.c (recursively_expand_for_file): Avoid appending to a
pattern-specific variable, unless the origin of this pattern-specific
variable beats or equals the origin of one of the parent definitions
of this variable.
* doc/make.texi (Override Directive): Add missing cross-reference.
* tests/scripts/variables/append: Add tests.
2024-02-04 18:26:21 -05:00
doc [SV 64822, SV 36486] Fix appending to a pattern specific variable 2024-02-04 18:26:21 -05:00
gl * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
mk * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
po * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
scripts * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
src [SV 64822, SV 36486] Fix appending to a pattern specific variable 2024-02-04 18:26:21 -05:00
tests [SV 64822, SV 36486] Fix appending to a pattern specific variable 2024-02-04 18:26:21 -05:00
.ccls * .clangd: Add configuration for the clangd LSP server 2024-01-01 19:24:37 -05:00
.clangd * .clangd: Add configuration for the clangd LSP server 2024-01-01 19:24:37 -05:00
.dir-locals.el * .dir-locals.el: Update for newer LSP config 2021-03-07 19:04:48 -05:00
.gitignore Add a UTF-8 resource when building for Windows 2023-06-19 13:29:52 -04:00
AUTHORS * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
autogen.sh * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
autopull.sh * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
Basic.mk.template * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
bootstrap Update to the latest gnulib stable branch 2023-01-01 17:05:12 -05:00
bootstrap-funclib.sh * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
bootstrap.bat * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
bootstrap.conf * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
build.cfg.in * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
build.sh * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
build_w32.bat * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
builddos.bat * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
ChangeLog.1 Update URLs to use https rather than http 2022-10-18 14:37:47 -04:00
ChangeLog.2 Update URLs to use https rather than http 2022-10-18 14:37:47 -04:00
ChangeLog.3 Update URLs to use https rather than http 2022-10-18 14:37:47 -04:00
configure.ac * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
COPYING Change HTTP URLs to use HTTPS instead 2021-12-19 16:55:50 -05:00
maintMakefile * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
make-gdb.py * NEWS: Use GNU Make instead of GNU make 2022-10-18 14:37:47 -04:00
Makefile.am * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
makefile.com * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
NEWS [SV 64822, SV 36486] Fix appending to a pattern specific variable 2024-02-04 18:26:21 -05:00
prepare_vms.com Remove template files to simplify distribution creation 2022-10-18 14:20:44 -04:00
README.customs * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
README.DOS * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
README.git Create a common method for skipping variable references 2024-01-27 16:40:36 -05:00
README.in * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
README.OS2 * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
README.VMS * NEWS: Use GNU Make instead of GNU make 2022-10-18 14:37:47 -04:00
README.W32 * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
README.zOS [SV 62654] Support GNU Make on z/OS 2023-01-08 10:45:38 -05:00
TODO.private * (all): Update Copyright year to 2024 2024-01-06 18:06:09 -05:00
vms_export_symbol_test.com

                                                                     -*-text-*-
GNU Make has been ported to z/OS, tested on z/OS V2R4.


PREREQUISITES
-------------
Building GNU Make requires certain tools be installed on your z/OS system.
These tools can be downloaded from: https://github.com/ZOSOpenTools
For detailed instructions on how to set up these tools, visit
https://zosopentools.github.io/meta/#/Guides/Pre-req

You will need curl, tar, and gzip to download and unpack the GNU Make release
package, but presumably you've already worked this out if you're reading this
document!

You will need the IBM C/C++ compiler.  You can download a web deliverable
add-on feature to your XL C/C++ compiler here:
https://www-40.ibm.com/servers/resourcelink/svc00100.nsf/pages/xlCC++V241ForZOsV24

Alternatively, you can install and manage C/C++ for Open Enterprise Languages
on z/OS using RedHat OpenShift Container Platform and IBM Z and Cloud
Modernization Stack.

GNU Make has a dependency on the ZOSLIB library, which is documented here:
https://zosopentools.github.io/meta/#/Guides/Zoslib.

To obtain the latest release of zoslib, you can download it from here:
https://github.com/ZOSOpenTools/zoslibport/releases.


BUILDING
--------
If you are trying to build from a checked-out Git workspace, see README.git.

Before building GNU Make, you will need to ensure that the following
environment variables are set, to turn on z/OS enhanced ASCII support:

  export _BPXK_AUTOCVT=ON
  export _CEE_RUNOPTS="$_CEE_RUNOPTS FILETAG(AUTOCVT,AUTOTAG) POSIX(ON)"
  export _TAG_REDIR_ERR=txt
  export _TAG_REDIR_IN=txt
  export _TAG_REDIR_OUT=txt

To ensure proper functioning of xlclang, set the following environment
variables before building:

  export _CC_CCMODE=1
  export _C89_CCMODE=1
  export _CXX_CCMODE=1

Set PATH_TO_ZOSLIB to the location of your zoslib installation; e.g.:

  PATH_TO_ZOSLIB=$HOME/zopen/prod/zoslib

Invoke ./configure as follows:

  ./configure \
      CC=xlclang \
      CPPFLAGS="-DNSIG=42 -D_XOPEN_SOURCE=600 -D_ALL_SOURCE -D_OPEN_SYS_FILE_EXT=1 -D_AE_BIMODAL=1 -D_ENHANCED_ASCII_EXT=0xFFFFFFF -DZOSLIB_OVERRIDE_CLIB=1" \
      CFLAGS="-qascii -std=gnu11 -qnocsect -qenum=int -I$PATH_TO_ZOSLIB/include" \
      LDFLAGS="-L$PATH_TO_ZOSLIB/lib" \
      LIBS="-lzoslib $PATH_TO_ZOSLIB/lib/CXXRT64.x"

If you have an instance of make already available you can build with:

  make

If not, you can build with:

  ./build.sh


TESTING
-------
To run the regression tests you'll need to install Perl and enable it.
Then you can run:

  ./make check


INSTALLING
----------
Copy the "make" program to wherever you want it to be installed, on your PATH.