Skip site navigation (1)Skip section navigation (2)
Date:      20 Mar 2005 23:03:13 -0000
From:      Michal Varga <varga@stonehenge.sk>
To:        FreeBSD-gnats-submit@FreeBSD.org
Subject:   ports/79064: Patchset for scons-0.96.90 to unbreak graphics/blender-devel
Message-ID:  <20050320230313.76267.qmail@mail.stonehenge.sk>
Resent-Message-ID: <200503202310.j2KNA1gh073410@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help

>Number:         79064
>Category:       ports
>Synopsis:       Patchset for scons-0.96.90 to unbreak graphics/blender-devel
>Confidential:   no
>Severity:       serious
>Priority:       medium
>Responsible:    freebsd-ports-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          update
>Submitter-Id:   current-users
>Arrival-Date:   Sun Mar 20 23:10:01 GMT 2005
>Closed-Date:
>Last-Modified:
>Originator:     Michal Varga
>Release:        FreeBSD 6.0-CURRENT i386
>Organization:
Stonehenge
>Environment:
System: FreeBSD xenon.stonehenge.sk 6.0-CURRENT FreeBSD 6.0-CURRENT #0: Sat Mar 19 20:11:17 CET 2005 root@xenon.stonehenge.sk:/usr/obj/usr/src/sys/KERNEL i386


	
>Description:
Patches for portions of scons 0.96.90 to unbreak build of
graphics/blender-devel, obtained from latest scons CVS. Successfully
tested with other two ports depending on scons (fsplib, kdissert), both
work.
>How-To-Repeat:
	
