5 # Permission is hereby granted, free of charge, to any person obtaining
6 # a copy of this software and associated documentation files (the
7 # "Software"), to deal in the Software without restriction, including
8 # without limitation the rights to use, copy, modify, merge, publish,
9 # distribute, sublicense, and/or sell copies of the Software, and to
10 # permit persons to whom the Software is furnished to do so, subject to
11 # the following conditions:
13 # The above copyright notice and this permission notice shall be included
14 # in all copies or substantial portions of the Software.
16 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
17 # KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
18 # WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19 # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20 # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21 # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22 # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25 __revision__
= "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
29 _python_
= TestSCons
._python
_
31 test
= TestSCons
.TestSCons()
33 # Test behavior of Scanners when evaluating implicit dependencies
34 # for nodes that do not have mappings from their scanner_key
35 # to a scanner instance
37 test
.write('SConstruct', r
"""
40 include_re = re.compile(r'^include\s+(\S+)$', re.M)
42 def scan(node, env, scanpaths, arg):
43 contents = node.get_text_contents()
44 includes = include_re.findall(contents)
47 def kfile_scan(node, env, scanpaths, arg):
48 print('kscan: ' + str(node))
49 return scan(node, env, scanpaths, arg)
51 def k2file_scan(node, env, scanpaths, arg):
52 print('k2scan: ' + str(node))
53 return scan(node, env, scanpaths, arg)
55 kscan = Scanner(name = 'kfile',
56 function = kfile_scan,
61 k2scan = Scanner(name = 'k2',
62 function = k2file_scan,
66 k2scan2 = Scanner(name = 'k2',
67 function = k2file_scan,
72 env1.Append(SCANNERS = [ kscan, k2scan ] )
73 env1.Command( 'k', 'foo.k', Copy( '$TARGET', '$SOURCE' ) )
76 env2.Append(SCANNERS = [ k2scan2 ] )
77 env2.Command( 'k2', 'foo.k', Copy( '$TARGET', '$SOURCE' ) )
87 test
.write('xxx.k', "xxx.k 1\n")
88 test
.write('yyy', "yyy 1\n")
89 test
.write('yyy.k2', "yyy.k2 1\n")
91 expected_stdout
= test
.wrap_stdout("""\
102 test
.run(arguments
='k k2', stdout
=expected_stdout
)
108 # indent-tabs-mode:nil
110 # vim: set expandtab tabstop=4 shiftwidth=4: