diff options
| -rw-r--r-- | README.md | 11 | ||||
| -rw-r--r-- | build/.gitignore | 1 | ||||
| -rw-r--r-- | meson.build | 139 | ||||
| -rw-r--r-- | meson_options.txt | 4 | 
4 files changed, 154 insertions, 1 deletions
| @@ -76,6 +76,17 @@ Other build options (all take either `ON` or `OFF`):  * NO_LOG (default: OFF) - do not compile LOG statements - will make library smaller, but without any diagnostic messages +### Meson +It is possible to use Meson and Ninja to build the project as well (currently available only `master` branch). +Please run: +``` +meson builddir +cd builddir +meson configure # to show available build flags +ninja +``` + +Tests build with bundled Catch is not supported yet with this method.  # Using libnitrokey with Python  To use libnitrokey with Python a [CFFI](http://cffi.readthedocs.io/en/latest/overview.html) library is required (either 2.7+ or 3.0+). It can be installed with: diff --git a/build/.gitignore b/build/.gitignore deleted file mode 100644 index 72e8ffc..0000000 --- a/build/.gitignore +++ /dev/null @@ -1 +0,0 @@ -* diff --git a/meson.build b/meson.build new file mode 100644 index 0000000..79f9d77 --- /dev/null +++ b/meson.build @@ -0,0 +1,139 @@ +project( +  'libnitrokey', 'cpp', +  version : '3.4.1', +  license : 'LGPL-3.0+', +  default_options : [ +    'cpp_std=c++14' +  ], +  meson_version : '>= 0.43.0', +) +cxx = meson.get_compiler('cpp') +host_system = host_machine.system() +pkg = import('pkgconfig') + +test_cflags = [ +  '-Wno-unused-function', +  '-Wcast-qual', +  '-Woverloaded-virtual', +] +add_project_arguments(cxx.get_supported_arguments(test_cflags), language : 'cpp') + +dep_hidapi = dependency('hidapi-libusb') + +inc_libnitrokey = include_directories('libnitrokey') +libnitrokey_args = [] +if not get_option('log') +  libnitrokey_args += ['-DNO_LOG'] +endif +if get_option('log-volatile-data') +  libnitrokey_args += ['-DLOG_VOLATILE_DATA'] +endif +libnitrokey = library( +  'nitokey', +  sources : [ +    'command_id.cc', +    'device.cc', +    'log.cc', +    'version.cc', +    'misc.cc', +    'NitrokeyManager.cc', +    'NK_C_API.cc', +    'DeviceCommunicationExceptions.cpp', +  ], +  include_directories : [ +    inc_libnitrokey, +  ], +  dependencies : [ +    dep_hidapi, +  ], +  cpp_args : libnitrokey_args, +  version : meson.project_version(), +  install : true, +) +install_headers( +  'libnitrokey/CommandFailedException.h', +  'libnitrokey/command.h', +  'libnitrokey/command_id.h', +  'libnitrokey/cxx_semantics.h', +  'libnitrokey/DeviceCommunicationExceptions.h', +  'libnitrokey/device.h', +  'libnitrokey/device_proto.h', +  'libnitrokey/dissect.h', +  'libnitrokey/LibraryException.h', +  'libnitrokey/log.h', +  'libnitrokey/LongOperationInProgressException.h', +  'libnitrokey/misc.h', +  'libnitrokey/version.h', +  'libnitrokey/NitrokeyManager.h', +  'libnitrokey/stick10_commands_0.8.h', +  'libnitrokey/stick10_commands.h', +  'libnitrokey/stick20_commands.h', +  subdir : meson.project_name(), +) + +ext_libnitrokey = declare_dependency( +  link_with : libnitrokey, +  include_directories : inc_libnitrokey, +) + +pkg.generate( +  name : meson.project_name(), +  filebase : 'libnitrokey-1', +  libraries : libnitrokey, +  version : meson.project_version(), +  requires_private : 'hidapi-libusb', +  description : 'Library for communicating with Nitrokey in a clean and easy manner', +  install : true, +) + +if get_option('tests') or get_option('offline-tests') +  # FIXME +  _inc_catch = include_directories('/usr/include/catch') +  if not cxx.has_header('catch.hpp', include_directories : _inc_catch) +    error('Can\'t find catch.hpp') +  endif +  _catch = static_library( +    'catch', +    sources : [ +      'unittest/catch_main.cpp', +    ], +    include_directories : [ +      _inc_catch, +    ], +  ) +  _dep_catch = declare_dependency( +    link_with : _catch, +    include_directories : _inc_catch, +  ) +endif + +tests = [] +if get_option('offline-tests') +  tests += [ +    ['test_offline', 'test_offline.cc'], +    ['test_minimal', 'test_minimal.cc'], +  ] +endif +if get_option('tests') +  tests += [ +    ['test_C_API',  'test_C_API.cpp'], +    ['test1',       'test1.cc'], +    ['test2',       'test2.cc'], +    ['test3',       'test3.cc'], +    ['test_HOTP',   'test_HOTP.cc'], +    ['test_issues', 'test_issues.cc'], +  ] +endif +foreach tst : tests +  test( +    tst[0], +    executable( +      tst[0], +      sources : 'unittest/@0@'.format(tst[1]), +      dependencies : [ +        ext_libnitrokey, +        _dep_catch, +      ], +    ) +  ) +endforeach diff --git a/meson_options.txt b/meson_options.txt new file mode 100644 index 0000000..aaf8195 --- /dev/null +++ b/meson_options.txt @@ -0,0 +1,4 @@ +option('log', type : 'boolean', value : true, description : 'Logging functionality') +option('log-volatile-data', type : 'boolean', value : false, description : 'Log volatile data (debug)') +option('tests', type : 'boolean', value : false, description : 'Compile tests (needs connected PRO device)') +option('offline-tests', type : 'boolean', value : false, description : 'Compile offline tests') | 