>Fix:
diff -rNu devel/scons/files/patch-node-FS.py devel/scons.new/files/patch-node-FS.py
--- devel/scons/files/patch-node-FS.py	Thu Jan  1 01:00:00 1970
+++ devel/scons.new/files/patch-node-FS.py	Sat Mar 19 23:43:26 2005
@@ -0,0 +1,312 @@
+--- engine/SCons/Node/FS.py.orig	Wed Feb 16 03:12:10 2005
++++ engine/SCons/Node/FS.py	Tue Mar  8 19:08:43 2005
+@@ -756,7 +756,7 @@
+ 
+         The path argument must be a valid absolute path.
+         """
+-        if __debug__: logInstanceCreation(self)
++        if __debug__: logInstanceCreation(self, 'Node.FS')
+         self.Top = None
+         if path == None:
+             self.pathTop = os.getcwd()
+@@ -999,15 +999,11 @@
+             self.__setTopLevelDir()
+             self.Top.addRepository(d)
+ 
+-    def do_Rsearch(self, path, func, clazz=_classEntry, cwd=None, verbose=lambda x: x):
++    def do_Rsearch(self, path, dir, func, clazz=_classEntry):
+         """Search for something in a Repository.  Returns the first
+         one found in the list, or None if there isn't one.
+         __cacheable__
+         """
+-        if isinstance(path, SCons.Node.Node):
+-            return path
+-
+-        path, dir = self.__transformPath(path, cwd)
+         d, name = os.path.split(path)
+         norm_name = _my_normcase(name)
+         if d:
+@@ -1021,8 +1017,7 @@
+             if node:
+                 dir = node.get_dir()
+         if node:
+-            verbose("... FOUND '%s' in '%s'\n" % (name, dir))
+-            return node
++            return node, dir
+         fname = '.'
+         while dir:
+             for rep in dir.getRepositories():
+@@ -1034,19 +1029,21 @@
+                 else:
+                     node = func(node)
+                 if node:
+-                    verbose("... FOUND '%s' in '%s'\n" % (name, dir))
+-                    return node
++                    return node, dir
+             fname = dir.name + os.sep + fname
+             dir = dir.get_dir()
+-        return None
++        return None, None
+ 
+     def Rsearch(self, path, clazz=_classEntry, cwd=None):
++        if isinstance(path, SCons.Node.Node):
++            return path
+         def func(node):
+             if node.exists() and \
+                (isinstance(node, Dir) or not node.is_derived()):
+                    return node
+             return None
+-        return self.do_Rsearch(path, func, clazz, cwd)
++        path, dir = self.__transformPath(path, cwd)
++        return self.do_Rsearch(path, dir, func, clazz)[0]
+ 
+     def Rsearchall(self, pathlist, must_exist=1, clazz=_classEntry, cwd=None):
+         """Search for a list of somethings in the Repository list.
+@@ -1087,10 +1084,6 @@
+             else:
+                 if not must_exist or node.exists():
+                     result.append(node)
+-                if isinstance(node, Dir):
+-                    result.extend(filter(select, node.getRepositories()))
+-                if node:
+-                    dir = node.get_dir()
+             fname = '.'
+             while dir:
+                 for rep in dir.getRepositories():
+@@ -1286,6 +1279,36 @@
+         if not self.builder is MkdirBuilder:
+             apply(SCons.Node.Node.build, [self,], kw)
+ 
++    def _create(self):
++        """Create this directory, silently and without worrying about
++        whether the builder is the default or not."""
++        listDirs = []
++        parent = self
++        while parent:
++            if parent.exists():
++                break
++            listDirs.append(parent)
++            p = parent.up()
++            if isinstance(p, ParentOfRoot):
++                raise SCons.Errors.StopError, parent.path
++            parent = p
++        listDirs.reverse()
++        for dirnode in listDirs:
++            try:
++                # Don't call dirnode.build(), call the base Node method
++                # directly because we definitely *must* create this
++                # directory.  The dirnode.build() method will suppress
++                # the build if it's the default builder.
++                SCons.Node.Node.build(dirnode)
++                dirnode.get_executor().nullify()
++                # The build() action may or may not have actually
++                # created the directory, depending on whether the -n
++                # option was used or not.  Delete the _exists and
++                # _rexists attributes so they can be reevaluated.
++                dirnode.clear()
++            except OSError:
++                pass
++
+     def multiple_side_effect_has_builder(self):
+         global MkdirBuilder
+         return not self.builder is MkdirBuilder and self.has_builder()
+@@ -1383,24 +1406,59 @@
+         sccspath = 'SCCS' + os.sep + 's.'+name
+         return self.entry_exists_on_disk(sccspath)
+ 
+-    def srcdir_duplicate(self, name, clazz):
+-        dname = '.'
++    def srcdir_list(self):
++        """__cacheable__"""
++        result = []
++
++        dirname = '.'
+         dir = self
+         while dir:
+             if dir.srcdir:
+-                srcdir = dir.srcdir.Dir(dname)
+-                if srcdir.entry_exists_on_disk(name):
+-                    srcnode = self.fs._doLookup(clazz, name, srcdir)
+-                    if self.duplicate:
+-                        node = self.fs._doLookup(clazz, name, self)
+-                        node.do_duplicate(srcnode)
+-                        return node
+-                    else:
+-                        return srcnode
+-            dname = dir.name + os.sep + dname
++                d = dir.srcdir.Dir(dirname)
++                if d.is_under(dir):
++                    # Shouldn't source from something in the build path:
++                    # build_dir is probably under src_dir, in which case
++                    # we are reflecting.
++                    break
++                result.append(d)
++            dirname = dir.name + os.sep + dirname
+             dir = dir.get_dir()
++
++        return result
++
++    def srcdir_duplicate(self, name, clazz):
++        for dir in self.srcdir_list():
++            if dir.entry_exists_on_disk(name):
++                srcnode = self.fs._doLookup(clazz, name, dir)
++                if self.duplicate:
++                    node = self.fs._doLookup(clazz, name, self)
++                    node.do_duplicate(srcnode)
++                    return node
++                else:
++                    return srcnode
+         return None
+ 
++    def srcdir_find_file(self, filename):
++        """__cacheable__"""
++        fs = self.fs
++        do_Rsearch = fs.do_Rsearch
++
++        def func(node):
++            if isinstance(node, SCons.Node.FS.File) and \
++               (node.is_derived() or node.is_pseudo_derived() or node.exists()):
++                    return node
++            return None
++
++        node, d = do_Rsearch(filename, self, func, File)
++        if node:
++            return node, d
++
++        for dir in self.srcdir_list():
++            node, d = do_Rsearch(filename, dir, func, File)
++            if node:
++                return File(filename, self, fs), d
++        return None, None
++
+     def node_on_disk(self, name, clazz):
+         if self.entry_exists_on_disk(name) or \
+            self.sccs_on_disk(name) or \
+@@ -1542,33 +1600,7 @@
+     def _createDir(self):
+         # ensure that the directories for this node are
+         # created.
+-
+-        listDirs = []
+-        parent=self.dir
+-        while parent:
+-            if parent.exists():
+-                break
+-            listDirs.append(parent)
+-            p = parent.up()
+-            if isinstance(p, ParentOfRoot):
+-                raise SCons.Errors.StopError, parent.path
+-            parent = p
+-        listDirs.reverse()
+-        for dirnode in listDirs:
+-            try:
+-                # Don't call dirnode.build(), call the base Node method
+-                # directly because we definitely *must* create this
+-                # directory.  The dirnode.build() method will suppress
+-                # the build if it's the default builder.
+-                SCons.Node.Node.build(dirnode)
+-                dirnode.get_executor().nullify()
+-                # The build() action may or may not have actually
+-                # created the directory, depending on whether the -n
+-                # option was used or not.  Delete the _exists and
+-                # _rexists attributes so they can be reevaluated.
+-                dirnode.clear()
+-            except OSError:
+-                pass
++        self.dir._create()
+ 
+     def retrieve_from_cache(self):
+         """Try to retrieve the node's content from a cache
+@@ -1844,7 +1876,7 @@
+ 
+ default_fs = FS()
+ 
+-def find_file(filename, paths, node_factory=default_fs.File, verbose=None):
++def find_file(filename, paths, verbose=None):
+     """
+     find_file(str, [Dir()]) -> [nodes]
+ 
+@@ -1860,6 +1892,7 @@
+ 
+     Only the first file found is returned, and none is returned
+     if no file is found.
++    __cacheable__
+     """
+     if verbose:
+         if not SCons.Util.is_String(verbose):
+@@ -1870,49 +1903,32 @@
+     else:
+         verbose = lambda x: x
+ 
+-    filedir, filename = os.path.split(filename)
+-    if filedir:
+-        lookup_dir = lambda d, fd=filedir: d.Dir(fd)
+-    else:
+-        lookup_dir = lambda d: d
+-
+     if callable(paths):
+         paths = paths()
+ 
+     # Give Entries a chance to morph into Dirs.
+     paths = map(lambda p: p.must_be_a_Dir(), paths)
+ 
+-    for pathdir in paths:
+-        verbose("looking for '%s' in '%s' ...\n" % (filename, pathdir))
+-        dir = lookup_dir(pathdir)
+-        def func(node):
+-            if isinstance(node, SCons.Node.FS.File) and \
+-               (node.is_derived() or node.is_pseudo_derived() or node.exists()):
+-                    return node
+-            return None
+-
+-        node = default_fs.do_Rsearch(filename, func, File, dir, verbose)
++    filedir, filename = os.path.split(filename)
++    if filedir:
++        def filedir_lookup(p, fd=filedir):
++            try:
++                return p.Dir(fd)
++            except TypeError:
++                # We tried to look up a Dir, but it seems there's already
++                # a File (or something else) there.  No big.
++                return None
++        paths = filter(None, map(filedir_lookup, paths))
++
++    for dir in paths:
++        verbose("looking for '%s' in '%s' ...\n" % (filename, dir))
++        node, d = dir.srcdir_find_file(filename)
+         if node:
++            verbose("... FOUND '%s' in '%s'\n" % (filename, d))
+             return node
+-
+-        dirname = '.'
+-        while dir:
+-            if dir.srcdir:
+-                d = dir.srcdir.Dir(dirname)
+-                if d.is_under(dir):
+-                    # Shouldn't source from something in the build path:
+-                    # build_dir is probably under src_dir, in which case
+-                    # we are reflecting.
+-                    break
+-                node = dir.fs.do_Rsearch(filename, func, File, d, verbose)
+-                if node:
+-                    return File(filename, dir.Dir(dirname), dir.fs)
+-            dirname = dir.name + os.sep + dirname
+-            dir = dir.get_dir()
+-
+     return None
+ 
+-def find_files(filenames, paths, node_factory = default_fs.File):
++def find_files(filenames, paths):
+     """
+     find_files([str], [Dir()]) -> [nodes]
+ 
+@@ -1927,7 +1943,5 @@
+     Only the first file found is returned for each filename,
+     and any files that aren't found are ignored.
+     """
+-    nodes = map(lambda x, paths=paths, node_factory=node_factory:
+-                       find_file(x, paths, node_factory),
+-                filenames)
+-    return filter(lambda x: x != None, nodes)
++    nodes = map(lambda x, paths=paths: find_file(x, paths), filenames)
++    return filter(None, nodes)
diff -rNu devel/scons/files/patch-scanner-D.py devel/scons.new/files/patch-scanner-D.py
--- devel/scons/files/patch-scanner-D.py	Thu Jan  1 01:00:00 1970
+++ devel/scons.new/files/patch-scanner-D.py	Sat Mar 19 23:43:52 2005
@@ -0,0 +1,11 @@
+--- engine/SCons/Scanner/D.py.orig	Wed Feb 16 03:12:10 2005
++++ engine/SCons/Scanner/D.py	Tue Mar  1 22:00:50 2005
+@@ -51,7 +51,5 @@
+         # translate dots (package separators) to slashes
+         inc = string.replace(include, '.', '/')
+ 
+-        i = SCons.Node.FS.find_file(inc + '.d',
+-                                    (source_dir,) + path,
+-                                    self.fs.File)
++        i = SCons.Node.FS.find_file(inc + '.d', (source_dir,) + path)
+         return i, include
diff -rNu devel/scons/files/patch-scanner-Prog.py devel/scons.new/files/patch-scanner-Prog.py
--- devel/scons/files/patch-scanner-Prog.py	Thu Jan  1 01:00:00 1970
+++ devel/scons.new/files/patch-scanner-Prog.py	Sat Mar 19 23:44:10 2005
@@ -0,0 +1,11 @@
+--- engine/SCons/Scanner/Prog.py.orig	Wed Feb 16 03:12:11 2005
++++ engine/SCons/Scanner/Prog.py	Tue Mar  1 22:00:50 2005
+@@ -89,7 +89,7 @@
+             lib = env.subst(lib)
+             for pref, suf in pairs:
+                 l = adjustixes(lib, pref, suf)
+-                l = find_file(l, libpath, fs.File, verbose=print_find_libs)
++                l = find_file(l, libpath, verbose=print_find_libs)
+                 if l:
+                     result.append(l)
+         else:
diff -rNu devel/scons/files/patch-scanner-__init__.py devel/scons.new/files/patch-scanner-__init__.py
--- devel/scons/files/patch-scanner-__init__.py	Thu Jan  1 01:00:00 1970
+++ devel/scons.new/files/patch-scanner-__init__.py	Sat Mar 19 23:44:44 2005
@@ -0,0 +1,24 @@
+--- engine/SCons/Scanner/__init__.py.orig	Wed Feb 16 03:12:10 2005
++++ engine/SCons/Scanner/__init__.py	Tue Mar  1 22:00:50 2005
+@@ -338,9 +338,7 @@
+     def find_include(self, include, source_dir, path):
+         "__cacheable__"
+         if callable(path): path = path()
+-        n = SCons.Node.FS.find_file(include,
+-                                    (source_dir,) + tuple(path),
+-                                    SCons.Node.FS.File)
++        n = SCons.Node.FS.find_file(include, (source_dir,) + tuple(path))
+         return n, include
+ 
+     def sort_key(self, include):
+@@ -398,9 +396,7 @@
+         else:
+             paths = Binder( tuple(path) + (source_dir,) )
+ 
+-        n = SCons.Node.FS.find_file(include[1],
+-                                    paths,
+-                                    self.fs.File)
++        n = SCons.Node.FS.find_file(include[1], paths)
+ 
+         return n, include[1]
+ 
diff -rNu devel/scons/files/patch-script-Main.py devel/scons.new/files/patch-script-Main.py
--- devel/scons/files/patch-script-Main.py	Thu Jan  1 01:00:00 1970
+++ devel/scons.new/files/patch-script-Main.py	Sun Mar 20 00:37:34 2005
@@ -0,0 +1,11 @@
+--- engine/SCons/Script/Main.py.orig	Wed Feb 16 03:12:11 2005
++++ engine/SCons/Script/Main.py	Sat Mar 19 23:40:24 2005
+@@ -1024,7 +1034,7 @@
+                 node = None
+         return node
+ 
+-    nodes = filter(lambda x: x is not None, map(Entry, targets))
++    nodes = filter(None, map(Entry, targets))
+ 
+     task_class = BuildTask	# default action is to build targets
+     opening_message = "Building targets ..."
diff -rNu devel/scons/files/patch-script-SConscript.py devel/scons.new/files/patch-script-SConscript.py
--- devel/scons/files/patch-script-SConscript.py	Thu Jan  1 01:00:00 1970
+++ devel/scons.new/files/patch-script-SConscript.py	Sat Mar 19 23:47:07 2005
@@ -0,0 +1,30 @@
+--- engine/SCons/Script/SConscript.py.orig	Wed Feb 16 03:12:11 2005
++++ engine/SCons/Script/SConscript.py	Thu Mar 17 14:07:00 2005
+@@ -55,6 +55,16 @@
+ import types
+ import UserList
+ 
++# The following variables used to live in this module.  Some
++# SConscript files out there may have referred to them directly as
++# SCons.Script.SConscript.*.  This is now supported by some special
++# handling towards the bottom of the SConscript.__init__.py module.
++#Arguments = {}
++#ArgList = []
++#BuildTargets = TargetList()
++#CommandLineTargets = []
++#DefaultTargets = []
++
+ launch_dir = os.path.abspath(os.curdir)
+ 
+ GlobalDict = None
+@@ -230,7 +240,9 @@
+                 # Repository directory.  Like above, we do this
+                 # directly.
+                 fs.chdir(frame.prev_dir, change_os_dir=0)
+-                os.chdir(frame.prev_dir.rdir().get_abspath())
++                rdir = frame.prev_dir.rdir()
++                rdir._create()  # Make sure there's a directory there.
++                os.chdir(rdir.get_abspath())
+ 
+             results.append(frame.retval)
+ 
diff -rNu devel/scons/files/patch-script-__init__.py devel/scons.new/files/patch-script-__init__.py
--- devel/scons/files/patch-script-__init__.py	Thu Jan  1 01:00:00 1970
+++ devel/scons.new/files/patch-script-__init__.py	Sat Mar 19 23:47:46 2005
@@ -0,0 +1,84 @@
+--- engine/SCons/Script/__init__.py.orig	Wed Feb 16 03:12:11 2005
++++ engine/SCons/Script/__init__.py	Thu Mar 17 14:07:01 2005
+@@ -77,6 +77,41 @@
+ 
+ main                    = Main.main
+ 
++# The following are global class definitions and variables that used to
++# live directly in this module back before 0.96.90, when it contained
++# a lot of code.  Some SConscript files in widely-distributed packages
++# (Blender is the specific example) actually reached into SCons.Script
++# directly to use some of these.  Rather than break those SConscript
++# files, we're going to propagate these names into the SCons.Script
++# namespace here.
++#
++# Some of these are commented out because it's *really* unlikely anyone
++# used them, but we're going to leave the comment here to try to make
++# it obvious what to do if the situation arises.
++BuildTask               = Main.BuildTask
++CleanTask               = Main.CleanTask
++QuestionTask            = Main.QuestionTask
++#PrintHelp               = Main.PrintHelp
++OptParser               = Main.OptParser
++SConscriptSettableOptions = Main.SConscriptSettableOptions
++
++keep_going_on_error     = Main.keep_going_on_error
++print_dtree             = Main.print_dtree
++print_explanations      = Main.print_explanations
++print_includes          = Main.print_includes
++print_objects           = Main.print_objects
++print_time              = Main.print_time
++print_tree              = Main.print_tree
++memory_stats            = Main.memory_stats
++ignore_errors           = Main.ignore_errors
++#sconscript_time         = Main.sconscript_time
++#command_time            = Main.command_time
++#exit_status             = Main.exit_status
++#profiling               = Main.profiling
++repositories            = Main.repositories
++#num_jobs                = Main.num_jobs     # settable by SConscript.SetJobs()
++
++#
+ import SConscript
+ _SConscript = SConscript
+ 
+@@ -206,7 +241,7 @@
+     'GetOption',
+     'Help',
+     'Import',
+-    'SConscript',
++    #'SConscript', is handled separately, below.
+     'SConscriptChdir',
+     'SetOption',
+ 
+@@ -221,6 +256,7 @@
+     #The Command() method is handled separately, below.
+     'Depends',
+     'Dir',
++    'Entry',
+     'Execute',
+     'File',
+     'FindFile',
+@@ -272,6 +308,22 @@
+ 
+ for name in GlobalDefaultEnvironmentFunctions + GlobalDefaultBuilders:
+     exec "%s = _SConscript.DefaultEnvironmentCall(%s)" % (name, repr(name))
++
++# There are a handful of variables that used to live in the
++# Script/SConscript.py module that some SConscript files out there were
++# accessing directly as SCons.Script.SConscript.*.  The problem is that
++# "SConscript" in this namespace is no longer a module, it's a global
++# function call--or more precisely, an object that implements a global
++# function call through the default Environment.  Nevertheless, we can
++# aintain backwards compatibility for SConscripts that were reaching in
++# this way by hanging some attributes off the "SConscript" object here.
++SConscript = _SConscript.DefaultEnvironmentCall('SConscript')
++
++SConscript.Arguments = ARGUMENTS
++SConscript.ArgList = ARGLIST
++SConscript.BuildTargets = BUILD_TARGETS
++SConscript.CommandLineTargets = COMMAND_LINE_TARGETS
++SConscript.DefaultTargets = DEFAULT_TARGETS
+ 
+ # The global Command() function must be handled differently than the
+ # global functions for other construction environment methods because

>Release-Note:
>Audit-Trail:
>Unformatted:



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20050320230313.76267.qmail>