1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
|
#! /bin/sh -e
# tup - A file-based build system
#
# Copyright (C) 2009-2024 Mike Shal <marfey@gmail.com>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 as
# published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
# Make sure a ghost node from a previous command doesn't affect a new command
# that doesn't rely on its ghostly past.
. ./tup.sh
cat > ok.sh << HERE
if [ -f ghost ]; then cat ghost; else echo nofile; fi
HERE
cat > Tupfile << HERE
: |> ./ok.sh > %o |> output.txt
HERE
chmod +x ok.sh
update
echo nofile | diff output.txt -
tup_dep_exist . ghost . './ok.sh > output.txt'
# Change ok.sh so it doesn't try to read from ghost, and make sure the
# dependency is gone.
cat > ok.sh << HERE
echo nofile
HERE
update
tup_object_no_exist . ghost
# Just as a double-check of sorts - actually create the ghost node and update,
# after deleting output.txt from behind tup's back. The output.txt file
# shouldn't be re-created (as it would be in t2028).
echo 'hey' > ghost
rm -f output.txt
update --no-scan
check_not_exist output.txt
eotup
|