| Index: meson.build |
| =================================================================== |
| --- a/meson.build |
| +++ b/meson.build |
| @@ -1,44 +1,59 @@ |
| -project('adblockpluscore', license: ['GPL3'], meson_version: '>0.40.0') |
| +project('adblockpluscore', 'cpp', license: ['GPL3'], meson_version: '>0.40.0') |
| -# locate emscripten-config |
| -python = import('python3').find_python() |
| -emscripten_config = get_option('emscripten-config') |
| -command = run_command(python, '-c', 'import os.path, sys;print(os.path.expanduser(sys.argv[1]))', emscripten_config) |
| -if command.returncode() != 0 |
| - error(command.stderr().strip()) |
| +native = get_option('native') |
| +if native |
| + target_type='native' |
| +else |
| + target_type='js' |
| endif |
| -emscripten_config = command.stdout().strip() |
| -message('Emscripten config file: ' + emscripten_config) |
| -# locate emcc |
| -command = run_command(python, '-c', 'import sys;exec(open(sys.argv[1]).read());print(EMSCRIPTEN_ROOT)', emscripten_config) |
| -if command.returncode() != 0 |
| - error(command.stderr().strip()) |
| +if target_type == 'js' |
| + # locate emscripten-config |
| + python = import('python3').find_python() |
| + emscripten_config = get_option('emscripten-config') |
| + command = run_command(python, '-c', 'import os.path, sys;print(os.path.expanduser(sys.argv[1]))', emscripten_config) |
| + if command.returncode() != 0 |
| + error(command.stderr().strip()) |
| + endif |
| + emscripten_config = command.stdout().strip() |
| + message('Emscripten config file: ' + emscripten_config) |
| + |
| + # locate emcc |
| + command = run_command(python, '-c', 'import sys;exec(open(sys.argv[1]).read());print(EMSCRIPTEN_ROOT)', emscripten_config) |
| + if command.returncode() != 0 |
| + error(command.stderr().strip()) |
| + endif |
| + emcc = join_paths(command.stdout().strip(), 'emcc') |
| + emcc = find_program(emcc) |
| + |
| + # locate node |
| + command = run_command(python, '-c', 'import sys;exec(open(sys.argv[1]).read());print(NODE_JS)', emscripten_config) |
| + if command.returncode() != 0 |
| + error(command.stderr().strip()) |
| + endif |
| + nodejs = find_program(command.stdout().strip(), 'node', 'nodejs') |
| endif |
| -emcc = join_paths(command.stdout().strip(), 'emcc') |
| -emcc = find_program(emcc) |
| - |
| -# locate node |
| -command = run_command(python, '-c', 'import sys;exec(open(sys.argv[1]).read());print(NODE_JS)', emscripten_config) |
| -if command.returncode() != 0 |
| - error(command.stderr().strip()) |
| -endif |
| -nodejs = find_program(command.stdout().strip(), 'node', 'nodejs') |
| JS_LIBRARY = files(join_paths('compiled', 'library.js')) |
| BINDINGS_JS_LIBRARY = files(join_paths('compiled', 'bindings', 'library.js')) |
| BINDINGS_GENERATOR = 'bindings.cpp.js' |
| BINDINGS_OUTPUT = 'bindings.js' |
| COMPILER_OUTPUT = 'compiled.js' |
| # params for emcc compilation |
| -ADDITIONAL_PARAMS = [ '-O3', '-m32', '-std=c++1z', '--memory-init-file', '0', |
| - '--emit-symbol-map', '-Wall', '-Werror', |
| +ADDITIONAL_PARAMS = [ '-O3', '-std=c++1z', '-Wall', '-Werror', |
| '-fno-rtti' ] |
| +if target_type == 'js' |
| +# CXXFLAGS specific to emcc |
| + ADDITIONAL_PARAMS += [ '-m32', '--memory-init-file', '0', |
| + '--emit-symbol-map' ] |
| +else |
| + ADDITIONAL_PARAMS += [ '-fsanitize=address' ] |
| +endif |
| # additional params just for core |
| CORE_PARAMS = [ '-fno-exceptions' ] |
| DEFINES = [] |
| GENERATION_PARAMS = [ |
| ['SHELL_FILE', '"' + |
| join_paths(meson.source_root(), 'compiled', 'shell.js') + |
| '"'], |
| @@ -81,16 +96,20 @@ |
| core_sources = [ |
| 'compiled/traceInit.cpp', |
| ] |
| # sources for the bindings generator |
| bindings_sources = [ |
| 'compiled/bindings/generator.cpp', |
| 'compiled/bindings/main.cpp', |
| ] |
| +# native sources |
| +native_sources = [ |
| + 'compiled/library.cpp', |
| +] |
| defines_args = [] |
| foreach define : DEFINES |
| defines_args += '-D' + define |
| endforeach |
| generation_args = [] |
| foreach param : GENERATION_PARAMS |
| @@ -98,74 +117,86 @@ |
| generation_args += param[0] + '=' + '@0@'.format(param[1]) |
| endforeach |
| optional_args = [] |
| buildtype = get_option('buildtype') |
| if buildtype.startswith('debug') |
| optional_args += '-DDEBUG' |
| optional_args += '-g3' |
| + if target_type == 'native' |
| + ADDITIONAL_PARAMS += [ '-fsanitize=address' ] |
| + LINK_PARAMS = [ '-fsanitize=address' ] |
| + endif |
| endif |
| tracing = get_option('tracing') |
| if tracing |
| optional_args += '--tracing' |
| endif |
| compiler_args = defines_args + generation_args + ADDITIONAL_PARAMS |
| -# build objects. |
| -core_objects = [] |
| -bindings_objects = [] |
| -shared_objects = [] |
| -foreach group : ['core', 'bindings', 'shared'] |
| - objects = [] |
| - foreach source_file : get_variable(group + '_sources') |
| - output_file = source_file.underscorify() + '.o' |
| - command = [ emcc, '-MD', '-MF', '@DEPFILE@', '-c', '-o', '@OUTPUT@', |
| - '@INPUT@' ] + compiler_args |
| - if group != 'bindings' |
| - command += CORE_PARAMS + optional_args |
| - endif |
| - objects += custom_target(output_file, |
| - input: files(source_file), |
| - output: output_file, |
| - depfile: output_file + '.deps', |
| - command: command) |
| +if target_type == 'js' |
| + # build objects. |
| + core_objects = [] |
| + bindings_objects = [] |
| + shared_objects = [] |
| + foreach group : ['core', 'bindings', 'shared'] |
| + objects = [] |
| + foreach source_file : get_variable(group + '_sources') |
| + output_file = source_file.underscorify() + '.o' |
| + command = [ emcc, '-MD', '-MF', '@DEPFILE@', '-c', '-o', '@OUTPUT@', |
| + '@INPUT@' ] + compiler_args |
| + if group != 'bindings' |
| + command += CORE_PARAMS + optional_args |
| + endif |
| + objects += custom_target(output_file, |
| + input: files(source_file), |
| + output: output_file, |
| + depfile: output_file + '.deps', |
| + command: command) |
| + endforeach |
| + # Ideally, we would call set_variable() here but that doesn't work |
| + # with arrays (see |
| + # https://github.com/mesonbuild/meson/issues/1481). So we have to |
| + # do this shifting dance instead. |
| + core_objects = bindings_objects |
| + bindings_objects = shared_objects |
| + shared_objects = objects |
| endforeach |
| - # Ideally, we would call set_variable() here but that doesn't work with arrays |
| - # (see https://github.com/mesonbuild/meson/issues/1481). So we have to do this |
| - # shifting dance instead. |
| - core_objects = bindings_objects |
| - bindings_objects = shared_objects |
| - shared_objects = objects |
| -endforeach |
| -# link the binding generator |
| -bindings_generator = custom_target(BINDINGS_GENERATOR, |
| - input: bindings_objects + shared_objects, |
| - output: BINDINGS_GENERATOR, |
| - depend_files: [ JS_LIBRARY, BINDINGS_JS_LIBRARY ], |
| - command: [ |
| - emcc, '-o', '@OUTPUT@', |
| - '--js-library', JS_LIBRARY, |
| - '--js-library', BINDINGS_JS_LIBRARY, |
| - '@INPUT@' |
| - ]) |
| -# run the binding generator |
| -bindings_output = custom_target(BINDINGS_OUTPUT, |
| - input: bindings_generator, |
| - output: BINDINGS_OUTPUT, |
| - capture: true, |
| - command: [nodejs, '@INPUT@']) |
| + # link the binding generator |
| + bindings_generator = custom_target(BINDINGS_GENERATOR, |
| + input: bindings_objects + shared_objects, |
| + output: BINDINGS_GENERATOR, |
| + depend_files: [ JS_LIBRARY, BINDINGS_JS_LIBRARY ], |
| + command: [ |
| + emcc, '-o', '@OUTPUT@', |
| + '--js-library', JS_LIBRARY, |
| + '--js-library', BINDINGS_JS_LIBRARY, |
| + '@INPUT@' |
| + ]) |
| + # run the binding generator |
| + bindings_output = custom_target(BINDINGS_OUTPUT, |
| + input: bindings_generator, |
| + output: BINDINGS_OUTPUT, |
| + capture: true, |
| + command: [nodejs, '@INPUT@']) |
| + # link the core |
| + output_file = join_paths(meson.source_root(), 'lib', COMPILER_OUTPUT) |
| + compiler_output = custom_target(COMPILER_OUTPUT, |
| + build_by_default: true, |
| + input: core_objects + shared_objects, |
| + output: COMPILER_OUTPUT, |
| + depend_files: [ JS_LIBRARY ], |
| + command: [ |
| + emcc, '-o', output_file, |
| + '--post-js', bindings_output, |
| + '--js-library', JS_LIBRARY, |
| + '@INPUT@' |
| + ] + compiler_args + optional_args) |
| +else |
| + adblockpluscore = library('adblockpluscore', shared_sources, |
| + native_sources, |
| + cpp_args: ADDITIONAL_PARAMS + CORE_PARAMS, |
| + link_args: LINK_PARAMS) |
| +endif |
| -# link the core |
| -output_file = join_paths(meson.source_root(), 'lib', COMPILER_OUTPUT) |
| -compiler_output = custom_target(COMPILER_OUTPUT, |
| - build_by_default: true, |
| - input: core_objects + shared_objects, |
| - output: COMPILER_OUTPUT, |
| - depend_files: [ JS_LIBRARY ], |
| - command: [ |
| - emcc, '-o', output_file, |
| - '--post-js', bindings_output, |
| - '--js-library', JS_LIBRARY, |
| - '@INPUT@' |
| - ] + compiler_args + optional_args) |