def prepareSrc(self, dict):
src = VarInterpolator.prepareSrc(self, dict)
- def path_dirs(path, fs = self.fs, dir = self.dir):
+ def path_dirs(rep, path, fs=self.fs, dir=self.dir):
+ if rep:
+ path = os.path.join(rep, path)
return fs.Dir(path, directory = dir)
return self.fs.Rsearchall(src, path_dirs)
return string.upper(x)
-def exists_path(path):
+def exists_path(rep, path):
"""Return a path if it's already a Node or it exists in the
real filesystem."""
+ if rep:
+ path = os.path.join(rep, path)
if os.path.exists(path):
return path
return None
if isinstance(path, SCons.Node.Node):
return path
else:
- n = func(path)
+ n = func(None, path)
if n:
return n
for dir in self.Repositories:
- n = func(os.path.join(dir.path, path))
+ n = func(dir.path, path)
if n:
return n
return None
if isinstance(path, SCons.Node.Node):
ret.append(path)
else:
- n = func(path)
+ n = func(None, path)
if n:
ret.append(n)
if not os.path.isabs(path):
if path[0] == '#':
path = path[1:]
for dir in self.Repositories:
- n = func(os.path.join(dir.path, path))
+ n = func(dir.path, path)
if n:
ret.append(n)
return ret
if not hasattr(self, '_rfile'):
self._rfile = self
if not os.path.isabs(self.path) and not os.path.isfile(self.path):
- def file_node(path, fs = self.fs):
+ def file_node(dir, path, fs=self.fs):
+ if dir:
+ path = os.path.join(dir, path)
if os.path.isfile(path):
return fs.File(path)
return None
assert fs.Rsearch('f2')
assert fs.Rsearch(f3) is f3
- assert not fs.Rsearch('f1', os.path.exists)
- assert fs.Rsearch('f2', os.path.exists)
- assert fs.Rsearch('f3', os.path.exists)
+ def my_exists(rep, path):
+ if rep:
+ path = os.path.join(rep, path)
+ return os.path.exists(path)
+
+ assert not fs.Rsearch('f1', my_exists)
+ assert fs.Rsearch('f2', my_exists)
+ assert fs.Rsearch('f3', my_exists)
list = fs.Rsearchall(fs.Dir('d1'))
assert len(list) == 1, list
# node.includes - the result of include_re.findall()
if not hasattr(target, 'cpppath'):
- def Dir(x, dir=target.cwd, fs=fs): return fs.Dir(x,dir)
+ def Dir(rep, path, dir=target.cwd, fs=fs):
+ if rep:
+ path = os.path.join(rep, path)
+ return fs.Dir(path, dir)
try:
target.cpppath = tuple(fs.Rsearchall(env['CPPPATH'], Dir))
except KeyError:
# node.includes - the result of include_re.findall()
if not hasattr(target, 'f77path'):
- def Dir(x, dir=target.cwd, fs=fs): return fs.Dir(x,dir)
+ def Dir(rep, path, dir=target.cwd, fs=fs):
+ if rep:
+ path = os.path.join(rep, path)
+ return fs.Dir(path, dir)
try:
target.f77path = tuple(fs.Rsearchall(env['F77PATH'], Dir))
except KeyError: