diff options
Diffstat (limited to 'meson.build')
-rw-r--r-- | meson.build | 119 |
1 files changed, 119 insertions, 0 deletions
diff --git a/meson.build b/meson.build new file mode 100644 index 0000000..08e0f29 --- /dev/null +++ b/meson.build @@ -0,0 +1,119 @@ +project( + 'jsoncpp', + 'cpp', + + # Note: version must be updated in three places when doing a release. This + # annoying process ensures that amalgamate, CMake, and meson all report the + # correct version. + # 1. /meson.build + # 2. /include/json/version.h + # 3. /CMakeLists.txt + # IMPORTANT: also update the SOVERSION!! + version : '1.9.4', + default_options : [ + 'buildtype=release', + 'cpp_std=c++11', + 'warning_level=1'], + license : 'Public Domain', + meson_version : '>= 0.49.0') + + +jsoncpp_headers = files([ + 'include/json/allocator.h', + 'include/json/assertions.h', + 'include/json/config.h', + 'include/json/json_features.h', + 'include/json/forwards.h', + 'include/json/json.h', + 'include/json/reader.h', + 'include/json/value.h', + 'include/json/version.h', + 'include/json/writer.h', +]) +jsoncpp_include_directories = include_directories('include') + +install_headers( + jsoncpp_headers, + subdir : 'json') + +if get_option('default_library') == 'shared' and meson.get_compiler('cpp').get_id() == 'msvc' + dll_export_flag = '-DJSON_DLL_BUILD' + dll_import_flag = '-DJSON_DLL' +else + dll_export_flag = [] + dll_import_flag = [] +endif + +jsoncpp_lib = library( + 'jsoncpp', files([ + 'src/lib_json/json_reader.cpp', + 'src/lib_json/json_value.cpp', + 'src/lib_json/json_writer.cpp', + ]), + soversion : 24, + install : true, + include_directories : jsoncpp_include_directories, + cpp_args: dll_export_flag) + +import('pkgconfig').generate( + libraries : jsoncpp_lib, + version : meson.project_version(), + name : 'jsoncpp', + filebase : 'jsoncpp', + description : 'A C++ library for interacting with JSON') + +# for libraries bundling jsoncpp +jsoncpp_dep = declare_dependency( + include_directories : jsoncpp_include_directories, + link_with : jsoncpp_lib, + version : meson.project_version()) + +# tests +if meson.is_subproject() or not get_option('tests') + subdir_done() +endif + +python = import('python').find_installation() + +jsoncpp_test = executable( + 'jsoncpp_test', files([ + 'src/test_lib_json/jsontest.cpp', + 'src/test_lib_json/main.cpp', + 'src/test_lib_json/fuzz.cpp', + ]), + include_directories : jsoncpp_include_directories, + link_with : jsoncpp_lib, + install : false, + cpp_args: dll_import_flag) +test( + 'unittest_jsoncpp_test', + jsoncpp_test) + +jsontestrunner = executable( + 'jsontestrunner', + 'src/jsontestrunner/main.cpp', + include_directories : jsoncpp_include_directories, + link_with : jsoncpp_lib, + install : false, + cpp_args: dll_import_flag) +test( + 'unittest_jsontestrunner', + python, + args : [ + '-B', + join_paths(meson.current_source_dir(), 'test/runjsontests.py'), + jsontestrunner, + join_paths(meson.current_source_dir(), 'test/data')], + ) +test( + 'jsonchecker_jsontestrunner', + python, + is_parallel : false, + args : [ + '-B', + join_paths(meson.current_source_dir(), 'test/runjsontests.py'), + '--with-json-checker', + jsontestrunner, + join_paths(meson.current_source_dir(), 'test/data')], + workdir : join_paths(meson.current_source_dir(), 'test/data'), + ) |