import os
import os.path
import sys
+import time
##############################################################################
# BEGIN STANDARD SCons SCRIPT HEADER
-e, --entry ENTRY Print only info about ENTRY.
-h, --help Print this message and exit.
-i, --implicit Print implicit dependency information.
+ -r, --readable Print timestamps in human-readable form.
-t, --timestamp Print timestamp information.
-v, --verbose Verbose, describe each field.
"""
-opts, args = getopt.getopt(sys.argv[1:], "bce:hitv",
+opts, args = getopt.getopt(sys.argv[1:], "bce:hirtv",
['bsig', 'csig', 'entry=', 'help', 'implicit',
- 'timestamp', 'verbose'])
+ 'readable', 'timestamp', 'verbose'])
pf_bsig = 0x1
pf_csig = 0x2
entries = []
printflags = 0
verbose = 0
+readable = 0
for o, a in opts:
if o in ('-b', '--bsig'):
printflags = printflags | pf_csig
elif o in ('-e', '--entry'):
entries.append(a)
- elif o in ('-h', o == '--help'):
+ elif o in ('-h', '--help'):
print helpstr
sys.exit(0)
elif o in ('-i', '--implicit'):
printflags = printflags | pf_implicit
+ elif o in ('-r', '--readable'):
+ readable = 1
elif o in ('-t', '--timestamp'):
printflags = printflags | pf_timestamp
elif o in ('-v', '--verbose'):
sep = "\n " + name + ": "
else:
sep = " "
- return sep + (val or '-')
+ return sep + str(val)
else:
return ""
def printfield(name, entry):
- timestamp = field("timestamp", pf_timestamp, entry.timestamp)
+ if readable and entry.timestamp:
+ ts = "'" + time.ctime(entry.timestamp) + "'"
+ else:
+ ts = entry.timestamp
+ timestamp = field("timestamp", pf_timestamp, ts)
bsig = field("bsig", pf_bsig, entry.bsig)
csig = field("csig", pf_csig, entry.csig)
print name + ":" + timestamp + bsig + csig
program = "sconsign",
arguments = "sub1/.sconsign",
stdout = """\
-hello.exe: - \S+ -
-hello.obj: - \S+ -
+hello.exe: None \S+ None
+hello.obj: None \S+ None
""")
test.run(interpreter = TestSCons.python,
arguments = "-v sub1/.sconsign",
stdout = """\
hello.exe:
- timestamp: -
+ timestamp: None
bsig: \S+
- csig: -
+ csig: None
hello.obj:
- timestamp: -
+ timestamp: None
bsig: \S+
- csig: -
+ csig: None
""")
test.run(interpreter = TestSCons.python,
arguments = "-c -v sub1/.sconsign",
stdout = """\
hello.exe:
- csig: -
+ csig: None
hello.obj:
- csig: -
+ csig: None
""")
test.run(interpreter = TestSCons.python,
program = "sconsign",
arguments = "-e hello.obj sub1/.sconsign",
stdout = """\
-hello.obj: - \S+ -
+hello.obj: None \S+ None
""")
test.run(interpreter = TestSCons.python,
program = "sconsign",
arguments = "-e hello.obj -e hello.exe -e hello.obj sub1/.sconsign",
stdout = """\
-hello.obj: - \S+ -
-hello.exe: - \S+ -
-hello.obj: - \S+ -
+hello.obj: None \S+ None
+hello.exe: None \S+ None
+hello.obj: None \S+ None
""")
test.run(interpreter = TestSCons.python,
program = "sconsign",
arguments = "sub2/.sconsign",
stdout = """\
-hello.exe: - \S+ -
-hello.obj: - \S+ -
+hello.exe: None \S+ None
+hello.obj: None \S+ None
%s
%s
""" % (string.replace(os.path.join('sub2', 'inc1.h'), '\\', '\\\\'),
""" % (string.replace(os.path.join('sub2', 'inc1.h'), '\\', '\\\\'),
string.replace(os.path.join('sub2', 'inc2.h'), '\\', '\\\\')))
-test.pass_test()
-
test.run(interpreter = TestSCons.python,
program = "sconsign",
arguments = "-e hello.obj sub2/.sconsign sub1/.sconsign",
stdout = """\
-hello.obj: - \S+ -
+hello.obj: None \S+ None
%s
%s
-hello.obj: - \S+ -
+hello.obj: None \S+ None
""" % (string.replace(os.path.join('sub2', 'inc1.h'), '\\', '\\\\'),
string.replace(os.path.join('sub2', 'inc2.h'), '\\', '\\\\')))
+test.run(arguments = '--clean .')
+
+test.write('SConstruct', """
+SourceSignatures('timestamp')
+TargetSignatures('content')
+env1 = Environment(PROGSUFFIX = '.exe', OBJSUFFIX = '.obj')
+env1.Program('sub1/hello.c')
+env2 = env1.Copy(CPPPATH = ['sub2'])
+env2.Program('sub2/hello.c')
+""")
+
+import time
+time.sleep(1)
+
+test.run(arguments = '. --max-drift=1')
+
+test.run(interpreter = TestSCons.python,
+ program = "sconsign",
+ arguments = "sub1/.sconsign",
+ stdout = """\
+hello.exe: None \S+ None
+hello.c: \d+ None \d+
+hello.obj: None \S+ None
+""")
+
+test.run(interpreter = TestSCons.python,
+ program = "sconsign",
+ arguments = "-r sub1/.sconsign",
+ stdout = """\
+hello.exe: None \S+ None
+hello.c: '\S+ \S+ \d+ \d\d:\d\d:\d\d \d\d\d\d' None \d+
+hello.obj: None \S+ None
+""")
+
test.pass_test()