aboutsummaryrefslogtreecommitdiffstats
path: root/wscript
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2018-05-27 15:48:25 +0200
committerDavid Robillard <d@drobilla.net>2020-06-21 18:12:04 +0200
commitea3a288ed266cc73995289ab249da2df13113626 (patch)
tree51f8d55e585f12737c024308ca3e40f01b6488e8 /wscript
parente170dfe1545c33bb54f2b8b6d39c2aff182e96fb (diff)
downloadserd-ea3a288ed266cc73995289ab249da2df13113626.tar.gz
serd-ea3a288ed266cc73995289ab249da2df13113626.tar.bz2
serd-ea3a288ed266cc73995289ab249da2df13113626.zip
Add model validation
Diffstat (limited to 'wscript')
-rw-r--r--wscript30
1 files changed, 28 insertions, 2 deletions
diff --git a/wscript b/wscript
index 18f6f14a..979ff727 100644
--- a/wscript
+++ b/wscript
@@ -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: