diff options
author | Mathieu Duponchelle <mathieu.duponchelle@opencreed.com> | 2015-06-07 21:49:46 +0200 |
---|---|---|
committer | Mathieu Duponchelle <mathieu.duponchelle@opencreed.com> | 2015-06-07 22:55:24 +0200 |
commit | fb401ed8d0fd9b4b6b09515ea815be7bd10b34e4 (patch) | |
tree | babcafc1d3c4a6fc3613ca7a2c826b941dd59e69 /modules | |
parent | 9c9e94d5318e1fddd7078f4c96d1fae350114458 (diff) | |
download | meson-fb401ed8d0fd9b4b6b09515ea815be7bd10b34e4.zip meson-fb401ed8d0fd9b4b6b09515ea815be7bd10b34e4.tar.gz meson-fb401ed8d0fd9b4b6b09515ea815be7bd10b34e4.tar.bz2 |
generate_gir: new kwarg: dependencies.
The dependencies will be queried for typelibdir and girdir,
which will get added to the scan and compile commands.
Diffstat (limited to 'modules')
-rw-r--r-- | modules/gnome.py | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/modules/gnome.py b/modules/gnome.py index fdcf827..51bd941 100644 --- a/modules/gnome.py +++ b/modules/gnome.py @@ -95,6 +95,17 @@ class GnomeModule: scan_command += ['--pkg-export=%s' % pkg for pkg in pkgs] else: raise MesonException('Gir export packages must be str or list') + + deps = None + if 'dependencies' in kwargs: + deps = kwargs.pop('dependencies') + if not isinstance (deps, list): + deps = [deps] + for dep in deps: + girdir = dep.held_object.get_variable ("girdir") + if girdir: + scan_command += ["--add-include-path=%s" % girdir] + inc_dirs = None if kwargs.get('include_directories'): inc_dirs = kwargs.pop('include_directories') @@ -121,7 +132,14 @@ class GnomeModule: typelib_output = '%s-%s.typelib' % (ns, nsversion) typelib_cmd = ['g-ir-compiler', scan_target, '--output', '@OUTPUT@'] if inc_dirs: - typelib_cmd += ['--includedir=%s' % inc for inc in inc_dirs.held_object.get_incdirs()] + typelib_cmd += ['--includedir=%s' % inc for inc in + inc_dirs.held_object.get_incdirs()] + if deps: + for dep in deps: + girdir = dep.held_object.get_variable ("girdir") + if girdir: + typelib_cmd += ["--includedir=%s" % girdir] + kwargs['output'] = typelib_output kwargs['command'] = typelib_cmd # Note that this can't be libdir, because e.g. on Debian it points to |