mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-11 15:06:14 +01:00
introspection: Generate separate GIR files for platform specific APIs
For both GLib and GIO. (GObject, GIRepository and GModule don’t have any platform specific APIs.) This is needed for two reasons: * If the same GIR file is shipped on multiple platforms, it has no way to conditionally define/not-define an API based on the platform (like an `#ifdef` in a C header). So we either end up shipping differing GIR APIs on different platforms, or shipping a GIR file which declares APIs which aren’t resolvable by `dlopen()` on certain platforms, and will cause a language runtime error. * The API reference documentation is now generated from the GIR, and similar problems are present there: if the GIR contains different symbols depending on the platform, there is no way to generate API documentation for the union of all of them. The fix is to ensure that there are no conditional symbols in a GIR, by splitting out the platform specific symbols into platform specific GIR files. Platform specific documentation can then be generated from these, in addition to the main, platform agnostic, documentation. The documentation changes will following in a subsequent commit. Signed-off-by: Philip Withnall <pwithnall@gnome.org> Helps: #3037
This commit is contained in:
parent
1f9e44d623
commit
5021d002ab
@ -49,6 +49,61 @@ glib_gir = gnome.generate_gir(libglib,
|
|||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if host_system == 'windows'
|
||||||
|
glib_win32_gir = gnome.generate_gir(libglib,
|
||||||
|
sources: [
|
||||||
|
gi_gen_shared_sources,
|
||||||
|
glib_win32_headers,
|
||||||
|
],
|
||||||
|
namespace: 'GLibWin32',
|
||||||
|
nsversion: '2.0',
|
||||||
|
identifier_prefix: gi_identifier_prefix,
|
||||||
|
symbol_prefix: gi_symbol_prefix,
|
||||||
|
export_packages: 'glib-2.0',
|
||||||
|
header: 'glib.h',
|
||||||
|
includes: [ glib_gir[0] ],
|
||||||
|
install: true,
|
||||||
|
dependencies: [
|
||||||
|
libgobject_dep,
|
||||||
|
],
|
||||||
|
env: gi_gen_env_variables,
|
||||||
|
extra_args: gir_args + [
|
||||||
|
'-DGLIB_COMPILATION',
|
||||||
|
'-DGETTEXT_PACKAGE="dummy"',
|
||||||
|
'--symbol-prefix=glib',
|
||||||
|
'--library-path=' + meson.current_build_dir(),
|
||||||
|
'--library=gobject-2.0',
|
||||||
|
],
|
||||||
|
)
|
||||||
|
else
|
||||||
|
glib_unix_gir = gnome.generate_gir(libglib,
|
||||||
|
sources: [
|
||||||
|
gi_gen_shared_sources,
|
||||||
|
glib_unix_headers,
|
||||||
|
],
|
||||||
|
namespace: 'GLibUnix',
|
||||||
|
nsversion: '2.0',
|
||||||
|
identifier_prefix: gi_identifier_prefix,
|
||||||
|
symbol_prefix: gi_symbol_prefix,
|
||||||
|
export_packages: 'glib-2.0',
|
||||||
|
header: 'glib.h',
|
||||||
|
includes: [ glib_gir[0] ],
|
||||||
|
install: true,
|
||||||
|
dependencies: [
|
||||||
|
libgobject_dep,
|
||||||
|
],
|
||||||
|
env: gi_gen_env_variables,
|
||||||
|
extra_args: gir_args + [
|
||||||
|
'-DGLIB_COMPILATION',
|
||||||
|
'-DGETTEXT_PACKAGE="dummy"',
|
||||||
|
'--symbol-prefix=glib',
|
||||||
|
'--library-path=' + meson.current_build_dir(),
|
||||||
|
'--library=gobject-2.0',
|
||||||
|
'--c-include=glib-unix.h',
|
||||||
|
],
|
||||||
|
)
|
||||||
|
endif
|
||||||
|
|
||||||
# GObject
|
# GObject
|
||||||
gobject_gir = gnome.generate_gir(libgobject,
|
gobject_gir = gnome.generate_gir(libgobject,
|
||||||
sources: [
|
sources: [
|
||||||
@ -112,31 +167,13 @@ gio_gir_sources = [
|
|||||||
application_sources,
|
application_sources,
|
||||||
gdbus_sources,
|
gdbus_sources,
|
||||||
contenttype_sources,
|
contenttype_sources,
|
||||||
unix_sources,
|
|
||||||
win32_sources,
|
|
||||||
settings_sources,
|
settings_sources,
|
||||||
]
|
]
|
||||||
gio_gir_packages = [ 'gio-2.0' ]
|
|
||||||
gio_gir_args = [
|
gio_gir_args = [
|
||||||
'-DGIO_COMPILATION',
|
'-DGIO_COMPILATION',
|
||||||
'-DG_SETTINGS_ENABLE_BACKEND',
|
'-DG_SETTINGS_ENABLE_BACKEND',
|
||||||
'--symbol-prefix=gio',
|
'--symbol-prefix=gio',
|
||||||
]
|
]
|
||||||
if host_system == 'windows'
|
|
||||||
gio_gir_sources += gio_win32_include_headers
|
|
||||||
foreach h: gio_win32_include_headers
|
|
||||||
gio_gir_args += '--c-include=@0@'.format(h)
|
|
||||||
endforeach
|
|
||||||
gio_gir_packages += 'gio-win32-2.0'
|
|
||||||
gio_gir_args += '--pkg=gio-win32-2.0'
|
|
||||||
else
|
|
||||||
gio_gir_sources += gio_unix_include_headers
|
|
||||||
foreach h: gio_unix_include_headers
|
|
||||||
gio_gir_args += '--c-include=@0@'.format(h)
|
|
||||||
endforeach
|
|
||||||
gio_gir_packages += 'gio-unix-2.0'
|
|
||||||
gio_gir_args += '--pkg=gio-unix-2.0'
|
|
||||||
endif
|
|
||||||
|
|
||||||
gio_gir = gnome.generate_gir(libgio,
|
gio_gir = gnome.generate_gir(libgio,
|
||||||
sources: gio_gir_sources,
|
sources: gio_gir_sources,
|
||||||
@ -144,7 +181,7 @@ gio_gir = gnome.generate_gir(libgio,
|
|||||||
nsversion: '2.0',
|
nsversion: '2.0',
|
||||||
identifier_prefix: gi_identifier_prefix,
|
identifier_prefix: gi_identifier_prefix,
|
||||||
symbol_prefix: gi_symbol_prefix,
|
symbol_prefix: gi_symbol_prefix,
|
||||||
export_packages: gio_gir_packages,
|
export_packages: [ 'gio-2.0' ],
|
||||||
header: 'gio/gio.h',
|
header: 'gio/gio.h',
|
||||||
includes: [ glib_gir[0], gmodule_gir[0], gobject_gir[0] ],
|
includes: [ glib_gir[0], gmodule_gir[0], gobject_gir[0] ],
|
||||||
install: true,
|
install: true,
|
||||||
@ -157,6 +194,57 @@ gio_gir = gnome.generate_gir(libgio,
|
|||||||
extra_args: gir_args + gio_gir_args,
|
extra_args: gir_args + gio_gir_args,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if host_system == 'windows'
|
||||||
|
gio_win32_gir_c_includes = []
|
||||||
|
foreach h: gio_win32_include_headers
|
||||||
|
gio_win32_gir_c_includes += '--c-include=@0@'.format(h)
|
||||||
|
endforeach
|
||||||
|
|
||||||
|
gio_win32_gir = gnome.generate_gir(libgio,
|
||||||
|
sources: gio_win32_include_headers + win32_sources,
|
||||||
|
namespace: 'GioWin32',
|
||||||
|
nsversion: '2.0',
|
||||||
|
identifier_prefix: gi_identifier_prefix,
|
||||||
|
symbol_prefix: gi_symbol_prefix,
|
||||||
|
export_packages: [ 'gio-win32-2.0' ],
|
||||||
|
header: 'gio/gio.h',
|
||||||
|
includes: [ glib_gir[0], gmodule_gir[0], gobject_gir[0], gio_gir[0] ],
|
||||||
|
install: true,
|
||||||
|
dependencies: [
|
||||||
|
libglib_dep,
|
||||||
|
libgobject_dep,
|
||||||
|
libgmodule_dep,
|
||||||
|
],
|
||||||
|
env: gi_gen_env_variables,
|
||||||
|
extra_args: gir_args + gio_gir_args + [ '--pkg=gio-win32-2.0' ] + gio_win32_gir_c_includes,
|
||||||
|
)
|
||||||
|
else
|
||||||
|
gio_unix_gir_c_includes = []
|
||||||
|
foreach h: gio_unix_include_headers
|
||||||
|
gio_unix_gir_c_includes += '--c-include=@0@'.format(h)
|
||||||
|
endforeach
|
||||||
|
|
||||||
|
gio_unix_gir = gnome.generate_gir(libgio,
|
||||||
|
sources: gio_unix_include_headers + unix_sources,
|
||||||
|
namespace: 'GioUnix',
|
||||||
|
nsversion: '2.0',
|
||||||
|
identifier_prefix: gi_identifier_prefix,
|
||||||
|
symbol_prefix: gi_symbol_prefix,
|
||||||
|
export_packages: [ 'gio-unix-2.0' ],
|
||||||
|
header: 'gio/gio.h',
|
||||||
|
includes: [ glib_gir[0], gmodule_gir[0], gobject_gir[0], gio_gir[0] ],
|
||||||
|
install: true,
|
||||||
|
dependencies: [
|
||||||
|
libglib_dep,
|
||||||
|
libgobject_dep,
|
||||||
|
libgmodule_dep,
|
||||||
|
],
|
||||||
|
env: gi_gen_env_variables,
|
||||||
|
extra_args: gir_args + gio_gir_args + [ '--pkg=gio-unix-2.0' ] + gio_unix_gir_c_includes,
|
||||||
|
)
|
||||||
|
endif
|
||||||
|
|
||||||
|
# GIRepository
|
||||||
libgirepository_gir_sources = [
|
libgirepository_gir_sources = [
|
||||||
gi_visibility_h,
|
gi_visibility_h,
|
||||||
girepo_headers,
|
girepo_headers,
|
||||||
|
Loading…
Reference in New Issue
Block a user