diff options
author | David Robillard <d@drobilla.net> | 2018-05-27 15:48:25 +0200 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2020-06-21 18:12:04 +0200 |
commit | ea3a288ed266cc73995289ab249da2df13113626 (patch) | |
tree | 51f8d55e585f12737c024308ca3e40f01b6488e8 /wscript | |
parent | e170dfe1545c33bb54f2b8b6d39c2aff182e96fb (diff) | |
download | serd-ea3a288ed266cc73995289ab249da2df13113626.tar.gz serd-ea3a288ed266cc73995289ab249da2df13113626.tar.bz2 serd-ea3a288ed266cc73995289ab249da2df13113626.zip |
Add model validation
Diffstat (limited to 'wscript')
-rw-r--r-- | wscript | 30 |
1 files changed, 28 insertions, 2 deletions
@@ -37,6 +37,7 @@ def options(ctx): 'no-shared': 'do not build shared library', 'static-progs': 'build programs as static binaries', 'largefile': 'build with large file support on 32-bit systems', + 'no-pcre': 'do not use PCRE, even if present', 'no-posix': 'do not use POSIX functions, even if present'}) @@ -83,6 +84,23 @@ def configure(conf): defines = ['_POSIX_C_SOURCE=200809L'], mandatory = False) + if not Options.options.no_pcre: + autowaf.check_pkg(conf, 'libpcre', + uselib_store='PCRE', + mandatory=False) + + if conf.env.HAVE_PCRE: + if conf.check(cflags=['-pthread'], mandatory=False): + conf.env.PTHREAD_CFLAGS = ['-pthread'] + if conf.env.CC_NAME != 'clang': + conf.env.PTHREAD_LINKFLAGS = ['-pthread'] + elif conf.check(linkflags=['-lpthread'], mandatory=False): + conf.env.PTHREAD_CFLAGS = [] + conf.env.PTHREAD_LINKFLAGS = ['-lpthread'] + else: + conf.env.PTHREAD_CFLAGS = [] + conf.env.PTHREAD_LINKFLAGS = [] + autowaf.set_lib_env(conf, 'serd', SERD_VERSION) conf.write_config_header('serd_config.h', remove=False) @@ -115,6 +133,7 @@ lib_source = ['src/base64.c', 'src/syntax.c', 'src/system.c', 'src/uri.c', + 'src/validate.c', 'src/world.c', 'src/writer.c', 'src/zix/btree.c', @@ -136,6 +155,7 @@ def build(bld): 'includes': ['.', './src'], 'cflags': ['-fvisibility=hidden'], 'lib': ['m'], + 'use': ['PCRE'], 'vnum': SERD_VERSION, 'install_path': '${LIBDIR}'} if bld.env.MSVC_COMPILER: @@ -149,6 +169,7 @@ def build(bld): source = lib_source, name = 'libserd', target = 'serd-%s' % SERD_MAJOR_VERSION, + uselib = 'PCRE', defines = defines + ['SERD_SHARED', 'SERD_INTERNAL'], **lib_args) @@ -158,6 +179,7 @@ def build(bld): source = lib_source, name = 'libserd_static', target = 'serd-%s' % SERD_MAJOR_VERSION, + uselib = 'PCRE', defines = defines + ['SERD_INTERNAL'], **lib_args) @@ -174,6 +196,7 @@ def build(bld): source = lib_source, name = 'libserd_profiled', target = 'serd_profiled', + uselib = 'PCRE', defines = defines + ['SERD_INTERNAL'], **test_args) @@ -202,13 +225,16 @@ def build(bld): target = 'serdi', includes = ['.', './src'], use = 'libserd', + uselib = 'PCRE', lib = lib_args['lib'], + cflags = bld.env.PTHREAD_CFLAGS, + linkflags = bld.env.PTHREAD_LINKFLAGS, install_path = '${BINDIR}') if not bld.env.BUILD_SHARED or bld.env.STATIC_PROGS: obj.use = 'libserd_static' if bld.env.STATIC_PROGS: - obj.env.SHLIB_MARKER = obj.env.STLIB_MARKER - obj.linkflags = ['-static'] + obj.env.SHLIB_MARKER = obj.env.STLIB_MARKER + obj.linkflags += ['-static'] # Documentation if bld.env.DOCS: |