diff options
-rwxr-xr-x | ship/build | 47 |
1 files changed, 20 insertions, 27 deletions
@@ -33,21 +33,23 @@ EOF ## usage: build_compile SRCFILE DSTFILE build_compile() { - defvar srcfile "$(cat "$1")" 'SRCFILE' - defvar build_directives "$(make_build_directives "$0")" '$0' - defvar build_x_directive_loader "$(make_build_x_directive_loader "$0")" '$0' + setf build_directives '$(make_build_directives "$%s")' 0 + setf build_x_directive_loader '$(make_build_x_directive_loader "$%s")' 0 eval "$build_x_directive_loader" - defvar input_parser "$(make_input_parser "$0")" - defvar sentinel "$(make_needs_compilation_sentinel $build_directives)" + setf input_parser '$(make_input_parser "$%s")' 0 + setf sentinel '$(make_needs_compilation_sentinel $%s)' build_directives - while needs_compilation "$srcfile" "$sentinel"; do - defvar script "$(make_sedscript_maker_shellscript "$srcfile" "$input_parser")" - defvar srcfile "$(echo "$srcfile" | sed -n "$script")" 'sed script srcfile' + SRCFILE="$1" setf src '$(cat "$%s")' SRCFILE + + while needs_compilation "$src" "$sentinel"; do + setf sedgen '$(echo "$%s" | nl -b a -s \ | sed "$%s")' src input_parser + setf sedscript '$(eval "$%s")' sedgen + setf src '$(echo "$%s" | sed -n "$%s")' src sedscript done - echo "$srcfile" > "$2" + echo "$src" > "$2" chmod +x "$2" } @@ -57,16 +59,6 @@ needs_compilation() { echo "$1" | grep -q "$2" } -## usage: make_sedscript_maker_shellscript SRCFILE INPUT_PARSER -# Print a shellscript that creates a sedscript that resolves all the build -# directives in SRCFILE. -make_sedscript_maker_shellscript() { - defvar sedscript_generator "$(echo "$1" | nl -b a -s ' ' | sed "$2")" \ - 'sed input_parser srcfile' - defvar sedscript "$(eval "$sedscript_generator")" 'eval sedscript_generator' - echo "$sedscript" -} - ## usage: build_deps SRCFILE... # Print all the dependencies of SRCFILE... (in alphabetic order) to stdout. build_deps() { @@ -132,15 +124,16 @@ make_needs_compilation_sentinel() { )\\)$" } -## usage: defvar NAME VALUE [DESCRIPTION] -defvar() { - eval "$1=\"\$2\"" +## usage: setf NAME FMT [ARG...] +setf() { + value_script="$(shift; printf "$@")" + + eval "$1=$value_script" + if test "${debug-false}" = true; then - printf '[35m====== %s%s[m\n%s\n' \ - "$1" \ - "${3+" ($3)"}" \ - "$(eval echo \"\$$1\" | nl -b a)" >&2 - fi + eval 'echo "[35m$1=\"$value_script\"[m"' + eval 'echo "'"\$$1"'"' | nl -b a + fi >&2 } ## main |