1 | # a waf tool to add autoconf-like macros to the configure section
|
---|
2 | # and for SAMBA_ macros for building libraries, binaries etc
|
---|
3 |
|
---|
4 | import Build, os, sys, Options, Task, Utils, cc, TaskGen, fnmatch, re, shutil, Logs, Constants
|
---|
5 | from Configure import conf
|
---|
6 | from Logs import debug
|
---|
7 | from samba_utils import SUBST_VARS_RECURSIVE
|
---|
8 | TaskGen.task_gen.apply_verif = Utils.nada
|
---|
9 |
|
---|
10 | # bring in the other samba modules
|
---|
11 | from samba_optimisation import *
|
---|
12 | from samba_utils import *
|
---|
13 | from samba_version import *
|
---|
14 | from samba_autoconf import *
|
---|
15 | from samba_patterns import *
|
---|
16 | from samba_pidl import *
|
---|
17 | from samba_autoproto import *
|
---|
18 | from samba_python import *
|
---|
19 | from samba_deps import *
|
---|
20 | from samba_bundled import *
|
---|
21 | import samba_install
|
---|
22 | import samba_conftests
|
---|
23 | import samba_abi
|
---|
24 | import samba_headers
|
---|
25 | import tru64cc
|
---|
26 | import irixcc
|
---|
27 | import hpuxcc
|
---|
28 | import generic_cc
|
---|
29 | import samba_dist
|
---|
30 | import samba_wildcard
|
---|
31 | import stale_files
|
---|
32 | import symbols
|
---|
33 | import pkgconfig
|
---|
34 |
|
---|
35 | # some systems have broken threading in python
|
---|
36 | if os.environ.get('WAF_NOTHREADS') == '1':
|
---|
37 | import nothreads
|
---|
38 |
|
---|
39 | LIB_PATH="shared"
|
---|
40 |
|
---|
41 | os.environ['PYTHONUNBUFFERED'] = '1'
|
---|
42 |
|
---|
43 |
|
---|
44 | if Constants.HEXVERSION < 0x105019:
|
---|
45 | Logs.error('''
|
---|
46 | Please use the version of waf that comes with Samba, not
|
---|
47 | a system installed version. See http://wiki.samba.org/index.php/Waf
|
---|
48 | for details.
|
---|
49 |
|
---|
50 | Alternatively, please run ./configure and make as usual. That will
|
---|
51 | call the right version of waf.''')
|
---|
52 | sys.exit(1)
|
---|
53 |
|
---|
54 |
|
---|
55 | @conf
|
---|
56 | def SAMBA_BUILD_ENV(conf):
|
---|
57 | '''create the samba build environment'''
|
---|
58 | conf.env.BUILD_DIRECTORY = conf.blddir
|
---|
59 | mkdir_p(os.path.join(conf.blddir, LIB_PATH))
|
---|
60 | mkdir_p(os.path.join(conf.blddir, LIB_PATH, "private"))
|
---|
61 | mkdir_p(os.path.join(conf.blddir, "modules"))
|
---|
62 | mkdir_p(os.path.join(conf.blddir, 'python/samba/dcerpc'))
|
---|
63 | # this allows all of the bin/shared and bin/python targets
|
---|
64 | # to be expressed in terms of build directory paths
|
---|
65 | mkdir_p(os.path.join(conf.blddir, 'default'))
|
---|
66 | for p in ['python','shared', 'modules']:
|
---|
67 | link_target = os.path.join(conf.blddir, 'default/' + p)
|
---|
68 | if not os.path.lexists(link_target):
|
---|
69 | os.symlink('../' + p, link_target)
|
---|
70 |
|
---|
71 | # get perl to put the blib files in the build directory
|
---|
72 | blib_bld = os.path.join(conf.blddir, 'default/pidl/blib')
|
---|
73 | blib_src = os.path.join(conf.srcdir, 'pidl/blib')
|
---|
74 | mkdir_p(blib_bld + '/man1')
|
---|
75 | mkdir_p(blib_bld + '/man3')
|
---|
76 | if os.path.islink(blib_src):
|
---|
77 | os.unlink(blib_src)
|
---|
78 | elif os.path.exists(blib_src):
|
---|
79 | shutil.rmtree(blib_src)
|
---|
80 |
|
---|
81 |
|
---|
82 | def ADD_INIT_FUNCTION(bld, subsystem, target, init_function):
|
---|
83 | '''add an init_function to the list for a subsystem'''
|
---|
84 | if init_function is None:
|
---|
85 | return
|
---|
86 | bld.ASSERT(subsystem is not None, "You must specify a subsystem for init_function '%s'" % init_function)
|
---|
87 | cache = LOCAL_CACHE(bld, 'INIT_FUNCTIONS')
|
---|
88 | if not subsystem in cache:
|
---|
89 | cache[subsystem] = []
|
---|
90 | cache[subsystem].append( { 'TARGET':target, 'INIT_FUNCTION':init_function } )
|
---|
91 | Build.BuildContext.ADD_INIT_FUNCTION = ADD_INIT_FUNCTION
|
---|
92 |
|
---|
93 |
|
---|
94 |
|
---|
95 | #################################################################
|
---|
96 | def SAMBA_LIBRARY(bld, libname, source,
|
---|
97 | deps='',
|
---|
98 | public_deps='',
|
---|
99 | includes='',
|
---|
100 | public_headers=None,
|
---|
101 | public_headers_install=True,
|
---|
102 | header_path=None,
|
---|
103 | pc_files=None,
|
---|
104 | vnum=None,
|
---|
105 | soname=None,
|
---|
106 | cflags='',
|
---|
107 | ldflags='',
|
---|
108 | external_library=False,
|
---|
109 | realname=None,
|
---|
110 | autoproto=None,
|
---|
111 | group='libraries',
|
---|
112 | depends_on='',
|
---|
113 | local_include=True,
|
---|
114 | global_include=True,
|
---|
115 | vars=None,
|
---|
116 | subdir=None,
|
---|
117 | install_path=None,
|
---|
118 | install=True,
|
---|
119 | pyembed=False,
|
---|
120 | pyext=False,
|
---|
121 | target_type='LIBRARY',
|
---|
122 | bundled_extension=True,
|
---|
123 | link_name=None,
|
---|
124 | abi_directory=None,
|
---|
125 | abi_match=None,
|
---|
126 | hide_symbols=False,
|
---|
127 | manpages=None,
|
---|
128 | private_library=False,
|
---|
129 | grouping_library=False,
|
---|
130 | allow_undefined_symbols=False,
|
---|
131 | enabled=True):
|
---|
132 | '''define a Samba library'''
|
---|
133 |
|
---|
134 | if not enabled:
|
---|
135 | SET_TARGET_TYPE(bld, libname, 'DISABLED')
|
---|
136 | return
|
---|
137 |
|
---|
138 | source = bld.EXPAND_VARIABLES(source, vars=vars)
|
---|
139 | if subdir:
|
---|
140 | source = bld.SUBDIR(subdir, source)
|
---|
141 |
|
---|
142 | # remember empty libraries, so we can strip the dependencies
|
---|
143 | if ((source == '') or (source == [])) and deps == '' and public_deps == '':
|
---|
144 | SET_TARGET_TYPE(bld, libname, 'EMPTY')
|
---|
145 | return
|
---|
146 |
|
---|
147 | if BUILTIN_LIBRARY(bld, libname):
|
---|
148 | obj_target = libname
|
---|
149 | else:
|
---|
150 | obj_target = libname + '.objlist'
|
---|
151 |
|
---|
152 | if group == 'libraries':
|
---|
153 | subsystem_group = 'main'
|
---|
154 | else:
|
---|
155 | subsystem_group = group
|
---|
156 |
|
---|
157 | # first create a target for building the object files for this library
|
---|
158 | # by separating in this way, we avoid recompiling the C files
|
---|
159 | # separately for the install library and the build library
|
---|
160 | bld.SAMBA_SUBSYSTEM(obj_target,
|
---|
161 | source = source,
|
---|
162 | deps = deps,
|
---|
163 | public_deps = public_deps,
|
---|
164 | includes = includes,
|
---|
165 | public_headers = public_headers,
|
---|
166 | public_headers_install = public_headers_install,
|
---|
167 | header_path = header_path,
|
---|
168 | cflags = cflags,
|
---|
169 | group = subsystem_group,
|
---|
170 | autoproto = autoproto,
|
---|
171 | depends_on = depends_on,
|
---|
172 | hide_symbols = hide_symbols,
|
---|
173 | pyext = pyext or (target_type == "PYTHON"),
|
---|
174 | local_include = local_include,
|
---|
175 | global_include = global_include)
|
---|
176 |
|
---|
177 | if BUILTIN_LIBRARY(bld, libname):
|
---|
178 | return
|
---|
179 |
|
---|
180 | if not SET_TARGET_TYPE(bld, libname, target_type):
|
---|
181 | return
|
---|
182 |
|
---|
183 | # the library itself will depend on that object target
|
---|
184 | deps += ' ' + public_deps
|
---|
185 | deps = TO_LIST(deps)
|
---|
186 | deps.append(obj_target)
|
---|
187 |
|
---|
188 | realname = bld.map_shlib_extension(realname, python=(target_type=='PYTHON'))
|
---|
189 | link_name = bld.map_shlib_extension(link_name, python=(target_type=='PYTHON'))
|
---|
190 |
|
---|
191 | # we don't want any public libraries without version numbers
|
---|
192 | if not private_library and vnum is None and soname is None and target_type != 'PYTHON' and not realname:
|
---|
193 | raise Utils.WafError("public library '%s' must have a vnum" % libname)
|
---|
194 |
|
---|
195 | if target_type == 'PYTHON' or realname or not private_library:
|
---|
196 | bundled_name = libname.replace('_', '-')
|
---|
197 | else:
|
---|
198 | bundled_name = PRIVATE_NAME(bld, libname, bundled_extension, private_library)
|
---|
199 |
|
---|
200 | ldflags = TO_LIST(ldflags)
|
---|
201 |
|
---|
202 | features = 'cc cshlib symlink_lib install_lib'
|
---|
203 | if target_type == 'PYTHON':
|
---|
204 | features += ' pyext'
|
---|
205 | if pyext or pyembed:
|
---|
206 | # this is quite strange. we should add pyext feature for pyext
|
---|
207 | # but that breaks the build. This may be a bug in the waf python tool
|
---|
208 | features += ' pyembed'
|
---|
209 |
|
---|
210 | if abi_directory:
|
---|
211 | features += ' abi_check'
|
---|
212 |
|
---|
213 | vscript = None
|
---|
214 | if bld.env.HAVE_LD_VERSION_SCRIPT:
|
---|
215 | if private_library:
|
---|
216 | version = "%s_%s" % (Utils.g_module.APPNAME, Utils.g_module.VERSION)
|
---|
217 | elif vnum:
|
---|
218 | version = "%s_%s" % (libname, vnum)
|
---|
219 | else:
|
---|
220 | version = None
|
---|
221 | if version:
|
---|
222 | vscript = "%s.vscript" % libname
|
---|
223 | bld.ABI_VSCRIPT(libname, abi_directory, version, vscript,
|
---|
224 | abi_match)
|
---|
225 | fullname = apply_pattern(bundled_name, bld.env.shlib_PATTERN)
|
---|
226 | fullpath = bld.path.find_or_declare(fullname)
|
---|
227 | vscriptpath = bld.path.find_or_declare(vscript)
|
---|
228 | if not fullpath:
|
---|
229 | raise Utils.WafError("unable to find fullpath for %s" % fullname)
|
---|
230 | if not vscriptpath:
|
---|
231 | raise Utils.WafError("unable to find vscript path for %s" % vscript)
|
---|
232 | bld.add_manual_dependency(fullpath, vscriptpath)
|
---|
233 | if Options.is_install:
|
---|
234 | # also make the .inst file depend on the vscript
|
---|
235 | instname = apply_pattern(bundled_name + '.inst', bld.env.shlib_PATTERN)
|
---|
236 | bld.add_manual_dependency(bld.path.find_or_declare(instname), bld.path.find_or_declare(vscript))
|
---|
237 | vscript = os.path.join(bld.path.abspath(bld.env), vscript)
|
---|
238 |
|
---|
239 | bld.SET_BUILD_GROUP(group)
|
---|
240 | t = bld(
|
---|
241 | features = features,
|
---|
242 | source = [],
|
---|
243 | target = bundled_name,
|
---|
244 | depends_on = depends_on,
|
---|
245 | samba_ldflags = ldflags,
|
---|
246 | samba_deps = deps,
|
---|
247 | samba_includes = includes,
|
---|
248 | version_script = vscript,
|
---|
249 | local_include = local_include,
|
---|
250 | global_include = global_include,
|
---|
251 | vnum = vnum,
|
---|
252 | soname = soname,
|
---|
253 | install_path = None,
|
---|
254 | samba_inst_path = install_path,
|
---|
255 | name = libname,
|
---|
256 | samba_realname = realname,
|
---|
257 | samba_install = install,
|
---|
258 | abi_directory = "%s/%s" % (bld.path.abspath(), abi_directory),
|
---|
259 | abi_match = abi_match,
|
---|
260 | private_library = private_library,
|
---|
261 | grouping_library=grouping_library,
|
---|
262 | allow_undefined_symbols=allow_undefined_symbols
|
---|
263 | )
|
---|
264 |
|
---|
265 | if realname and not link_name:
|
---|
266 | link_name = 'shared/%s' % realname
|
---|
267 |
|
---|
268 | if link_name:
|
---|
269 | t.link_name = link_name
|
---|
270 |
|
---|
271 | if pc_files is not None:
|
---|
272 | bld.PKG_CONFIG_FILES(pc_files, vnum=vnum)
|
---|
273 |
|
---|
274 | if manpages is not None and 'XSLTPROC_MANPAGES' in bld.env and bld.env['XSLTPROC_MANPAGES']:
|
---|
275 | bld.MANPAGES(manpages)
|
---|
276 |
|
---|
277 |
|
---|
278 | Build.BuildContext.SAMBA_LIBRARY = SAMBA_LIBRARY
|
---|
279 |
|
---|
280 |
|
---|
281 | #################################################################
|
---|
282 | def SAMBA_BINARY(bld, binname, source,
|
---|
283 | deps='',
|
---|
284 | includes='',
|
---|
285 | public_headers=None,
|
---|
286 | header_path=None,
|
---|
287 | modules=None,
|
---|
288 | ldflags=None,
|
---|
289 | cflags='',
|
---|
290 | autoproto=None,
|
---|
291 | use_hostcc=False,
|
---|
292 | use_global_deps=True,
|
---|
293 | compiler=None,
|
---|
294 | group='binaries',
|
---|
295 | manpages=None,
|
---|
296 | local_include=True,
|
---|
297 | global_include=True,
|
---|
298 | subsystem_name=None,
|
---|
299 | pyembed=False,
|
---|
300 | vars=None,
|
---|
301 | subdir=None,
|
---|
302 | install=True,
|
---|
303 | install_path=None,
|
---|
304 | enabled=True):
|
---|
305 | '''define a Samba binary'''
|
---|
306 |
|
---|
307 | if not enabled:
|
---|
308 | SET_TARGET_TYPE(bld, binname, 'DISABLED')
|
---|
309 | return
|
---|
310 |
|
---|
311 | if not SET_TARGET_TYPE(bld, binname, 'BINARY'):
|
---|
312 | return
|
---|
313 |
|
---|
314 | features = 'cc cprogram symlink_bin install_bin'
|
---|
315 | if pyembed:
|
---|
316 | features += ' pyembed'
|
---|
317 |
|
---|
318 | obj_target = binname + '.objlist'
|
---|
319 |
|
---|
320 | source = bld.EXPAND_VARIABLES(source, vars=vars)
|
---|
321 | if subdir:
|
---|
322 | source = bld.SUBDIR(subdir, source)
|
---|
323 | source = unique_list(TO_LIST(source))
|
---|
324 |
|
---|
325 | if group == 'binaries':
|
---|
326 | subsystem_group = 'main'
|
---|
327 | else:
|
---|
328 | subsystem_group = group
|
---|
329 |
|
---|
330 | # first create a target for building the object files for this binary
|
---|
331 | # by separating in this way, we avoid recompiling the C files
|
---|
332 | # separately for the install binary and the build binary
|
---|
333 | bld.SAMBA_SUBSYSTEM(obj_target,
|
---|
334 | source = source,
|
---|
335 | deps = deps,
|
---|
336 | includes = includes,
|
---|
337 | cflags = cflags,
|
---|
338 | group = subsystem_group,
|
---|
339 | autoproto = autoproto,
|
---|
340 | subsystem_name = subsystem_name,
|
---|
341 | local_include = local_include,
|
---|
342 | global_include = global_include,
|
---|
343 | use_hostcc = use_hostcc,
|
---|
344 | pyext = pyembed,
|
---|
345 | use_global_deps= use_global_deps)
|
---|
346 |
|
---|
347 | bld.SET_BUILD_GROUP(group)
|
---|
348 |
|
---|
349 | # the binary itself will depend on that object target
|
---|
350 | deps = TO_LIST(deps)
|
---|
351 | deps.append(obj_target)
|
---|
352 |
|
---|
353 | t = bld(
|
---|
354 | features = features,
|
---|
355 | source = [],
|
---|
356 | target = binname,
|
---|
357 | samba_deps = deps,
|
---|
358 | samba_includes = includes,
|
---|
359 | local_include = local_include,
|
---|
360 | global_include = global_include,
|
---|
361 | samba_modules = modules,
|
---|
362 | top = True,
|
---|
363 | samba_subsystem= subsystem_name,
|
---|
364 | install_path = None,
|
---|
365 | samba_inst_path= install_path,
|
---|
366 | samba_install = install,
|
---|
367 | samba_ldflags = TO_LIST(ldflags)
|
---|
368 | )
|
---|
369 |
|
---|
370 | if manpages is not None and 'XSLTPROC_MANPAGES' in bld.env and bld.env['XSLTPROC_MANPAGES']:
|
---|
371 | bld.MANPAGES(manpages)
|
---|
372 |
|
---|
373 | Build.BuildContext.SAMBA_BINARY = SAMBA_BINARY
|
---|
374 |
|
---|
375 |
|
---|
376 | #################################################################
|
---|
377 | def SAMBA_MODULE(bld, modname, source,
|
---|
378 | deps='',
|
---|
379 | includes='',
|
---|
380 | subsystem=None,
|
---|
381 | init_function=None,
|
---|
382 | module_init_name='samba_init_module',
|
---|
383 | autoproto=None,
|
---|
384 | autoproto_extra_source='',
|
---|
385 | cflags='',
|
---|
386 | internal_module=True,
|
---|
387 | local_include=True,
|
---|
388 | global_include=True,
|
---|
389 | vars=None,
|
---|
390 | subdir=None,
|
---|
391 | enabled=True,
|
---|
392 | pyembed=False,
|
---|
393 | allow_undefined_symbols=False
|
---|
394 | ):
|
---|
395 | '''define a Samba module.'''
|
---|
396 |
|
---|
397 | source = bld.EXPAND_VARIABLES(source, vars=vars)
|
---|
398 | if subdir:
|
---|
399 | source = bld.SUBDIR(subdir, source)
|
---|
400 |
|
---|
401 | if internal_module or BUILTIN_LIBRARY(bld, modname):
|
---|
402 | bld.SAMBA_SUBSYSTEM(modname, source,
|
---|
403 | deps=deps,
|
---|
404 | includes=includes,
|
---|
405 | autoproto=autoproto,
|
---|
406 | autoproto_extra_source=autoproto_extra_source,
|
---|
407 | cflags=cflags,
|
---|
408 | local_include=local_include,
|
---|
409 | global_include=global_include,
|
---|
410 | enabled=enabled)
|
---|
411 |
|
---|
412 | bld.ADD_INIT_FUNCTION(subsystem, modname, init_function)
|
---|
413 | return
|
---|
414 |
|
---|
415 | if not enabled:
|
---|
416 | SET_TARGET_TYPE(bld, modname, 'DISABLED')
|
---|
417 | return
|
---|
418 |
|
---|
419 | obj_target = modname + '.objlist'
|
---|
420 |
|
---|
421 | realname = modname
|
---|
422 | if subsystem is not None:
|
---|
423 | deps += ' ' + subsystem
|
---|
424 | while realname.startswith("lib"+subsystem+"_"):
|
---|
425 | realname = realname[len("lib"+subsystem+"_"):]
|
---|
426 | while realname.startswith(subsystem+"_"):
|
---|
427 | realname = realname[len(subsystem+"_"):]
|
---|
428 |
|
---|
429 | realname = bld.make_libname(realname)
|
---|
430 | while realname.startswith("lib"):
|
---|
431 | realname = realname[len("lib"):]
|
---|
432 |
|
---|
433 | build_link_name = "modules/%s/%s" % (subsystem, realname)
|
---|
434 |
|
---|
435 | if init_function:
|
---|
436 | cflags += " -D%s=%s" % (init_function, module_init_name)
|
---|
437 |
|
---|
438 | bld.SAMBA_LIBRARY(modname,
|
---|
439 | source,
|
---|
440 | deps=deps,
|
---|
441 | includes=includes,
|
---|
442 | cflags=cflags,
|
---|
443 | realname = realname,
|
---|
444 | autoproto = autoproto,
|
---|
445 | local_include=local_include,
|
---|
446 | global_include=global_include,
|
---|
447 | vars=vars,
|
---|
448 | link_name=build_link_name,
|
---|
449 | install_path="${MODULESDIR}/%s" % subsystem,
|
---|
450 | pyembed=pyembed,
|
---|
451 | allow_undefined_symbols=allow_undefined_symbols
|
---|
452 | )
|
---|
453 |
|
---|
454 |
|
---|
455 | Build.BuildContext.SAMBA_MODULE = SAMBA_MODULE
|
---|
456 |
|
---|
457 |
|
---|
458 | #################################################################
|
---|
459 | def SAMBA_SUBSYSTEM(bld, modname, source,
|
---|
460 | deps='',
|
---|
461 | public_deps='',
|
---|
462 | includes='',
|
---|
463 | public_headers=None,
|
---|
464 | public_headers_install=True,
|
---|
465 | header_path=None,
|
---|
466 | cflags='',
|
---|
467 | cflags_end=None,
|
---|
468 | group='main',
|
---|
469 | init_function_sentinal=None,
|
---|
470 | autoproto=None,
|
---|
471 | autoproto_extra_source='',
|
---|
472 | depends_on='',
|
---|
473 | local_include=True,
|
---|
474 | local_include_first=True,
|
---|
475 | global_include=True,
|
---|
476 | subsystem_name=None,
|
---|
477 | enabled=True,
|
---|
478 | use_hostcc=False,
|
---|
479 | use_global_deps=True,
|
---|
480 | vars=None,
|
---|
481 | subdir=None,
|
---|
482 | hide_symbols=False,
|
---|
483 | pyext=False):
|
---|
484 | '''define a Samba subsystem'''
|
---|
485 |
|
---|
486 | if not enabled:
|
---|
487 | SET_TARGET_TYPE(bld, modname, 'DISABLED')
|
---|
488 | return
|
---|
489 |
|
---|
490 | # remember empty subsystems, so we can strip the dependencies
|
---|
491 | if ((source == '') or (source == [])) and deps == '' and public_deps == '':
|
---|
492 | SET_TARGET_TYPE(bld, modname, 'EMPTY')
|
---|
493 | return
|
---|
494 |
|
---|
495 | if not SET_TARGET_TYPE(bld, modname, 'SUBSYSTEM'):
|
---|
496 | return
|
---|
497 |
|
---|
498 | source = bld.EXPAND_VARIABLES(source, vars=vars)
|
---|
499 | if subdir:
|
---|
500 | source = bld.SUBDIR(subdir, source)
|
---|
501 | source = unique_list(TO_LIST(source))
|
---|
502 |
|
---|
503 | deps += ' ' + public_deps
|
---|
504 |
|
---|
505 | bld.SET_BUILD_GROUP(group)
|
---|
506 |
|
---|
507 | features = 'cc'
|
---|
508 | if pyext:
|
---|
509 | features += ' pyext'
|
---|
510 |
|
---|
511 | t = bld(
|
---|
512 | features = features,
|
---|
513 | source = source,
|
---|
514 | target = modname,
|
---|
515 | samba_cflags = CURRENT_CFLAGS(bld, modname, cflags, hide_symbols=hide_symbols),
|
---|
516 | depends_on = depends_on,
|
---|
517 | samba_deps = TO_LIST(deps),
|
---|
518 | samba_includes = includes,
|
---|
519 | local_include = local_include,
|
---|
520 | local_include_first = local_include_first,
|
---|
521 | global_include = global_include,
|
---|
522 | samba_subsystem= subsystem_name,
|
---|
523 | samba_use_hostcc = use_hostcc,
|
---|
524 | samba_use_global_deps = use_global_deps
|
---|
525 | )
|
---|
526 |
|
---|
527 | if cflags_end is not None:
|
---|
528 | t.samba_cflags.extend(TO_LIST(cflags_end))
|
---|
529 |
|
---|
530 | if autoproto is not None:
|
---|
531 | bld.SAMBA_AUTOPROTO(autoproto, source + TO_LIST(autoproto_extra_source))
|
---|
532 | if public_headers is not None:
|
---|
533 | bld.PUBLIC_HEADERS(public_headers, header_path=header_path,
|
---|
534 | public_headers_install=public_headers_install)
|
---|
535 | return t
|
---|
536 |
|
---|
537 |
|
---|
538 | Build.BuildContext.SAMBA_SUBSYSTEM = SAMBA_SUBSYSTEM
|
---|
539 |
|
---|
540 |
|
---|
541 | def SAMBA_GENERATOR(bld, name, rule, source='', target='',
|
---|
542 | group='generators', enabled=True,
|
---|
543 | public_headers=None,
|
---|
544 | public_headers_install=True,
|
---|
545 | header_path=None,
|
---|
546 | vars=None,
|
---|
547 | always=False):
|
---|
548 | '''A generic source generator target'''
|
---|
549 |
|
---|
550 | if not SET_TARGET_TYPE(bld, name, 'GENERATOR'):
|
---|
551 | return
|
---|
552 |
|
---|
553 | if not enabled:
|
---|
554 | return
|
---|
555 |
|
---|
556 | bld.SET_BUILD_GROUP(group)
|
---|
557 | t = bld(
|
---|
558 | rule=rule,
|
---|
559 | source=bld.EXPAND_VARIABLES(source, vars=vars),
|
---|
560 | target=target,
|
---|
561 | shell=isinstance(rule, str),
|
---|
562 | on_results=True,
|
---|
563 | before='cc',
|
---|
564 | ext_out='.c',
|
---|
565 | samba_type='GENERATOR',
|
---|
566 | dep_vars = [rule] + (vars or []),
|
---|
567 | name=name)
|
---|
568 |
|
---|
569 | if always:
|
---|
570 | t.always = True
|
---|
571 |
|
---|
572 | if public_headers is not None:
|
---|
573 | bld.PUBLIC_HEADERS(public_headers, header_path=header_path,
|
---|
574 | public_headers_install=public_headers_install)
|
---|
575 | return t
|
---|
576 | Build.BuildContext.SAMBA_GENERATOR = SAMBA_GENERATOR
|
---|
577 |
|
---|
578 |
|
---|
579 |
|
---|
580 | @runonce
|
---|
581 | def SETUP_BUILD_GROUPS(bld):
|
---|
582 | '''setup build groups used to ensure that the different build
|
---|
583 | phases happen consecutively'''
|
---|
584 | bld.p_ln = bld.srcnode # we do want to see all targets!
|
---|
585 | bld.env['USING_BUILD_GROUPS'] = True
|
---|
586 | bld.add_group('setup')
|
---|
587 | bld.add_group('build_compiler_source')
|
---|
588 | bld.add_group('vscripts')
|
---|
589 | bld.add_group('base_libraries')
|
---|
590 | bld.add_group('generators')
|
---|
591 | bld.add_group('compiler_prototypes')
|
---|
592 | bld.add_group('compiler_libraries')
|
---|
593 | bld.add_group('build_compilers')
|
---|
594 | bld.add_group('build_source')
|
---|
595 | bld.add_group('prototypes')
|
---|
596 | bld.add_group('headers')
|
---|
597 | bld.add_group('main')
|
---|
598 | bld.add_group('symbolcheck')
|
---|
599 | bld.add_group('libraries')
|
---|
600 | bld.add_group('binaries')
|
---|
601 | bld.add_group('syslibcheck')
|
---|
602 | bld.add_group('final')
|
---|
603 | Build.BuildContext.SETUP_BUILD_GROUPS = SETUP_BUILD_GROUPS
|
---|
604 |
|
---|
605 |
|
---|
606 | def SET_BUILD_GROUP(bld, group):
|
---|
607 | '''set the current build group'''
|
---|
608 | if not 'USING_BUILD_GROUPS' in bld.env:
|
---|
609 | return
|
---|
610 | bld.set_group(group)
|
---|
611 | Build.BuildContext.SET_BUILD_GROUP = SET_BUILD_GROUP
|
---|
612 |
|
---|
613 |
|
---|
614 |
|
---|
615 | @conf
|
---|
616 | def ENABLE_TIMESTAMP_DEPENDENCIES(conf):
|
---|
617 | """use timestamps instead of file contents for deps
|
---|
618 | this currently doesn't work"""
|
---|
619 | def h_file(filename):
|
---|
620 | import stat
|
---|
621 | st = os.stat(filename)
|
---|
622 | if stat.S_ISDIR(st[stat.ST_MODE]): raise IOError('not a file')
|
---|
623 | m = Utils.md5()
|
---|
624 | m.update(str(st.st_mtime))
|
---|
625 | m.update(str(st.st_size))
|
---|
626 | m.update(filename)
|
---|
627 | return m.digest()
|
---|
628 | Utils.h_file = h_file
|
---|
629 |
|
---|
630 |
|
---|
631 |
|
---|
632 | t = Task.simple_task_type('copy_script', 'rm -f "${LINK_TARGET}" && ln -s "${SRC[0].abspath(env)}" ${LINK_TARGET}',
|
---|
633 | shell=True, color='PINK', ext_in='.bin')
|
---|
634 | t.quiet = True
|
---|
635 |
|
---|
636 | @feature('copy_script')
|
---|
637 | @before('apply_link')
|
---|
638 | def copy_script(self):
|
---|
639 | tsk = self.create_task('copy_script', self.allnodes[0])
|
---|
640 | tsk.env.TARGET = self.target
|
---|
641 |
|
---|
642 | def SAMBA_SCRIPT(bld, name, pattern, installdir, installname=None):
|
---|
643 | '''used to copy scripts from the source tree into the build directory
|
---|
644 | for use by selftest'''
|
---|
645 |
|
---|
646 | source = bld.path.ant_glob(pattern)
|
---|
647 |
|
---|
648 | bld.SET_BUILD_GROUP('build_source')
|
---|
649 | for s in TO_LIST(source):
|
---|
650 | iname = s
|
---|
651 | if installname != None:
|
---|
652 | iname = installname
|
---|
653 | target = os.path.join(installdir, iname)
|
---|
654 | tgtdir = os.path.dirname(os.path.join(bld.srcnode.abspath(bld.env), '..', target))
|
---|
655 | mkdir_p(tgtdir)
|
---|
656 | t = bld(features='copy_script',
|
---|
657 | source = s,
|
---|
658 | target = target,
|
---|
659 | always = True,
|
---|
660 | install_path = None)
|
---|
661 | t.env.LINK_TARGET = target
|
---|
662 |
|
---|
663 | Build.BuildContext.SAMBA_SCRIPT = SAMBA_SCRIPT
|
---|
664 |
|
---|
665 | def copy_and_fix_python_path(task):
|
---|
666 | pattern='sys.path.insert(0, "bin/python")'
|
---|
667 | if task.env["PYTHONARCHDIR"] in sys.path and task.env["PYTHONDIR"] in sys.path:
|
---|
668 | replacement = ""
|
---|
669 | elif task.env["PYTHONARCHDIR"] == task.env["PYTHONDIR"]:
|
---|
670 | replacement="""sys.path.insert(0, "%s")""" % task.env["PYTHONDIR"]
|
---|
671 | else:
|
---|
672 | replacement="""sys.path.insert(0, "%s")
|
---|
673 | sys.path.insert(1, "%s")""" % (task.env["PYTHONARCHDIR"], task.env["PYTHONDIR"])
|
---|
674 |
|
---|
675 | installed_location=task.outputs[0].bldpath(task.env)
|
---|
676 | source_file = open(task.inputs[0].srcpath(task.env))
|
---|
677 | installed_file = open(installed_location, 'w')
|
---|
678 | for line in source_file:
|
---|
679 | newline = line
|
---|
680 | if pattern in line:
|
---|
681 | newline = line.replace(pattern, replacement)
|
---|
682 | installed_file.write(newline)
|
---|
683 | installed_file.close()
|
---|
684 | os.chmod(installed_location, 0755)
|
---|
685 | return 0
|
---|
686 |
|
---|
687 |
|
---|
688 | def install_file(bld, destdir, file, chmod=MODE_644, flat=False,
|
---|
689 | python_fixup=False, destname=None, base_name=None):
|
---|
690 | '''install a file'''
|
---|
691 | destdir = bld.EXPAND_VARIABLES(destdir)
|
---|
692 | if not destname:
|
---|
693 | destname = file
|
---|
694 | if flat:
|
---|
695 | destname = os.path.basename(destname)
|
---|
696 | dest = os.path.join(destdir, destname)
|
---|
697 | if python_fixup:
|
---|
698 | # fixup the python path it will use to find Samba modules
|
---|
699 | inst_file = file + '.inst'
|
---|
700 | bld.SAMBA_GENERATOR('python_%s' % destname,
|
---|
701 | rule=copy_and_fix_python_path,
|
---|
702 | source=file,
|
---|
703 | target=inst_file)
|
---|
704 | file = inst_file
|
---|
705 | if base_name:
|
---|
706 | file = os.path.join(base_name, file)
|
---|
707 | bld.install_as(dest, file, chmod=chmod)
|
---|
708 |
|
---|
709 |
|
---|
710 | def INSTALL_FILES(bld, destdir, files, chmod=MODE_644, flat=False,
|
---|
711 | python_fixup=False, destname=None, base_name=None):
|
---|
712 | '''install a set of files'''
|
---|
713 | for f in TO_LIST(files):
|
---|
714 | install_file(bld, destdir, f, chmod=chmod, flat=flat,
|
---|
715 | python_fixup=python_fixup, destname=destname,
|
---|
716 | base_name=base_name)
|
---|
717 | Build.BuildContext.INSTALL_FILES = INSTALL_FILES
|
---|
718 |
|
---|
719 |
|
---|
720 | def INSTALL_WILDCARD(bld, destdir, pattern, chmod=MODE_644, flat=False,
|
---|
721 | python_fixup=False, exclude=None, trim_path=None):
|
---|
722 | '''install a set of files matching a wildcard pattern'''
|
---|
723 | files=TO_LIST(bld.path.ant_glob(pattern))
|
---|
724 | if trim_path:
|
---|
725 | files2 = []
|
---|
726 | for f in files:
|
---|
727 | files2.append(os_path_relpath(f, trim_path))
|
---|
728 | files = files2
|
---|
729 |
|
---|
730 | if exclude:
|
---|
731 | for f in files[:]:
|
---|
732 | if fnmatch.fnmatch(f, exclude):
|
---|
733 | files.remove(f)
|
---|
734 | INSTALL_FILES(bld, destdir, files, chmod=chmod, flat=flat,
|
---|
735 | python_fixup=python_fixup, base_name=trim_path)
|
---|
736 | Build.BuildContext.INSTALL_WILDCARD = INSTALL_WILDCARD
|
---|
737 |
|
---|
738 |
|
---|
739 | def INSTALL_DIRS(bld, destdir, dirs):
|
---|
740 | '''install a set of directories'''
|
---|
741 | destdir = bld.EXPAND_VARIABLES(destdir)
|
---|
742 | dirs = bld.EXPAND_VARIABLES(dirs)
|
---|
743 | for d in TO_LIST(dirs):
|
---|
744 | bld.install_dir(os.path.join(destdir, d))
|
---|
745 | Build.BuildContext.INSTALL_DIRS = INSTALL_DIRS
|
---|
746 |
|
---|
747 |
|
---|
748 | def MANPAGES(bld, manpages):
|
---|
749 | '''build and install manual pages'''
|
---|
750 | bld.env.MAN_XSL = 'http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl'
|
---|
751 | for m in manpages.split():
|
---|
752 | source = m + '.xml'
|
---|
753 | bld.SAMBA_GENERATOR(m,
|
---|
754 | source=source,
|
---|
755 | target=m,
|
---|
756 | group='final',
|
---|
757 | rule='${XSLTPROC} -o ${TGT} --nonet ${MAN_XSL} ${SRC}'
|
---|
758 | )
|
---|
759 | bld.INSTALL_FILES('${MANDIR}/man%s' % m[-1], m, flat=True)
|
---|
760 | Build.BuildContext.MANPAGES = MANPAGES
|
---|
761 |
|
---|
762 |
|
---|
763 | #############################################################
|
---|
764 | # give a nicer display when building different types of files
|
---|
765 | def progress_display(self, msg, fname):
|
---|
766 | col1 = Logs.colors(self.color)
|
---|
767 | col2 = Logs.colors.NORMAL
|
---|
768 | total = self.position[1]
|
---|
769 | n = len(str(total))
|
---|
770 | fs = '[%%%dd/%%%dd] %s %%s%%s%%s\n' % (n, n, msg)
|
---|
771 | return fs % (self.position[0], self.position[1], col1, fname, col2)
|
---|
772 |
|
---|
773 | def link_display(self):
|
---|
774 | if Options.options.progress_bar != 0:
|
---|
775 | return Task.Task.old_display(self)
|
---|
776 | fname = self.outputs[0].bldpath(self.env)
|
---|
777 | return progress_display(self, 'Linking', fname)
|
---|
778 | Task.TaskBase.classes['cc_link'].display = link_display
|
---|
779 |
|
---|
780 | def samba_display(self):
|
---|
781 | if Options.options.progress_bar != 0:
|
---|
782 | return Task.Task.old_display(self)
|
---|
783 |
|
---|
784 | targets = LOCAL_CACHE(self, 'TARGET_TYPE')
|
---|
785 | if self.name in targets:
|
---|
786 | target_type = targets[self.name]
|
---|
787 | type_map = { 'GENERATOR' : 'Generating',
|
---|
788 | 'PROTOTYPE' : 'Generating'
|
---|
789 | }
|
---|
790 | if target_type in type_map:
|
---|
791 | return progress_display(self, type_map[target_type], self.name)
|
---|
792 |
|
---|
793 | if len(self.inputs) == 0:
|
---|
794 | return Task.Task.old_display(self)
|
---|
795 |
|
---|
796 | fname = self.inputs[0].bldpath(self.env)
|
---|
797 | if fname[0:3] == '../':
|
---|
798 | fname = fname[3:]
|
---|
799 | ext_loc = fname.rfind('.')
|
---|
800 | if ext_loc == -1:
|
---|
801 | return Task.Task.old_display(self)
|
---|
802 | ext = fname[ext_loc:]
|
---|
803 |
|
---|
804 | ext_map = { '.idl' : 'Compiling IDL',
|
---|
805 | '.et' : 'Compiling ERRTABLE',
|
---|
806 | '.asn1': 'Compiling ASN1',
|
---|
807 | '.c' : 'Compiling' }
|
---|
808 | if ext in ext_map:
|
---|
809 | return progress_display(self, ext_map[ext], fname)
|
---|
810 | return Task.Task.old_display(self)
|
---|
811 |
|
---|
812 | Task.TaskBase.classes['Task'].old_display = Task.TaskBase.classes['Task'].display
|
---|
813 | Task.TaskBase.classes['Task'].display = samba_display
|
---|
814 |
|
---|
815 |
|
---|
816 | @after('apply_link')
|
---|
817 | @feature('cshlib')
|
---|
818 | def apply_bundle_remove_dynamiclib_patch(self):
|
---|
819 | if self.env['MACBUNDLE'] or getattr(self,'mac_bundle',False):
|
---|
820 | if not getattr(self,'vnum',None):
|
---|
821 | try:
|
---|
822 | self.env['LINKFLAGS'].remove('-dynamiclib')
|
---|
823 | self.env['LINKFLAGS'].remove('-single_module')
|
---|
824 | except ValueError:
|
---|
825 | pass
|
---|