2010-02-21 00:24:28 +11:00
# a waf tool to add autoconf-like macros to the configure section
2010-02-21 00:40:26 +11:00
# and for SAMBA_ macros for building libraries, binaries etc
2010-02-21 00:24:28 +11:00
2011-01-05 12:16:15 +01:00
import Build , os , sys , Options , Task , Utils , cc , TaskGen , fnmatch , re , shutil , Logs , Constants
2010-02-21 00:24:28 +11:00
from Configure import conf
2010-03-17 20:21:47 +11:00
from Logs import debug
2010-03-19 19:49:59 +11:00
from samba_utils import SUBST_VARS_RECURSIVE
2010-06-15 01:24:20 +02:00
TaskGen . task_gen . apply_verif = Utils . nada
2010-02-21 00:24:28 +11:00
2010-02-26 22:21:50 +11:00
# bring in the other samba modules
2010-03-19 18:07:39 +11:00
from samba_optimisation import *
2010-02-26 22:21:50 +11:00
from samba_utils import *
2010-05-28 15:20:03 +10:00
from samba_version import *
2010-02-26 22:21:50 +11:00
from samba_autoconf import *
2010-02-26 22:38:38 +11:00
from samba_patterns import *
2010-02-28 17:34:43 +11:00
from samba_pidl import *
2010-03-17 21:53:29 +11:00
from samba_autoproto import *
2010-03-20 16:27:48 +11:00
from samba_python import *
from samba_deps import *
2010-03-28 14:09:36 +11:00
from samba_bundled import *
2010-04-01 22:19:32 +11:00
import samba_install
2010-03-24 16:56:57 -06:00
import samba_conftests
2010-04-18 12:43:15 +10:00
import samba_abi
2010-04-02 21:32:42 +11:00
import tru64cc
2010-04-03 09:19:57 +11:00
import irixcc
2010-12-07 23:42:15 +03:00
import hpuxcc
2010-04-03 09:19:57 +11:00
import generic_cc
2010-04-04 10:06:34 +10:00
import samba_dist
2010-05-04 10:08:43 +02:00
import samba_wildcard
2010-10-14 16:24:50 +11:00
import stale_files
2010-10-30 11:07:40 +11:00
import symbols
2010-11-03 11:14:40 +11:00
import pkgconfig
2010-04-01 17:24:02 +11:00
# some systems have broken threading in python
if os . environ . get ( ' WAF_NOTHREADS ' ) == ' 1 ' :
import nothreads
2010-02-23 12:18:04 +11:00
2010-02-26 22:21:50 +11:00
LIB_PATH = " shared "
2010-02-23 12:18:04 +11:00
2010-03-22 16:37:47 +11:00
os . putenv ( ' PYTHONUNBUFFERED ' , ' 1 ' )
2010-03-17 20:12:16 +11:00
2010-04-15 08:55:26 +10:00
2010-10-06 18:55:38 +11:00
if Constants . HEXVERSION < 0x105019 :
2010-04-15 08:55:26 +10:00
Logs . error ( '''
Please use the version of waf that comes with Samba , not
a system installed version . See http : / / wiki . samba . org / index . php / Waf
2010-04-15 09:14:10 +10:00
for details .
2011-02-07 14:43:52 +11:00
Alternatively , please run . / configure and make as usual . That will
call the right version of waf . ''' )
2010-04-15 08:55:26 +10:00
sys . exit ( 1 )
2010-02-22 11:59:06 +11:00
@conf
def SAMBA_BUILD_ENV ( conf ) :
2010-03-28 22:01:04 +11:00
''' create the samba build environment '''
2010-04-08 21:46:20 +10:00
conf . env . BUILD_DIRECTORY = conf . blddir
2010-03-17 20:12:16 +11:00
mkdir_p ( os . path . join ( conf . blddir , LIB_PATH ) )
2010-11-05 02:30:01 +01:00
mkdir_p ( os . path . join ( conf . blddir , LIB_PATH , " private " ) )
2010-09-05 20:16:50 +02:00
mkdir_p ( os . path . join ( conf . blddir , " modules " ) )
2010-03-17 20:12:16 +11:00
mkdir_p ( os . path . join ( conf . blddir , ' python/samba/dcerpc ' ) )
2010-03-16 16:41:14 +11:00
# this allows all of the bin/shared and bin/python targets
# to be expressed in terms of build directory paths
2010-04-24 20:02:44 +02:00
mkdir_p ( os . path . join ( conf . blddir , ' default ' ) )
2010-09-04 02:18:31 +02:00
for p in [ ' python ' , ' shared ' , ' modules ' ] :
2010-03-17 08:50:49 +11:00
link_target = os . path . join ( conf . blddir , ' default/ ' + p )
if not os . path . lexists ( link_target ) :
os . symlink ( ' ../ ' + p , link_target )
2010-03-27 16:47:43 +11:00
# get perl to put the blib files in the build directory
blib_bld = os . path . join ( conf . blddir , ' default/pidl/blib ' )
blib_src = os . path . join ( conf . srcdir , ' pidl/blib ' )
mkdir_p ( blib_bld + ' /man1 ' )
mkdir_p ( blib_bld + ' /man3 ' )
2010-03-29 15:19:13 +11:00
if os . path . islink ( blib_src ) :
os . unlink ( blib_src )
2010-03-29 22:32:03 +11:00
elif os . path . exists ( blib_src ) :
2010-03-29 15:19:13 +11:00
shutil . rmtree ( blib_src )
2010-03-17 20:12:16 +11:00
2010-03-17 20:32:15 +11:00
2010-03-17 20:12:16 +11:00
def ADD_INIT_FUNCTION ( bld , subsystem , target , init_function ) :
2010-03-28 22:01:04 +11:00
''' add an init_function to the list for a subsystem '''
2010-03-17 20:26:03 +11:00
if init_function is None :
return
bld . ASSERT ( subsystem is not None , " You must specify a subsystem for init_function ' %s ' " % init_function )
2010-02-23 19:23:18 +11:00
cache = LOCAL_CACHE ( bld , ' INIT_FUNCTIONS ' )
2010-02-23 12:18:04 +11:00
if not subsystem in cache :
2010-03-20 16:27:48 +11:00
cache [ subsystem ] = [ ]
2010-03-17 20:12:16 +11:00
cache [ subsystem ] . append ( { ' TARGET ' : target , ' INIT_FUNCTION ' : init_function } )
2010-03-17 20:26:03 +11:00
Build . BuildContext . ADD_INIT_FUNCTION = ADD_INIT_FUNCTION
2010-02-21 00:24:28 +11:00
2010-03-28 22:01:04 +11:00
2010-02-21 00:24:28 +11:00
#################################################################
2010-03-01 09:01:48 +11:00
def SAMBA_LIBRARY ( bld , libname , source ,
2010-02-23 08:04:00 +11:00
deps = ' ' ,
public_deps = ' ' ,
2010-03-20 16:27:48 +11:00
includes = ' ' ,
2010-02-23 11:17:06 +11:00
public_headers = None ,
2010-03-27 09:46:50 +11:00
header_path = None ,
2010-03-27 18:14:06 +11:00
pc_files = None ,
2010-02-23 08:04:00 +11:00
vnum = None ,
2010-10-27 02:54:56 +02:00
soname = None ,
2010-02-24 17:38:12 +11:00
cflags = ' ' ,
2010-12-08 14:52:43 +11:00
ldflags = ' ' ,
2010-03-17 20:12:16 +11:00
external_library = False ,
2010-02-26 22:25:31 +11:00
realname = None ,
2010-03-17 21:46:38 +11:00
autoproto = None ,
2010-10-30 11:07:40 +11:00
group = ' libraries ' ,
2010-03-20 16:27:48 +11:00
depends_on = ' ' ,
2010-03-18 23:47:48 +11:00
local_include = True ,
2010-03-24 16:23:10 -06:00
vars = None ,
2010-03-18 23:47:48 +11:00
install_path = None ,
install = True ,
2010-10-10 04:25:50 +02:00
pyembed = False ,
2010-10-21 15:25:44 +11:00
pyext = False ,
2010-03-29 15:19:13 +11:00
target_type = ' LIBRARY ' ,
2010-03-28 14:09:36 +11:00
bundled_extension = True ,
2010-03-29 15:19:13 +11:00
link_name = None ,
2010-12-09 11:10:45 +11:00
abi_directory = None ,
2010-04-18 12:43:15 +10:00
abi_match = None ,
hide_symbols = False ,
2010-05-31 12:08:01 +02:00
manpages = None ,
2010-10-20 18:17:13 +11:00
private_library = False ,
2010-10-21 11:22:36 +11:00
grouping_library = False ,
2010-03-18 23:47:48 +11:00
enabled = True ) :
2010-03-28 22:01:04 +11:00
''' define a Samba library '''
2010-03-18 23:47:48 +11:00
if not enabled :
SET_TARGET_TYPE ( bld , libname , ' DISABLED ' )
return
2010-02-23 14:43:06 +11:00
2010-03-24 16:23:10 -06:00
source = bld . EXPAND_VARIABLES ( source , vars = vars )
2010-02-23 16:48:38 +11:00
# remember empty libraries, so we can strip the dependencies
2010-04-25 21:00:44 +10:00
if ( ( source == ' ' ) or ( source == [ ] ) ) and deps == ' ' and public_deps == ' ' :
2010-03-20 16:27:48 +11:00
SET_TARGET_TYPE ( bld , libname , ' EMPTY ' )
2010-02-23 16:48:38 +11:00
return
2010-06-18 09:45:15 +02:00
if BUILTIN_LIBRARY ( bld , libname ) :
2010-03-21 11:04:57 +11:00
obj_target = libname
else :
obj_target = libname + ' .objlist '
2010-03-18 23:47:48 +11:00
2010-10-30 11:07:40 +11:00
if group == ' libraries ' :
subsystem_group = ' main '
else :
subsystem_group = group
2010-03-18 23:47:48 +11:00
# first create a target for building the object files for this library
# by separating in this way, we avoid recompiling the C files
# separately for the install library and the build library
bld . SAMBA_SUBSYSTEM ( obj_target ,
source = source ,
deps = deps ,
public_deps = public_deps ,
includes = includes ,
public_headers = public_headers ,
2010-03-27 09:46:50 +11:00
header_path = header_path ,
2010-03-18 23:47:48 +11:00
cflags = cflags ,
2010-10-30 11:07:40 +11:00
group = subsystem_group ,
2010-03-18 23:47:48 +11:00
autoproto = autoproto ,
depends_on = depends_on ,
2010-04-18 12:43:15 +10:00
hide_symbols = hide_symbols ,
2010-10-21 15:25:44 +11:00
pyext = pyext or ( target_type == " PYTHON " ) ,
2010-03-18 23:47:48 +11:00
local_include = local_include )
2010-06-18 09:45:15 +02:00
if BUILTIN_LIBRARY ( bld , libname ) :
2010-03-21 11:04:57 +11:00
return
2010-03-29 15:19:13 +11:00
if not SET_TARGET_TYPE ( bld , libname , target_type ) :
2010-03-21 11:04:57 +11:00
return
2010-03-18 23:47:48 +11:00
# the library itself will depend on that object target
2010-03-20 16:27:48 +11:00
deps + = ' ' + public_deps
2010-03-18 23:47:48 +11:00
deps = TO_LIST ( deps )
deps . append ( obj_target )
2010-03-09 08:17:43 +11:00
2010-10-17 21:58:22 +11:00
realname = bld . map_shlib_extension ( realname , python = ( target_type == ' PYTHON ' ) )
link_name = bld . map_shlib_extension ( link_name , python = ( target_type == ' PYTHON ' ) )
2010-10-20 18:17:13 +11:00
# we don't want any public libraries without version numbers
2010-10-27 02:54:56 +02:00
if not private_library and vnum is None and soname is None and target_type != ' PYTHON ' and not realname :
2010-10-20 18:17:13 +11:00
raise Utils . WafError ( " public library ' %s ' must have a vnum " % libname )
2010-10-21 11:22:36 +11:00
if target_type == ' PYTHON ' or realname or not private_library :
2010-10-24 11:26:09 -07:00
bundled_name = libname . replace ( ' _ ' , ' - ' )
2010-03-29 15:19:13 +11:00
else :
2010-10-23 23:26:43 +02:00
bundled_name = PRIVATE_NAME ( bld , libname , bundled_extension , private_library )
2010-03-29 15:19:13 +11:00
2010-12-08 14:52:43 +11:00
ldflags = TO_LIST ( ldflags )
2010-04-01 22:19:32 +11:00
features = ' cc cshlib symlink_lib install_lib '
2010-04-01 12:30:56 +11:00
if target_type == ' PYTHON ' :
2010-03-29 15:19:13 +11:00
features + = ' pyext '
2010-10-21 17:44:32 +11:00
if pyext or pyembed :
# this is quite strange. we should add pyext feature for pyext
# but that breaks the build. This may be a bug in the waf python tool
2010-04-01 12:30:56 +11:00
features + = ' pyembed '
2010-04-18 12:43:15 +10:00
2010-12-09 11:10:45 +11:00
if abi_directory :
features + = ' abi_check '
2010-12-09 12:24:48 +11:00
2010-12-17 19:21:47 +01:00
vscript = None
2010-12-09 12:24:48 +11:00
if bld . env . HAVE_LD_VERSION_SCRIPT :
if private_library :
version = " %s _ %s " % ( Utils . g_module . APPNAME , Utils . g_module . VERSION )
2010-12-09 12:30:30 +11:00
elif vnum :
2010-12-09 12:24:48 +11:00
version = " %s _ %s " % ( libname , vnum )
2010-12-09 12:30:30 +11:00
else :
version = None
if version :
2010-12-17 19:21:47 +01:00
vscript = " %s .vscript " % libname
2010-12-17 22:23:52 +01:00
bld . ABI_VSCRIPT ( libname , abi_directory , version , vscript ,
abi_match )
2010-12-09 13:06:22 +11:00
fullname = bld . env . shlib_PATTERN % bundled_name
bld . add_manual_dependency ( bld . path . find_or_declare ( fullname ) , bld . path . find_or_declare ( vscript ) )
2010-12-10 17:59:34 +11:00
if Options . is_install :
# also make the .inst file depend on the vscript
instname = bld . env . shlib_PATTERN % ( bundled_name + ' .inst ' )
bld . add_manual_dependency ( bld . path . find_or_declare ( instname ) , bld . path . find_or_declare ( vscript ) )
2010-12-17 19:38:12 +01:00
vscript = os . path . join ( bld . path . abspath ( bld . env ) , vscript )
2010-03-28 14:09:36 +11:00
2010-03-20 16:27:48 +11:00
bld . SET_BUILD_GROUP ( group )
2010-03-17 21:53:29 +11:00
t = bld (
2010-04-01 22:19:32 +11:00
features = features ,
2010-03-18 23:47:48 +11:00
source = [ ] ,
2010-03-28 14:09:36 +11:00
target = bundled_name ,
2010-03-20 16:27:48 +11:00
depends_on = depends_on ,
2010-12-17 18:42:34 +01:00
samba_ldflags = ldflags ,
2010-03-18 23:47:48 +11:00
samba_deps = deps ,
2010-03-20 16:27:48 +11:00
samba_includes = includes ,
2010-12-17 19:16:33 +01:00
version_script = vscript ,
2010-03-20 16:27:48 +11:00
local_include = local_include ,
2010-03-18 23:47:48 +11:00
vnum = vnum ,
2010-10-27 02:54:56 +02:00
soname = soname ,
2010-03-23 10:00:48 -04:00
install_path = None ,
2010-04-01 22:19:32 +11:00
samba_inst_path = install_path ,
2010-05-31 12:08:01 +02:00
name = libname ,
2010-04-01 22:19:32 +11:00
samba_realname = realname ,
2010-04-18 12:43:15 +10:00
samba_install = install ,
2010-12-09 21:49:01 +11:00
abi_directory = " %s / %s " % ( bld . path . abspath ( ) , abi_directory ) ,
2010-06-13 20:52:47 +02:00
abi_match = abi_match ,
2010-10-21 11:22:36 +11:00
private_library = private_library ,
grouping_library = grouping_library
2010-03-17 20:32:15 +11:00
)
2010-03-18 23:47:48 +11:00
2010-04-26 19:04:33 +10:00
if realname and not link_name :
link_name = ' shared/ %s ' % realname
2010-03-29 15:19:13 +11:00
if link_name :
t . link_name = link_name
2010-03-27 18:14:06 +11:00
if pc_files is not None :
2010-03-29 15:27:54 +11:00
bld . PKG_CONFIG_FILES ( pc_files , vnum = vnum )
2010-03-27 18:14:06 +11:00
2010-06-24 16:02:43 +10:00
if manpages is not None and ' XSLTPROC_MANPAGES ' in bld . env and bld . env [ ' XSLTPROC_MANPAGES ' ] :
2010-05-31 12:17:33 +02:00
bld . MANPAGES ( manpages )
2010-05-31 12:08:01 +02:00
2010-02-21 00:24:28 +11:00
Build . BuildContext . SAMBA_LIBRARY = SAMBA_LIBRARY
2010-03-18 23:47:48 +11:00
2010-02-21 00:24:28 +11:00
#################################################################
2010-03-01 09:01:48 +11:00
def SAMBA_BINARY ( bld , binname , source ,
2010-02-23 08:04:00 +11:00
deps = ' ' ,
2010-03-17 21:53:29 +11:00
includes = ' ' ,
2010-02-23 11:17:06 +11:00
public_headers = None ,
2010-03-27 09:46:50 +11:00
header_path = None ,
2010-02-23 08:04:00 +11:00
modules = None ,
ldflags = None ,
2010-02-24 17:39:23 +11:00
cflags = ' ' ,
2010-02-23 09:04:44 +11:00
autoproto = None ,
2010-04-12 09:30:12 +02:00
use_hostcc = False ,
2010-04-12 10:16:54 +02:00
use_global_deps = True ,
2010-02-23 16:26:59 +11:00
compiler = None ,
2010-03-17 20:12:16 +11:00
group = ' binaries ' ,
2010-03-20 16:27:48 +11:00
manpages = None ,
local_include = True ,
2010-03-17 20:12:16 +11:00
subsystem_name = None ,
2010-10-10 04:25:50 +02:00
pyembed = False ,
2010-03-24 16:23:10 -06:00
vars = None ,
2010-03-18 23:47:48 +11:00
install = True ,
2010-04-29 07:47:19 +10:00
install_path = None ,
enabled = True ) :
2010-03-28 22:01:04 +11:00
''' define a Samba binary '''
2010-03-17 20:26:03 +11:00
2010-04-29 07:47:19 +10:00
if not enabled :
SET_TARGET_TYPE ( bld , binname , ' DISABLED ' )
return
2010-03-17 20:21:47 +11:00
if not SET_TARGET_TYPE ( bld , binname , ' BINARY ' ) :
return
2010-02-23 19:04:40 +11:00
2010-04-01 22:19:32 +11:00
features = ' cc cprogram symlink_bin install_bin '
2010-10-10 04:25:50 +02:00
if pyembed :
2010-03-20 16:27:48 +11:00
features + = ' pyembed '
2010-03-09 08:17:43 +11:00
2010-03-18 23:47:48 +11:00
obj_target = binname + ' .objlist '
2010-03-24 16:23:10 -06:00
source = bld . EXPAND_VARIABLES ( source , vars = vars )
2010-04-25 12:41:41 +10:00
source = unique_list ( TO_LIST ( source ) )
2010-03-24 16:23:10 -06:00
2010-10-30 11:07:40 +11:00
if group == ' binaries ' :
subsystem_group = ' main '
else :
subsystem_group = group
2010-03-18 23:47:48 +11:00
# first create a target for building the object files for this binary
# by separating in this way, we avoid recompiling the C files
# separately for the install binary and the build binary
bld . SAMBA_SUBSYSTEM ( obj_target ,
source = source ,
deps = deps ,
includes = includes ,
cflags = cflags ,
2010-10-30 11:07:40 +11:00
group = subsystem_group ,
2010-03-18 23:47:48 +11:00
autoproto = autoproto ,
subsystem_name = subsystem_name ,
2010-04-12 09:30:12 +02:00
local_include = local_include ,
2010-04-12 10:16:54 +02:00
use_hostcc = use_hostcc ,
2010-10-11 01:09:26 +02:00
pyext = pyembed ,
2010-04-12 10:16:54 +02:00
use_global_deps = use_global_deps )
2010-03-18 23:47:48 +11:00
2010-03-30 20:21:21 +11:00
bld . SET_BUILD_GROUP ( group )
2010-04-01 22:19:32 +11:00
# the binary itself will depend on that object target
2010-03-18 23:47:48 +11:00
deps = TO_LIST ( deps )
deps . append ( obj_target )
2010-04-01 09:49:46 +11:00
t = bld (
2010-04-01 22:19:32 +11:00
features = features ,
2010-03-18 23:47:48 +11:00
source = [ ] ,
2010-03-20 16:27:48 +11:00
target = binname ,
2010-03-18 23:47:48 +11:00
samba_deps = deps ,
2010-03-20 16:27:48 +11:00
samba_includes = includes ,
local_include = local_include ,
samba_modules = modules ,
top = True ,
2010-03-18 23:47:48 +11:00
samba_subsystem = subsystem_name ,
2010-03-23 10:00:48 -04:00
install_path = None ,
2010-04-01 22:19:32 +11:00
samba_inst_path = install_path ,
2010-12-15 14:59:47 +11:00
samba_install = install ,
samba_ldflags = TO_LIST ( ldflags )
2010-03-20 16:27:48 +11:00
)
2010-02-23 14:43:06 +11:00
2010-06-24 16:02:43 +10:00
if manpages is not None and ' XSLTPROC_MANPAGES ' in bld . env and bld . env [ ' XSLTPROC_MANPAGES ' ] :
2010-05-31 12:17:33 +02:00
bld . MANPAGES ( manpages )
2010-05-31 01:35:43 +02:00
2010-03-20 16:27:48 +11:00
Build . BuildContext . SAMBA_BINARY = SAMBA_BINARY
2010-02-23 13:04:34 +11:00
2010-02-23 08:04:00 +11:00
2010-03-17 20:26:03 +11:00
#################################################################
2010-03-01 09:01:48 +11:00
def SAMBA_MODULE ( bld , modname , source ,
2010-02-23 08:04:00 +11:00
deps = ' ' ,
2010-03-20 16:27:48 +11:00
includes = ' ' ,
2010-03-17 20:26:03 +11:00
subsystem = None ,
init_function = None ,
2010-11-01 12:29:04 +11:00
module_init_name = ' samba_init_module ' ,
2010-02-23 08:04:00 +11:00
autoproto = None ,
2010-03-20 16:27:48 +11:00
autoproto_extra_source = ' ' ,
2010-02-24 17:39:23 +11:00
cflags = ' ' ,
2010-03-17 20:12:16 +11:00
internal_module = True ,
2010-03-20 16:27:48 +11:00
local_include = True ,
2010-03-24 16:23:10 -06:00
vars = None ,
2010-10-10 21:22:02 +02:00
enabled = True ,
2010-12-14 15:38:03 +03:00
pyembed = False ,
2010-10-10 21:22:02 +02:00
) :
2010-03-28 22:01:04 +11:00
''' define a Samba module. '''
2010-03-20 16:27:48 +11:00
2010-06-15 01:24:20 +02:00
source = bld . EXPAND_VARIABLES ( source , vars = vars )
2010-06-15 20:35:22 +02:00
if internal_module or BUILTIN_LIBRARY ( bld , modname ) :
bld . SAMBA_SUBSYSTEM ( modname , source ,
2010-06-15 01:24:20 +02:00
deps = deps ,
includes = includes ,
autoproto = autoproto ,
autoproto_extra_source = autoproto_extra_source ,
cflags = cflags ,
local_include = local_include ,
enabled = enabled )
2010-06-10 13:02:59 +02:00
bld . ADD_INIT_FUNCTION ( subsystem , modname , init_function )
2010-03-20 16:27:48 +11:00
return
2010-03-17 20:21:47 +11:00
2010-03-20 16:27:48 +11:00
if not enabled :
SET_TARGET_TYPE ( bld , modname , ' DISABLED ' )
2010-03-17 20:21:47 +11:00
return
2010-10-21 08:27:07 +11:00
obj_target = modname + ' .objlist '
realname = modname
if subsystem is not None :
deps + = ' ' + subsystem
while realname . startswith ( " lib " + subsystem + " _ " ) :
realname = realname [ len ( " lib " + subsystem + " _ " ) : ]
while realname . startswith ( subsystem + " _ " ) :
realname = realname [ len ( subsystem + " _ " ) : ]
realname = bld . make_libname ( realname )
while realname . startswith ( " lib " ) :
realname = realname [ len ( " lib " ) : ]
build_link_name = " modules/ %s / %s " % ( subsystem , realname )
if init_function :
2010-11-01 12:29:04 +11:00
cflags + = " -D %s = %s " % ( init_function , module_init_name )
2010-10-21 08:27:07 +11:00
bld . SAMBA_LIBRARY ( modname ,
source ,
deps = deps ,
cflags = cflags ,
realname = realname ,
autoproto = autoproto ,
local_include = local_include ,
vars = vars ,
link_name = build_link_name ,
install_path = " $ {MODULESDIR} / %s " % subsystem ,
pyembed = pyembed ,
)
2010-03-17 20:26:03 +11:00
Build . BuildContext . SAMBA_MODULE = SAMBA_MODULE
2010-03-17 20:21:47 +11:00
2010-03-17 20:26:03 +11:00
#################################################################
2010-03-01 09:01:48 +11:00
def SAMBA_SUBSYSTEM ( bld , modname , source ,
2010-02-23 08:04:00 +11:00
deps = ' ' ,
public_deps = ' ' ,
2010-03-20 16:27:48 +11:00
includes = ' ' ,
2010-02-23 11:17:06 +11:00
public_headers = None ,
2010-03-27 09:46:50 +11:00
header_path = None ,
2010-02-24 17:38:12 +11:00
cflags = ' ' ,
2010-03-17 17:47:31 +11:00
cflags_end = None ,
2010-02-24 17:38:12 +11:00
group = ' main ' ,
2010-03-17 21:46:38 +11:00
init_function_sentinal = None ,
2010-03-17 21:53:29 +11:00
autoproto = None ,
2010-03-20 16:27:48 +11:00
autoproto_extra_source = ' ' ,
depends_on = ' ' ,
local_include = True ,
local_include_first = True ,
2010-03-17 20:12:16 +11:00
subsystem_name = None ,
enabled = True ,
2010-04-12 09:30:12 +02:00
use_hostcc = False ,
2010-04-12 10:16:54 +02:00
use_global_deps = True ,
2010-03-24 16:23:10 -06:00
vars = None ,
2010-04-18 12:43:15 +10:00
hide_symbols = False ,
2010-10-10 21:22:02 +02:00
pyext = False ) :
2010-03-28 22:01:04 +11:00
''' define a Samba subsystem '''
2010-03-20 16:27:48 +11:00
if not enabled :
SET_TARGET_TYPE ( bld , modname , ' DISABLED ' )
2010-03-17 20:21:47 +11:00
return
# remember empty subsystems, so we can strip the dependencies
2010-04-25 21:00:44 +10:00
if ( ( source == ' ' ) or ( source == [ ] ) ) and deps == ' ' and public_deps == ' ' :
2010-03-20 16:27:48 +11:00
SET_TARGET_TYPE ( bld , modname , ' EMPTY ' )
return
if not SET_TARGET_TYPE ( bld , modname , ' SUBSYSTEM ' ) :
2010-03-17 20:21:47 +11:00
return
2010-03-24 16:23:10 -06:00
source = bld . EXPAND_VARIABLES ( source , vars = vars )
2010-04-25 12:41:41 +10:00
source = unique_list ( TO_LIST ( source ) )
2010-03-24 16:23:10 -06:00
2010-03-20 16:27:48 +11:00
deps + = ' ' + public_deps
2010-03-17 20:21:47 +11:00
2010-02-24 17:39:23 +11:00
bld . SET_BUILD_GROUP ( group )
2010-03-20 16:27:48 +11:00
2010-03-17 20:12:16 +11:00
features = ' cc '
2010-10-10 21:22:02 +02:00
if pyext :
features + = ' pyext '
2010-03-17 20:12:16 +11:00
2010-03-17 21:46:38 +11:00
t = bld (
2010-03-17 20:12:16 +11:00
features = features ,
2010-03-20 16:27:48 +11:00
source = source ,
target = modname ,
2010-04-18 12:43:15 +10:00
samba_cflags = CURRENT_CFLAGS ( bld , modname , cflags , hide_symbols = hide_symbols ) ,
2010-03-20 16:27:48 +11:00
depends_on = depends_on ,
samba_deps = TO_LIST ( deps ) ,
samba_includes = includes ,
local_include = local_include ,
2010-03-17 20:12:16 +11:00
local_include_first = local_include_first ,
2010-04-12 09:30:12 +02:00
samba_subsystem = subsystem_name ,
2010-04-12 10:16:54 +02:00
samba_use_hostcc = use_hostcc ,
samba_use_global_deps = use_global_deps
2010-03-20 16:27:48 +11:00
)
2010-03-17 21:53:29 +11:00
2010-03-17 17:47:31 +11:00
if cflags_end is not None :
t . samba_cflags . extend ( TO_LIST ( cflags_end ) )
2010-03-17 21:53:29 +11:00
if autoproto is not None :
2010-04-25 12:41:41 +10:00
bld . SAMBA_AUTOPROTO ( autoproto , source + TO_LIST ( autoproto_extra_source ) )
2010-03-27 09:46:50 +11:00
if public_headers is not None :
bld . PUBLIC_HEADERS ( public_headers , header_path = header_path )
2010-03-17 21:46:38 +11:00
return t
2010-03-17 21:53:29 +11:00
2010-03-27 09:46:50 +11:00
2010-03-17 20:26:03 +11:00
Build . BuildContext . SAMBA_SUBSYSTEM = SAMBA_SUBSYSTEM
2010-04-05 11:25:20 +10:00
def SAMBA_GENERATOR ( bld , name , rule , source = ' ' , target = ' ' ,
2010-03-30 20:21:21 +11:00
group = ' generators ' , enabled = True ,
2010-03-27 13:55:38 +11:00
public_headers = None ,
header_path = None ,
2010-06-28 12:07:55 +10:00
vars = None ,
always = False ) :
2010-03-20 16:27:48 +11:00
''' A generic source generator target '''
if not SET_TARGET_TYPE ( bld , name , ' GENERATOR ' ) :
return
2010-03-20 22:13:53 -04:00
if not enabled :
2010-03-21 13:50:43 +11:00
return
2010-03-20 22:13:53 -04:00
2010-03-20 16:27:48 +11:00
bld . SET_BUILD_GROUP ( group )
2010-03-27 16:47:43 +11:00
t = bld (
2010-03-20 16:27:48 +11:00
rule = rule ,
2010-03-24 16:23:10 -06:00
source = bld . EXPAND_VARIABLES ( source , vars = vars ) ,
2010-03-20 16:27:48 +11:00
target = target ,
2010-03-27 20:00:01 +11:00
shell = isinstance ( rule , str ) ,
2010-03-24 22:10:24 +11:00
on_results = True ,
2010-03-20 16:27:48 +11:00
before = ' cc ' ,
2010-03-20 22:13:53 -04:00
ext_out = ' .c ' ,
2010-12-08 15:03:35 +11:00
samba_type = ' GENERATOR ' ,
vars = [ rule ] ,
2010-03-20 22:13:53 -04:00
name = name )
2010-03-27 13:55:38 +11:00
2010-06-28 12:07:55 +10:00
if always :
t . always = True
2010-03-27 13:55:38 +11:00
if public_headers is not None :
bld . PUBLIC_HEADERS ( public_headers , header_path = header_path )
2010-03-27 16:47:43 +11:00
return t
2010-03-20 16:27:48 +11:00
Build . BuildContext . SAMBA_GENERATOR = SAMBA_GENERATOR
2010-02-24 17:39:23 +11:00
@runonce
def SETUP_BUILD_GROUPS ( bld ) :
2010-03-28 22:01:04 +11:00
''' setup build groups used to ensure that the different build
phases happen consecutively '''
2010-03-17 21:53:29 +11:00
bld . p_ln = bld . srcnode # we do want to see all targets!
2010-02-24 17:39:23 +11:00
bld . env [ ' USING_BUILD_GROUPS ' ] = True
bld . add_group ( ' setup ' )
2010-03-21 13:50:43 +11:00
bld . add_group ( ' build_compiler_source ' )
2010-12-08 14:52:43 +11:00
bld . add_group ( ' vscripts ' )
2010-03-17 21:53:29 +11:00
bld . add_group ( ' base_libraries ' )
2010-03-30 20:21:21 +11:00
bld . add_group ( ' generators ' )
bld . add_group ( ' compiler_prototypes ' )
bld . add_group ( ' compiler_libraries ' )
2010-02-24 17:39:23 +11:00
bld . add_group ( ' build_compilers ' )
bld . add_group ( ' build_source ' )
bld . add_group ( ' prototypes ' )
bld . add_group ( ' main ' )
2010-10-30 11:07:40 +11:00
bld . add_group ( ' symbolcheck ' )
bld . add_group ( ' libraries ' )
2010-03-17 20:12:16 +11:00
bld . add_group ( ' binaries ' )
2010-10-30 11:07:40 +11:00
bld . add_group ( ' syslibcheck ' )
2010-02-24 17:39:23 +11:00
bld . add_group ( ' final ' )
Build . BuildContext . SETUP_BUILD_GROUPS = SETUP_BUILD_GROUPS
def SET_BUILD_GROUP ( bld , group ) :
2010-03-28 22:01:04 +11:00
''' set the current build group '''
2010-02-24 17:39:23 +11:00
if not ' USING_BUILD_GROUPS ' in bld . env :
return
bld . set_group ( group )
Build . BuildContext . SET_BUILD_GROUP = SET_BUILD_GROUP
2010-03-17 20:38:03 +11:00
2010-03-20 16:27:48 +11:00
@conf
def ENABLE_TIMESTAMP_DEPENDENCIES ( conf ) :
2010-03-28 22:01:04 +11:00
""" use timestamps instead of file contents for deps
this currently doesn ' t work " " "
def h_file ( filename ) :
import stat
st = os . stat ( filename )
if stat . S_ISDIR ( st [ stat . ST_MODE ] ) : raise IOError ( ' not a file ' )
m = Utils . md5 ( )
m . update ( str ( st . st_mtime ) )
m . update ( str ( st . st_size ) )
m . update ( filename )
return m . digest ( )
2010-03-20 16:27:48 +11:00
Utils . h_file = h_file
2010-03-17 20:12:16 +11:00
2010-03-28 22:01:04 +11:00
2010-11-21 23:04:43 +11:00
t = Task . simple_task_type ( ' copy_script ' , ' rm -f " $ {LINK_TARGET} " && ln -s " $ { SRC[0].abspath(env)} " $ {LINK_TARGET} ' ,
2010-03-25 14:21:22 +11:00
shell = True , color = ' PINK ' , ext_in = ' .bin ' )
2010-03-17 20:12:16 +11:00
t . quiet = True
@feature ( ' copy_script ' )
@before ( ' apply_link ' )
def copy_script ( self ) :
tsk = self . create_task ( ' copy_script ' , self . allnodes [ 0 ] )
tsk . env . TARGET = self . target
def SAMBA_SCRIPT ( bld , name , pattern , installdir , installname = None ) :
''' used to copy scripts from the source tree into the build directory
for use by selftest '''
source = bld . path . ant_glob ( pattern )
bld . SET_BUILD_GROUP ( ' build_source ' )
for s in TO_LIST ( source ) :
iname = s
if installname != None :
iname = installname
target = os . path . join ( installdir , iname )
tgtdir = os . path . dirname ( os . path . join ( bld . srcnode . abspath ( bld . env ) , ' .. ' , target ) )
mkdir_p ( tgtdir )
t = bld ( features = ' copy_script ' ,
2010-03-18 23:47:48 +11:00
source = s ,
target = target ,
always = True ,
install_path = None )
2010-03-17 20:12:16 +11:00
t . env . LINK_TARGET = target
Build . BuildContext . SAMBA_SCRIPT = SAMBA_SCRIPT
2010-03-17 10:58:07 +11:00
2011-02-01 14:29:35 +11:00
def copy_and_fix_python_path ( task ) :
pattern = ' sys.path.insert(0, " bin/python " ) '
if task . env [ " PYTHONARCHDIR " ] in sys . path and task . env [ " PYTHONDIR " ] in sys . path :
replacement = " "
elif task . env [ " PYTHONARCHDIR " ] == task . env [ " PYTHONDIR " ] :
replacement = """ sys.path.insert(0, " %s " ) """ % task . env [ " PYTHONDIR " ]
else :
replacement = """ sys.path.insert(0, " %s " )
sys . path . insert ( 1 , " %s " ) """ % (task.env[ " PYTHONARCHDIR " ], task.env[ " PYTHONDIR " ])
installed_location = task . outputs [ 0 ] . bldpath ( task . env )
source_file = open ( task . inputs [ 0 ] . srcpath ( task . env ) )
installed_file = open ( installed_location , ' w ' )
for line in source_file :
newline = line
if pattern in line :
newline = line . replace ( pattern , replacement )
installed_file . write ( newline )
installed_file . close ( )
os . chmod ( installed_location , 0755 )
return 0
2010-03-27 09:46:50 +11:00
2010-10-06 20:11:01 +11:00
def install_file ( bld , destdir , file , chmod = MODE_644 , flat = False ,
2010-04-02 00:13:26 +11:00
python_fixup = False , destname = None , base_name = None ) :
2010-03-27 19:12:10 +11:00
''' install a file '''
destdir = bld . EXPAND_VARIABLES ( destdir )
if not destname :
destname = file
if flat :
destname = os . path . basename ( destname )
dest = os . path . join ( destdir , destname )
if python_fixup :
# fixup the python path it will use to find Samba modules
inst_file = file + ' .inst '
bld . SAMBA_GENERATOR ( ' python_ %s ' % destname ,
2011-02-01 14:29:35 +11:00
rule = copy_and_fix_python_path ,
2010-03-27 19:12:10 +11:00
source = file ,
target = inst_file )
file = inst_file
2010-04-02 00:13:26 +11:00
if base_name :
file = os . path . join ( base_name , file )
2010-03-27 19:12:10 +11:00
bld . install_as ( dest , file , chmod = chmod )
2010-10-06 20:11:01 +11:00
def INSTALL_FILES ( bld , destdir , files , chmod = MODE_644 , flat = False ,
2010-04-02 00:13:26 +11:00
python_fixup = False , destname = None , base_name = None ) :
2010-03-27 09:46:50 +11:00
''' install a set of files '''
2010-03-27 19:12:10 +11:00
for f in TO_LIST ( files ) :
install_file ( bld , destdir , f , chmod = chmod , flat = flat ,
2010-04-02 00:13:26 +11:00
python_fixup = python_fixup , destname = destname ,
base_name = base_name )
2010-03-27 09:46:50 +11:00
Build . BuildContext . INSTALL_FILES = INSTALL_FILES
2010-10-06 20:11:01 +11:00
def INSTALL_WILDCARD ( bld , destdir , pattern , chmod = MODE_644 , flat = False ,
2010-04-02 00:13:26 +11:00
python_fixup = False , exclude = None , trim_path = None ) :
2010-03-27 09:46:50 +11:00
''' install a set of files matching a wildcard pattern '''
2010-03-27 15:12:40 +11:00
files = TO_LIST ( bld . path . ant_glob ( pattern ) )
2010-04-02 00:13:26 +11:00
if trim_path :
files2 = [ ]
for f in files :
files2 . append ( os_path_relpath ( f , trim_path ) )
files = files2
2010-03-27 15:12:40 +11:00
if exclude :
for f in files [ : ] :
if fnmatch . fnmatch ( f , exclude ) :
files . remove ( f )
2010-04-02 00:13:26 +11:00
INSTALL_FILES ( bld , destdir , files , chmod = chmod , flat = flat ,
python_fixup = python_fixup , base_name = trim_path )
2010-03-27 09:46:50 +11:00
Build . BuildContext . INSTALL_WILDCARD = INSTALL_WILDCARD
2010-04-19 21:00:36 +10:00
def INSTALL_DIRS ( bld , destdir , dirs ) :
''' install a set of directories '''
2010-04-19 21:54:40 +10:00
destdir = bld . EXPAND_VARIABLES ( destdir )
dirs = bld . EXPAND_VARIABLES ( dirs )
2010-04-19 21:00:36 +10:00
for d in TO_LIST ( dirs ) :
bld . install_dir ( os . path . join ( destdir , d ) )
Build . BuildContext . INSTALL_DIRS = INSTALL_DIRS
2010-05-19 22:13:03 +02:00
re_header = re . compile ( ' #include[ \t ]* " ([^ " ]+) " ' , re . I | re . M )
class header_task ( Task . Task ) :
2010-05-24 02:26:36 +02:00
"""
The public headers ( the one installed on the system ) have both
different paths and contents , so the rename is not enough .
Intermediate . inst . h files are created because path manipulation
may be slow . The substitution is thus performed only once .
"""
2010-05-19 22:13:03 +02:00
name = ' header '
color = ' PINK '
vars = [ ' INCLUDEDIR ' , ' HEADER_DEPS ' ]
2010-05-24 02:26:36 +02:00
2010-05-19 22:13:03 +02:00
def run ( self ) :
txt = self . inputs [ 0 ] . read ( self . env )
2010-05-24 02:26:36 +02:00
# hard-coded string, but only present in samba4 (I promise, you won't feel a thing)
2010-05-19 22:13:03 +02:00
txt = txt . replace ( ' #if _SAMBA_BUILD_ == 4 ' , ' #if 1 \n ' )
2010-05-24 02:26:36 +02:00
# use a regexp to substitute the #include lines in the files
map = self . generator . bld . hnodemap
dirnodes = self . generator . bld . hnodedirs
2010-05-19 22:13:03 +02:00
def repl ( m ) :
if m . group ( 1 ) :
s = m . group ( 1 )
2010-05-24 02:26:36 +02:00
# pokemon headers: gotta catch'em all!
fin = s
if s . startswith ( ' bin/default ' ) :
node = self . generator . bld . srcnode . find_resource ( s . replace ( ' bin/default/ ' , ' ' ) )
if not node :
Logs . warn ( ' could not find the public header for %r ' % s )
elif node . id in map :
fin = map [ node . id ]
else :
Logs . warn ( ' could not find the public header replacement for build header %r ' % s )
else :
# this part is more difficult since the path may be relative to anything
for dirnode in dirnodes :
node = dirnode . find_resource ( s )
if node :
if node . id in map :
fin = map [ node . id ]
break
else :
Logs . warn ( ' could not find the public header replacement for source header %r %r ' % ( s , node ) )
else :
Logs . warn ( ' -> could not find the public header for %r ' % s )
return " #include < %s > " % fin
2010-05-19 22:13:03 +02:00
return ' '
txt = re_header . sub ( repl , txt )
2010-05-24 02:26:36 +02:00
# and write the output file
2010-05-19 22:13:03 +02:00
f = None
try :
f = open ( self . outputs [ 0 ] . abspath ( self . env ) , ' w ' )
f . write ( txt )
finally :
if f :
f . close ( )
2010-05-24 02:26:36 +02:00
@TaskGen.feature ( ' pubh ' )
def make_public_headers ( self ) :
2010-05-19 22:13:03 +02:00
"""
2010-05-24 02:26:36 +02:00
collect the public headers to process and to install , then
create the substitutions ( name and contents )
2010-05-19 22:13:03 +02:00
"""
if not self . bld . is_install :
# install time only (lazy)
return
2010-05-24 02:26:36 +02:00
# keep two variables
# hnodedirs: list of folders for searching the headers
# hnodemap: node ids and replacement string (node objects are unique)
try :
self . bld . hnodedirs . append ( self . path )
except AttributeError :
self . bld . hnodemap = { }
self . bld . hnodedirs = [ self . bld . srcnode , self . path ]
for k in ' source4 source4/include lib/talloc lib/tevent/ source4/lib/ldb/include/ ' . split ( ) :
node = self . bld . srcnode . find_dir ( k )
if node :
self . bld . hnodedirs . append ( node )
2010-05-19 22:13:03 +02:00
header_path = getattr ( self , ' header_path ' , None ) or ' '
for x in self . to_list ( self . headers ) :
# too complicated, but what was the original idea?
if isinstance ( header_path , list ) :
add_dir = ' '
for ( p1 , dir ) in header_path :
lst = self . to_list ( p1 )
for p2 in lst :
if fnmatch . fnmatch ( x , p2 ) :
add_dir = dir
break
else :
continue
break
inst_path = add_dir
else :
inst_path = header_path
dest = ' '
name = x
if x . find ( ' : ' ) != - 1 :
s = x . split ( ' : ' )
name = s [ 0 ]
dest = s [ 1 ]
inn = self . path . find_resource ( name )
2010-05-24 02:26:36 +02:00
2010-05-19 22:13:03 +02:00
if not inn :
raise ValueError ( " could not find the public header %r in %r " % ( name , self . path ) )
out = inn . change_ext ( ' .inst.h ' )
self . create_task ( ' header ' , inn , out )
if not dest :
dest = inn . name
if inst_path :
inst_path = inst_path + ' / '
inst_path = inst_path + dest
self . bld . install_as ( ' $ {INCLUDEDIR} / %s ' % inst_path , out , self . env )
2010-05-24 02:26:36 +02:00
self . bld . hnodemap [ inn . id ] = inst_path
# create a hash (not md5) to make sure the headers are re-created if something changes
val = 0
lst = list ( self . bld . hnodemap . keys ( ) )
lst . sort ( )
for k in lst :
val = hash ( ( val , k , self . bld . hnodemap [ k ] ) )
self . bld . env . HEADER_DEPS = val
2010-03-27 09:46:50 +11:00
def PUBLIC_HEADERS ( bld , public_headers , header_path = None ) :
2010-03-27 13:55:38 +11:00
''' install some headers
header_path may either be a string that is added to the INCLUDEDIR ,
or it can be a dictionary of wildcard patterns which map to destination
directories relative to INCLUDEDIR
'''
2010-05-19 22:13:03 +02:00
bld . SET_BUILD_GROUP ( ' final ' )
ret = bld ( features = [ ' pubh ' ] , headers = public_headers , header_path = header_path )
return ret
2010-03-27 09:46:50 +11:00
Build . BuildContext . PUBLIC_HEADERS = PUBLIC_HEADERS
2010-03-27 18:14:06 +11:00
2010-05-31 12:17:33 +02:00
def MANPAGES ( bld , manpages ) :
''' build and install manual pages '''
bld . env . MAN_XSL = ' http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl '
for m in manpages . split ( ) :
source = m + ' .xml '
bld . SAMBA_GENERATOR ( m ,
source = source ,
target = m ,
2010-05-31 17:51:21 +02:00
group = ' final ' ,
2010-06-24 16:02:43 +10:00
rule = ' $ {XSLTPROC} -o $ {TGT} --nonet $ {MAN_XSL} $ {SRC} '
2010-05-31 12:17:33 +02:00
)
bld . INSTALL_FILES ( ' $ {MANDIR} /man %s ' % m [ - 1 ] , m , flat = True )
Build . BuildContext . MANPAGES = MANPAGES
2010-03-29 08:30:29 +11:00
2010-03-29 16:59:13 +11:00
#############################################################
# give a nicer display when building different types of files
def progress_display ( self , msg , fname ) :
col1 = Logs . colors ( self . color )
col2 = Logs . colors . NORMAL
total = self . position [ 1 ]
n = len ( str ( total ) )
fs = ' [ %% %d d/ %% %d d] %s %% s %% s %% s \n ' % ( n , n , msg )
return fs % ( self . position [ 0 ] , self . position [ 1 ] , col1 , fname , col2 )
2010-03-29 08:30:29 +11:00
def link_display ( self ) :
if Options . options . progress_bar != 0 :
2010-03-29 16:59:13 +11:00
return Task . Task . old_display ( self )
2010-03-29 08:30:29 +11:00
fname = self . outputs [ 0 ] . bldpath ( self . env )
2010-03-29 16:59:13 +11:00
return progress_display ( self , ' Linking ' , fname )
2010-03-29 08:30:29 +11:00
Task . TaskBase . classes [ ' cc_link ' ] . display = link_display
2010-03-29 16:59:13 +11:00
def samba_display ( self ) :
if Options . options . progress_bar != 0 :
return Task . Task . old_display ( self )
2010-04-02 13:06:35 +11:00
targets = LOCAL_CACHE ( self , ' TARGET_TYPE ' )
if self . name in targets :
target_type = targets [ self . name ]
type_map = { ' GENERATOR ' : ' Generating ' ,
' PROTOTYPE ' : ' Generating '
}
if target_type in type_map :
return progress_display ( self , type_map [ target_type ] , self . name )
2010-10-29 11:53:15 +11:00
if len ( self . inputs ) == 0 :
return Task . Task . old_display ( self )
2010-03-29 16:59:13 +11:00
fname = self . inputs [ 0 ] . bldpath ( self . env )
if fname [ 0 : 3 ] == ' ../ ' :
fname = fname [ 3 : ]
ext_loc = fname . rfind ( ' . ' )
if ext_loc == - 1 :
return Task . Task . old_display ( self )
ext = fname [ ext_loc : ]
ext_map = { ' .idl ' : ' Compiling IDL ' ,
' .et ' : ' Compiling ERRTABLE ' ,
' .asn1 ' : ' Compiling ASN1 ' ,
' .c ' : ' Compiling ' }
if ext in ext_map :
return progress_display ( self , ext_map [ ext ] , fname )
return Task . Task . old_display ( self )
Task . TaskBase . classes [ ' Task ' ] . old_display = Task . TaskBase . classes [ ' Task ' ] . display
Task . TaskBase . classes [ ' Task ' ] . display = samba_display
2010-10-30 16:51:20 +04:00
@after ( ' apply_link ' )
@feature ( ' cshlib ' )
def apply_bundle_remove_dynamiclib_patch ( self ) :
if self . env [ ' MACBUNDLE ' ] or getattr ( self , ' mac_bundle ' , False ) :
if not getattr ( self , ' vnum ' , None ) :
try :
self . env [ ' LINKFLAGS ' ] . remove ( ' -dynamiclib ' )
self . env [ ' LINKFLAGS ' ] . remove ( ' -single_module ' )
except ValueError :
pass