diff options
author | Andrew Tridgell <tridge@samba.org> | 2010-03-19 18:03:17 +1100 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2010-04-06 20:26:54 +1000 |
commit | 8caac7a1a32c69474dd8b74d1ab8181c8f6c74f0 (patch) | |
tree | b91095dc33b7e25fffb2d55f19be3a9f869ae5c4 /buildtools/wafsamba | |
parent | 5e73038ba3fce75d7d4e9b15c3a4dd189bb816f2 (diff) | |
download | samba-8caac7a1a32c69474dd8b74d1ab8181c8f6c74f0.tar.gz samba-8caac7a1a32c69474dd8b74d1ab8181c8f6c74f0.tar.bz2 samba-8caac7a1a32c69474dd8b74d1ab8181c8f6c74f0.zip |
build: more optimisations from Thomas
Diffstat (limited to 'buildtools/wafsamba')
-rw-r--r-- | buildtools/wafsamba/samba_includes.py | 58 |
1 files changed, 54 insertions, 4 deletions
diff --git a/buildtools/wafsamba/samba_includes.py b/buildtools/wafsamba/samba_includes.py index 54d43a3b94..8174bfffe5 100644 --- a/buildtools/wafsamba/samba_includes.py +++ b/buildtools/wafsamba/samba_includes.py @@ -21,14 +21,14 @@ def apply_incpaths(self): for path in self.to_list(self.includes): if not path in lst: - if preproc.go_absolute or not os.path.isabs(path): + if preproc.go_absolute or path[0] != '/': #os.path.isabs(path): lst.append(path) else: self.env.prepend_value('CPPPATH', path) for path in lst: node = None - if os.path.isabs(path): + if path[0] == '/': # os.path.isabs(path): if preproc.go_absolute: node = self.bld.root.find_dir(path) elif path[0] == '#': @@ -56,6 +56,8 @@ def apply_obj_vars_cc(self): app = env.append_unique cpppath_st = env['CPPPATH_ST'] + lss = env['_CCINCFLAGS'] + global cac # local flags come first @@ -63,11 +65,13 @@ def apply_obj_vars_cc(self): for i in env['INC_PATHS']: try: - app('_CCINCFLAGS', cac[i.id]) + lss.extend(cac[i.id]) except KeyError: + cac[i.id] = [cpppath_st % i.bldpath(env), cpppath_st % i.srcpath(env)] - app('_CCINCFLAGS', cac[i.id]) + lss.extend(cac[i.id]) + env['_CCINCFLAGS'] = lss # set the library include paths for i in env['CPPPATH']: app('_CCINCFLAGS', cpppath_st % i) @@ -85,4 +89,50 @@ def variant(self, env): Node.Node.variant = variant +import TaskGen, Task + +def create_task(self, name, src=None, tgt=None): + task = Task.TaskBase.classes[name](self.env, generator=self) + if src: + task.set_inputs(src) + if tgt: + task.set_outputs(tgt) + return task +TaskGen.task_gen.create_task = create_task + +def hash_constraints(self): + a = self.attr + sum = hash((str(a('before', '')), + str(a('after', '')), + str(a('ext_in', '')), + str(a('ext_out', '')), + self.__class__.maxjobs)) + return sum +Task.TaskBase.hash_constraints = hash_constraints + + +# import cc +# from TaskGen import extension +# import Utils + +# @extension(cc.EXT_CC) +# def c_hook(self, node): +# task = self.create_task('cc', node, node.change_ext('.o')) +# try: +# self.compiled_tasks.append(task) +# except AttributeError: +# raise Utils.WafError('Have you forgotten to set the feature "cc" on %s?' % str(self)) + +# bld = self.bld +# try: +# dc = bld.dc +# except AttributeError: +# dc = bld.dc = {} + +# if task.outputs[0].id in dc: +# raise Utils.WafError('Samba, you are doing it wrong %r %s %s' % (task.outputs, task.generator, dc[task.outputs[0].id].generator)) +# else: +# dc[task.outputs[0].id] = task + +# return task |