1 # a set of config tests that use the samba_autoconf functions
2 # to test for commonly needed configuration options
4 import os, Build, shutil, Utils, re
5 from Configure import conf
6 from samba_utils import *
9 def CHECK_ICONV(conf, define='HAVE_NATIVE_ICONV'):
10 '''check if the iconv library is installed
11 optionally pass a define'''
12 if conf.CHECK_FUNCS_IN('iconv_open', 'iconv', checklibc=True, headers='iconv.h'):
13 conf.DEFINE(define, 1)
19 def CHECK_LARGEFILE(conf, define='HAVE_LARGEFILE'):
20 '''see what we need for largefile support'''
21 if conf.CHECK_CODE('return !(sizeof(off_t) >= 8)',
24 msg='Checking for large file support'):
26 if conf.CHECK_CODE('return !(sizeof(off_t) >= 8)',
29 cflags='-D_FILE_OFFSET_BITS=64',
30 msg='Checking for -D_FILE_OFFSET_BITS=64'):
31 conf.DEFINE('_FILE_OFFSET_BITS', 64)
37 def CHECK_C_PROTOTYPE(conf, function, prototype, define, headers=None, msg=None):
38 '''verify that a C prototype matches the one on the current system'''
39 if not conf.CHECK_DECLS(function, headers=headers):
42 msg = 'Checking C prototype for %s' % function
43 return conf.CHECK_CODE('%s; void *_x = (void *)%s' % (prototype, function),
53 def CHECK_CHARSET_EXISTS(conf, charset, outcharset='UCS-2LE', headers=None, define=None):
54 '''check that a named charset is able to be used with iconv_open() for conversion
57 msg = 'Checking if can we convert from %s to %s' % (charset, outcharset)
59 define = 'HAVE_CHARSET_%s' % charset.upper().replace('-','_')
60 return conf.CHECK_CODE('''
61 iconv_t cd = iconv_open("%s", "%s");
62 if (cd == 0 || cd == (iconv_t)-1) return -1;
63 ''' % (charset, outcharset),
70 def find_config_dir(conf):
71 '''find a directory to run tests in'''
74 dir = os.path.join(conf.blddir, '.conf_check_%d' % k)
88 conf.fatal('cannot create a configuration test folder %r' % dir)
93 conf.fatal('cannot use the configuration test folder %r' % dir)
97 def CHECK_SHLIB_INTRASINC_NAME_FLAGS(conf, msg):
99 check if the waf default flags for setting the name of lib
108 return conf.check(features='cc cshlib',vnum="1",fragment=snip,msg=msg)
111 def CHECK_SHLIB_W_PYTHON(conf, msg):
112 '''check if we need -undefined dynamic_lookup'''
114 dir = find_config_dir(conf)
120 #include <crt_externs.h>
121 #define environ (*_NSGetEnviron())
123 static PyObject *ldb_module = NULL;
125 extern char **environ;
127 ldb_module = PyImport_ImportModule("ldb");
130 return conf.check(features='cc cshlib',uselib='PYEMBED',fragment=snip,msg=msg)
132 # this one is quite complex, and should probably be broken up
133 # into several parts. I'd quite like to create a set of CHECK_COMPOUND()
134 # functions that make writing complex compound tests like this much easier
136 def CHECK_LIBRARY_SUPPORT(conf, rpath=False, msg=None):
137 '''see if the platform supports building libraries'''
141 msg = "rpath library support"
143 msg = "building library support"
145 dir = find_config_dir(conf)
147 bdir = os.path.join(dir, 'testbuild')
148 if not os.path.exists(bdir):
153 subdir = os.path.join(dir, "libdir")
157 dest = open(os.path.join(subdir, 'lib1.c'), 'w')
158 dest.write('int lib_func(void) { return 42; }\n')
161 dest = open(os.path.join(dir, 'main.c'), 'w')
162 dest.write('int main(void) {return !(lib_func() == 42);}\n')
165 bld = Build.BuildContext()
167 bld.all_envs.update(conf.all_envs)
168 bld.all_envs['default'] = env
169 bld.lst_variants = bld.all_envs.keys()
170 bld.load_dirs(dir, bdir)
172 bld.rescan(bld.srcnode)
174 bld(features='cc cshlib',
175 source='libdir/lib1.c',
176 target='libdir/lib1',
179 o = bld(features='cc cprogram',
185 o.rpath=os.path.join(bdir, 'default/libdir')
187 # compile the program
191 conf.check_message(msg, '', False)
195 lastprog = o.link_task.outputs[0].abspath(env)
198 if 'LD_LIBRARY_PATH' in os.environ:
199 old_ld_library_path = os.environ['LD_LIBRARY_PATH']
201 old_ld_library_path = None
202 ADD_LD_LIBRARY_PATH(os.path.join(bdir, 'default/libdir'))
204 # we need to run the program, try to get its result
205 args = conf.SAMBA_CROSS_ARGS(msg=msg)
206 proc = Utils.pproc.Popen([lastprog] + args, stdout=Utils.pproc.PIPE, stderr=Utils.pproc.PIPE)
207 (out, err) = proc.communicate()
212 w('\nreturncode %r\n' % proc.returncode)
213 ret = (proc.returncode == 0)
216 os.environ['LD_LIBRARY_PATH'] = old_ld_library_path or ''
218 conf.check_message(msg, '', ret)
224 def CHECK_PERL_MANPAGE(conf, msg=None, section=None):
225 '''work out what extension perl uses for manpages'''
229 msg = "perl man%s extension" % section
231 msg = "perl manpage generation"
233 conf.check_message_1(msg)
235 dir = find_config_dir(conf)
237 bdir = os.path.join(dir, 'testbuild')
238 if not os.path.exists(bdir):
241 dest = open(os.path.join(bdir, 'Makefile.PL'), 'w')
243 use ExtUtils::MakeMaker;
246 'EXE_FILES' => [ 'WafTest' ]
250 back = os.path.abspath('.')
252 proc = Utils.pproc.Popen(['perl', 'Makefile.PL'],
253 stdout=Utils.pproc.PIPE,
254 stderr=Utils.pproc.PIPE)
255 (out, err) = proc.communicate()
258 ret = (proc.returncode == 0)
260 conf.check_message_2('not found', color='YELLOW')
264 f = open(os.path.join(bdir,'Makefile'), 'r')
267 m = re.search('MAN%sEXT\s+=\s+(\w+)' % section, man)
269 conf.check_message_2('not found', color='YELLOW')
272 conf.check_message_2(ext)
275 conf.check_message_2('ok')
280 def CHECK_COMMAND(conf, cmd, msg=None, define=None, on_target=True, boolean=False):
281 '''run a command and return result'''
283 msg = 'Checking %s' % ' '.join(cmd)
284 conf.COMPOUND_START(msg)
287 cmd.extend(conf.SAMBA_CROSS_ARGS(msg=msg))
289 ret = Utils.cmd_output(cmd)
291 conf.COMPOUND_END(False)
294 conf.COMPOUND_END('ok')
296 conf.DEFINE(define, '1')
299 conf.COMPOUND_END(ret)
301 conf.DEFINE(define, ret, quote=True)
306 def CHECK_UNAME(conf):
307 '''setup SYSTEM_UNAME_* defines'''
309 for v in "sysname machine release version".split():
310 if not conf.CHECK_CODE('''
312 if (uname(&n) == -1) return -1;
315 define='SYSTEM_UNAME_%s' % v.upper(),
319 headers='sys/utsname.h',
321 msg="Checking uname %s type" % v):
326 def CHECK_INLINE(conf):
327 '''check for the right value for inline'''
328 conf.COMPOUND_START('Checking for inline')
329 for i in ['inline', '__inline__', '__inline']:
330 ret = conf.CHECK_CODE('''
332 static %s foo_t static_foo () {return 0; }
333 %s foo_t foo () {return 0; }''' % (i, i),
334 define='INLINE_MACRO',
339 conf.DEFINE('inline', i, quote=False)
342 conf.COMPOUND_END(ret)
348 def CHECK_XSLTPROC_MANPAGES(conf):
349 '''check if xsltproc can run with the given stylesheets'''
352 if not conf.CONFIG_SET('XSLTPROC'):
353 conf.find_program('xsltproc', var='XSLTPROC')
354 if not conf.CONFIG_SET('XSLTPROC'):
357 s='http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl'
358 conf.CHECK_COMMAND('%s --nonet %s 2> /dev/null' % (conf.env.XSLTPROC, s),
359 msg='Checking for stylesheet %s' % s,
360 define='XSLTPROC_MANPAGES', on_target=False,