No description
Find a file
Paul Smith 971b02d58e tests: Run each file in a separate directory
Avoid cross-contamination between test files by creating a new
working directory for each file, and setting it as the current
directory before starting the tests in that file.

Rename the test output as tNNN.{base,log,diff,mk} where NNN is
a test number starting with 001 for the first test.  It is
slightly more annoying to find diff files since you can't use
autocomplete directly but it is simpler to match things.

Detect the source directory as the location of the test_driver.pl
script, so remove the separate -srcdir option.

* Makefile.am: Remove hacks to create symlinks when building
out-of-tree, and remove -srcdir option from run_make_tests.
* tests/test_driver.pl: Locate $srcpath based on __FILE__, then
compute $toppath as its parent.  Set $scriptpath under $srcpath
and $workpath under the current directory.  Toss $*_filename
and modify get_logfile() etc. to use the suffix directly.  Add
a chdir() around the invocation of the test.
* tests/run_make_tests.pl: Throw out the -srcdir option and use
$srcpath set in test_driver.pl.  The #WORK# helper is no longer
useful so remove it.  Set #PWD# to the current working dir. Always
search the local directory and $srcpath for config-flags.pm.
Use $srcpath for finding the thelp.pl script.
* tests/scripts/features/vpath: Don't put things in work/ as it
is no longer a subdirectory.
* tests/scripts/features/vpathgpath: Ditto.
* tests/scripts/features/vpathplus: Ditto.
* tests/scripts/misc/general1: Ditto.
* tests/scripts/misc/general2: Ditto.
* tests/scripts/options/dash-k: Ditto.
* tests/scripts/options/symlinks: Use $testpath as the working
directory.
* tests/scripts/variables/GNUMAKEFLAGS: Use the test helper to
display env var values (grepping for GNUMAKEFLAGS finds extra things
now that it is our current working directory).
2023-04-02 17:32:09 -04:00
doc * doc/make.texi: Clean up function and variable references 2023-04-02 10:02:18 -04:00
gl Use MK_OS_DOS macro instead of __MSDOS__ 2023-01-16 00:03:13 -05:00
mk Rename WINDOWS32 macro to MK_OS_W32 2023-01-15 18:27:13 -05:00
po Add support for .WARNINGS special variable 2023-04-02 10:02:18 -04:00
scripts Convert references from "GNU make" to "GNU Make" 2023-01-01 17:05:12 -05:00
src [SV 63856] Fix pruning of double-colon rules 2023-04-02 11:12:19 -04:00
tests tests: Run each file in a separate directory 2023-04-02 17:32:09 -04:00
.ccls
.dir-locals.el
.gitignore Make bootstrap.bat more portable 2022-12-26 13:10:26 -05:00
AUTHORS Remove support for AmigaOS 2023-01-15 17:32:15 -05:00
autogen.sh Update to the latest gnulib stable branch 2023-01-01 17:05:12 -05:00
autopull.sh Update to the latest gnulib stable branch 2023-01-01 17:05:12 -05:00
Basic.mk.template Remove support for AmigaOS 2023-01-15 17:32:15 -05:00
bootstrap Update to the latest gnulib stable branch 2023-01-01 17:05:12 -05:00
bootstrap-funclib.sh Update to the latest gnulib stable branch 2023-01-01 17:05:12 -05:00
bootstrap.bat Convert references from "GNU make" to "GNU Make" 2023-01-01 17:05:12 -05:00
bootstrap.conf Update to the latest gnulib stable branch 2023-01-01 17:05:12 -05:00
build.cfg.in Update the copyright year on all files 2023-01-01 10:06:01 -05:00
build.sh [SV 62654] Support GNU Make on z/OS 2023-01-08 10:45:38 -05:00
build_w32.bat Add support for .WARNINGS special variable 2023-04-02 10:02:18 -04:00
builddos.bat Add support for .WARNINGS special variable 2023-04-02 10:02:18 -04: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 Rename WINDOWS32 macro to MK_OS_W32 2023-01-15 18:27:13 -05:00
COPYING
maintMakefile Remove support for AmigaOS 2023-01-15 17:32:15 -05:00
make-gdb.py * NEWS: Use GNU Make instead of GNU make 2022-10-18 14:37:47 -04:00
Makefile.am tests: Run each file in a separate directory 2023-04-02 17:32:09 -04:00
makefile.com Update the copyright year on all files 2023-01-01 10:06:01 -05:00
NEWS * NEWS: Mention the new .WARNINGS variable 2023-04-02 10:29:19 -04:00
prepare_vms.com
README.customs Update the copyright year on all files 2023-01-01 10:06:01 -05:00
README.DOS Update the copyright year on all files 2023-01-01 10:06:01 -05:00
README.git * README.git: Clarify some release steps 2023-02-26 15:52:25 -05:00
README.in Remove support for AmigaOS 2023-01-15 17:32:15 -05:00
README.OS2 Update support for OS/2 2023-01-08 18:44:25 -05:00
README.VMS * NEWS: Use GNU Make instead of GNU make 2022-10-18 14:37:47 -04:00
README.W32 * README.W32: Add Windows 11 2023-02-21 20:54:48 -05:00
README.zOS [SV 62654] Support GNU Make on z/OS 2023-01-08 10:45:38 -05:00
TODO.private Update the copyright year on all files 2023-01-01 10:06:01 -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.