File: t2030-ghost-node3.sh

package info (click to toggle)
tup 0.8-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 21,076 kB
  • sloc: ansic: 256,651; sh: 19,101; perl: 184; python: 67; lisp: 63; makefile: 56
file content (50 lines) | stat: -rwxr-xr-x 1,520 bytes parent folder | download | duplicates (2)
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 if we have a ghost node that it doesn't get used in wildcarding or
# explicit inputs.

. ./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
tup_object_exist . ghost
echo nofile | diff output.txt -

# This should parse correctly because the g* shouldn't match the ghost node
cat > Tupfile << HERE
: |> ./ok.sh > %o |> output.txt
: foreach g* |> cat %f |>
HERE
parse
tup_object_no_exist . 'cat ghost'
update

# When we explicitly name the file, it should fail
cat > Tupfile << HERE
: |> ./ok.sh > %o |> output.txt
: ghost |> cat %f |>
HERE
parse_fail_msg "Explicitly named file 'ghost' is a ghost file, so it can't be used as an input"

eotup