diff options
| author | Mohammad Akhlaghi <mohammad@akhlaghi.org> | 2024-05-03 13:07:41 +0200 | 
|---|---|---|
| committer | Mohammad Akhlaghi <mohammad@akhlaghi.org> | 2025-02-10 19:34:26 +0100 | 
| commit | 3c9bf3aff30f02c7d31bd86f36c4db2520f8ffa4 (patch) | |
| tree | c4b6ee74518ae5256626f6888c2ceccfa66ce2a2 /reproduce/software/shell/pre-make-build.sh | |
| parent | 8161194d68665648b93389adb333e741ba230497 (diff) | |
Configuration: no dependency on /bin/sh and useful run-time options
SUMMARY: no change necessary in your project, this commit only involves
changes in how already-existing software are built. Some handy options have
also been added to the top-level project script and the copyright years
have been updated.
Until now, if the host's '/bin/sh' had conflicts with the Maneage
environment, the configuration of Maneage would crash as soon as we entered
the building of high-level software. The full scenario is described in the
comments of the newly added 'reproduce/software/shell/prep-source.sh'. This
is most relevant when building older Maneage'd project in newer
environments.
With this commit, the following changes were made to avoid the problem
above:
  - Maneage edits the source code of all installed software to replace
    '/bin/sh' with Maneage's own shell before the programs are
    built. Through this, we were able to solve the problem described
    above.
  - The portable '#!/usr/bin/env sh' shebangs are now used at the start of
    the scripts that run during configure time so it uses the first
    available shell that it finds in its PATH (the system's before Dash is
    built), then Dash, and after Dash is built, Bash.
  - For TeXLive, since we don't install it from source, it was necessary to
    add the libraries necessary for the local '/bin/sh' in LD_LIBRARY_PATH.
Some high-level options have been added to the './project' script to
simplify certain operations:
  --keep-going: do not stop upon the first crash, but keep going on to
    build targets until all build-able targets have been built. This is
    very useful for debugging large pipelines and allows you to isolate the
    problematic part of your project.
  --highlight-all: equivalent to calling both '--highlight-new' &
    '--highlight-notes'.
Diffstat (limited to 'reproduce/software/shell/pre-make-build.sh')
| -rwxr-xr-x | reproduce/software/shell/pre-make-build.sh | 24 | 
1 files changed, 16 insertions, 8 deletions
| diff --git a/reproduce/software/shell/pre-make-build.sh b/reproduce/software/shell/pre-make-build.sh index 808429b..93d3266 100755 --- a/reproduce/software/shell/pre-make-build.sh +++ b/reproduce/software/shell/pre-make-build.sh @@ -2,7 +2,7 @@  #  # Very basic tools necessary to start Maneage's default building.  # -# Copyright (C) 2020-2023 Mohammad Akhlaghi <mohammad@akhlaghi.org> +# Copyright (C) 2020-2025 Mohammad Akhlaghi <mohammad@akhlaghi.org>  #  # This script is free software: you can redistribute it and/or modify  # it under the terms of the GNU General Public License as published by @@ -48,7 +48,7 @@ instdir="$sdir"/installed  tmpblddir="$sdir"/build-tmp  confdir=reproduce/software/config  ibidir="$instdir"/version-info/proglib -downloadwrapper=reproduce/analysis/bash/download-multi-try +downloadwrapper=reproduce/analysis/bash/download-multi-try.sh  # Derived directories  bindir="$instdir"/bin @@ -123,7 +123,8 @@ download_tarball() {      # Make sure this is the correct tarball.      if type sha512sum > /dev/null 2> /dev/null; then        checksum=$(sha512sum "$ucname" | awk '{print $1}') -      expectedchecksum=$(awk '/^'$progname'-checksum/{print $3}' "$checksumsfile") +      expectedchecksum=$(awk '/^'$progname'-checksum/{print $3}' \ +                             "$checksumsfile")        if [ x$checksum = x$expectedchecksum ]; then mv "$ucname" "$maneagetar"        else          echo "ERROR: Non-matching checksum: $tarball" @@ -135,8 +136,10 @@ download_tarball() {      fi    fi -  # If the tarball is newer than the (possibly existing) program (the version -  # has changed), then delete the program. +  # If the tarball is newer than the (possibly existing) program (the +  # version has changed), then delete the program. When the LaTeX name is +  # not given here, the software is re-built later (close to the end of +  # 'basic.mk') and the name is properly placed there.    if [ -f "$ibidir/$progname" ]; then        if [ "$maneagetar" -nt "$ibidir/$progname" ]; then            rm "$ibidir/$progname" @@ -210,10 +213,15 @@ build_program() {          fi      fi -    # Clean up the source directory +    # Clean up the source directory and write the LaTeX name of the +    # software (if necessary: otherwise, just make an empty file).      cd "$topdir"      rm -rf "$tmpblddir/$unpackdir" -    echo "$progname_tex $version" > "$ibidir/$progname" +    if [ x"$progname_tex" = x ]; then +        echo "" > "$ibidir/$progname" +    else +        echo "$progname_tex $version" > "$ibidir/$progname" +    fi    fi  } @@ -256,7 +264,7 @@ build_program  # Make that has a different executable name (using the '--program-prefix='  # configure option) from the "default" make (which is this one!).  progname="make" -progname_tex="GNU Make" +progname_tex="" # Make re-built after GCC (empty string to avoid repetition)  url=$(awk '/^'$progname'-url/{print $3}' $urlfile)  version=$(awk '/^'$progname'-version/{print $3}' $versionsfile)  tarball=$progname-$version.tar.lz | 
