[pango/pango2: 39/201] Build a single .so
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [pango/pango2: 39/201] Build a single .so
- Date: Sat, 11 Jun 2022 02:22:27 +0000 (UTC)
commit ad772544e84a0b28a0befbf9a8f9797e4eb537d3
Author: Matthias Clasen <mclasen redhat com>
Date: Sat Feb 12 08:31:12 2022 -0500
Build a single .so
Drop the separate libpangoft2, libpangowin32, etc.
examples/meson.build | 2 +-
pango/meson.build | 356 +++++++++++++--------------------------------------
tests/meson.build | 38 +++---
utils/meson.build | 9 +-
4 files changed, 114 insertions(+), 291 deletions(-)
---
diff --git a/examples/meson.build b/examples/meson.build
index 3919823c..d96fe7d2 100644
--- a/examples/meson.build
+++ b/examples/meson.build
@@ -8,7 +8,7 @@ if pango_cairo_backends.contains('png')
]
endif
-examples_deps = [ libpango_dep, libpangocairo_dep, ]
+examples_deps = [ libpango_dep ]
# somebody will have to fix this
# if host_system == 'windows'
diff --git a/pango/meson.build b/pango/meson.build
index 2769b1d3..b0a8f31f 100644
--- a/pango/meson.build
+++ b/pango/meson.build
@@ -58,6 +58,95 @@ pango_headers = [
'pango-utils.h',
]
+pango_gir_includes = [
+ 'HarfBuzz-0.0',
+ 'GObject-2.0',
+]
+
+if cairo_dep.found()
+ pango_headers += [
+ 'pangocairo.h',
+ ]
+
+ pango_sources += [
+ 'pangocairo-context.c',
+ 'pangocairo-font.c',
+ 'pangocairo-fontmap.c',
+ 'pangocairo-render.c',
+ ]
+
+ if pango_font_backends.contains('freetype')
+ pango_sources += [
+ 'pangocairo-fcfont.c',
+ 'pangocairo-fcfontmap.c',
+ ]
+ endif
+
+ if pango_font_backends.contains('win32')
+ pango_sources += [
+ 'pangocairo-win32font.c',
+ 'pangocairo-win32fontmap.c',
+ ]
+ endif
+
+ if pango_font_backends.contains('quartz')
+ pango_sources += [
+ 'pangocoretext.c',
+ 'pangocoretext-fontmap.c',
+ 'pangocairo-coretextfont.c',
+ 'pangocairo-coretextfontmap.c',
+ ]
+ endif
+
+ pango_gir_includes += [
+ 'cairo-1.0',
+ ]
+endif
+
+if build_pangoft2
+ pango_headers += [
+ 'pangofc-font.h',
+ 'pangofc-fontmap.h',
+ 'pangofc-decoder.h',
+ ]
+
+ pango_sources += [
+ 'pangofc-font.c',
+ 'pangofc-fontmap.c',
+ 'pangofc-decoder.c',
+ 'pango-trace.c',
+ ]
+
+ pango_gir_includes += [
+ 'fontconfig-2.0',
+ 'freetype2-2.0',
+ ]
+endif
+
+if host_system == 'windows'
+ pango_headers += [
+ 'pangowin32.h',
+ ]
+
+ pango_sources += [
+ 'pangowin32.c',
+ 'pangowin32-fontcache.c',
+ 'pangowin32-fontmap.c',
+ ]
+
+ pango_deps += [
+ cc.find_library('gdi32'),
+ ]
+
+ pangowin32_rc = configure_file(
+ input: 'pangowin32.rc.in',
+ output: 'pangowin32.rc',
+ configuration: pango_features_conf,
+ )
+ pangowin32_res = import('windows').compile_resources(pangowin32_rc)
+ pango_sources += pangowin32_res
+endif
+
pango_installed_headers = pango_headers + [ 'pango-version-macros.h' ]
install_headers(pango_installed_headers, subdir: pango_api_path)
@@ -122,7 +211,7 @@ libpango = library(
link_args: common_ldflags,
)
-pango_dep_sources = [pango_enum_h]
+pango_dep_sources = [ pango_enum_h ]
gir = find_program('g-ir-scanner', required : get_option('introspection'))
build_gir = gir.found() and (not meson.is_cross_build() or get_option('introspection').enabled())
@@ -148,7 +237,7 @@ if build_gir
symbol_prefix: 'pango',
export_packages: 'pango',
dependencies: pango_deps,
- includes: [ 'HarfBuzz-0.0', 'GObject-2.0', 'cairo-1.0', ],
+ includes: pango_gir_includes,
header: 'pango/pango.h',
install: true,
extra_args: gir_args,
@@ -177,266 +266,3 @@ pkgconfig.generate(libpango,
filebase: 'pango',
subdirs: pango_api_name,
)
-
-# FreeType
-if build_pangoft2
- pangofc_headers = [
- 'pangofc-font.h',
- 'pangofc-fontmap.h',
- 'pangofc-decoder.h',
- ]
-
- pangofc_public_sources = [
- 'pangofc-font.c',
- 'pangofc-fontmap.c',
- 'pangofc-decoder.c',
- 'pango-trace.c',
- ]
-
- pangoft2_headers = [
- ]
-
- pangoft2_public_sources = [
- ]
-
- pangoft2_sources = pangofc_public_sources + pangoft2_public_sources
-
- if host_system == 'windows'
- pangoft2_rc = configure_file(
- input: 'pangoft2.rc.in',
- output: 'pangoft2.rc',
- configuration: pango_features_conf,
- )
- pangoft2_res = import('windows').compile_resources(pangoft2_rc)
- pangoft2_sources += pangoft2_res
- endif
-
- install_headers(pangoft2_headers + pangofc_headers, subdir: pango_api_path)
-
- libpangoft2 = library(
- 'pangoft2-@0@'.format(pango_api_version),
- sources: pangoft2_sources,
- version: pango_libversion,
- soversion: pango_soversion,
- darwin_versions : pango_osxversion,
- install: true,
- dependencies: pango_deps + [ libpango_dep ],
- include_directories: [ root_inc, pango_inc ],
- c_args: common_cflags + pango_debug_cflags + pango_cflags + [
- '-DPANGO_DISABLE_DEPRECATION_WARNINGS',
- ],
- link_args: common_ldflags,
- )
-
- pangoft2_dep_sources = []
-
- if build_gir
- pangofc_gir = gnome.generate_gir(
- libpangoft2,
- sources: pangofc_headers + pangofc_public_sources,
- dependencies: [ libpango_dep, pango_gir_dep ],
- namespace: 'PangoFc',
- nsversion: pango_api_version,
- identifier_prefix: 'PangoFc',
- symbol_prefix: 'pango_fc',
- export_packages: 'pangofc',
- includes: [ pango_gir[0], 'fontconfig-2.0', ],
- header: 'pango/pangofc-fontmap.h',
- install: true,
- extra_args: gir_args,
- )
- pangofc_gir_dep = declare_dependency(sources: pangofc_gir)
- pangoft2_dep_sources += pangofc_gir
- endif
-
- libpangoft2_dep = declare_dependency(
- link_with: libpangoft2,
- include_directories: pango_inc,
- dependencies: pango_deps + [ libpango_dep ],
- sources: pangoft2_dep_sources,
- )
- meson.override_dependency('pangoft2', libpangoft2_dep)
-
- pkgconfig.generate(
- name: 'Pango FC',
- description: 'Fontconfig support for Pango',
- filebase: 'pangofc',
- subdirs: pango_api_name,
- requires: [ 'pangoft2' ],
- )
-endif
-
-# Win32
-if host_system == 'windows'
- pangowin32_headers = [
- 'pangowin32.h',
- ]
-
- pangowin32_sources = [
- 'pangowin32.c',
- 'pangowin32-fontcache.c',
- 'pangowin32-fontmap.c',
- ]
-
- pangowin32_deps = pango_deps + [
- libpango_dep,
- cc.find_library('gdi32'),
- ]
-
- pangowin32_rc = configure_file(
- input: 'pangowin32.rc.in',
- output: 'pangowin32.rc',
- configuration: pango_features_conf,
- )
- pangowin32_res = import('windows').compile_resources(pangowin32_rc)
- pangowin32_sources += pangowin32_res
-
- install_headers(pangowin32_headers, subdir: pango_api_path)
-
- libpangowin32 = library(
- 'pangowin32-@0@'.format(pango_api_version),
- sources: pangowin32_sources,
- version: pango_libversion,
- soversion: pango_soversion,
- install: true,
- dependencies: pangowin32_deps,
- include_directories: [ root_inc, pango_inc ],
- c_args: common_cflags + pango_debug_cflags + pango_cflags + [
- '-DPANGO_DISABLE_DEPRECATION_WARNINGS',
- ],
- link_args: common_ldflags,
- )
-
- libpangowin32_dep = declare_dependency(
- link_with: libpangowin32,
- include_directories: root_inc,
- dependencies: pango_deps + [ libpango_dep ],
- )
- meson.override_dependency('pangowin32', libpangowin32_dep)
-
- pkgconfig.generate(libpangowin32,
- name: 'Pango Win32',
- description: 'Win32 GDI font support for Pango',
- filebase: 'pangowin32',
- subdirs: pango_api_name,
- requires: 'pango',
- )
-else
- # For usage as a subproject
- libpangowin32_dep = dependency('', required: false)
-endif
-
-# Cairo
-if cairo_dep.found()
- pangocairo_headers = [
- 'pangocairo.h',
- ]
-
- pangocairo_sources = [
- 'pangocairo-context.c',
- 'pangocairo-font.c',
- 'pangocairo-fontmap.c',
- 'pangocairo-render.c',
- ]
-
- pangocairo_deps = pango_deps + [ libpango_dep ]
-
- if pango_font_backends.contains('freetype')
- pangocairo_sources += [
- 'pangocairo-fcfont.c',
- 'pangocairo-fcfontmap.c',
- ]
-
- pangocairo_deps += [ libpangoft2_dep ]
- endif
-
- if host_system == 'windows' and pango_font_backends.contains('win32')
- pangocairo_sources += [
- 'pangocairo-win32font.c',
- 'pangocairo-win32fontmap.c',
- ]
-
- pangocairo_rc = configure_file(
- input: 'pangocairo.rc.in',
- output: 'pangocairo.rc',
- configuration: pango_features_conf,
- )
- pangocairo_res = import('windows').compile_resources(pangocairo_rc)
- pangocairo_sources += pangocairo_res
-
- pangocairo_deps += cc.find_library('gdi32')
- pangocairo_deps += libpangowin32_dep
- endif
-
- if host_system == 'darwin' and pango_font_backends.contains('quartz')
- pangocairo_sources += [
- 'pangocoretext.c',
- 'pangocoretext-fontmap.c',
- 'pangocairo-coretextfont.c',
- 'pangocairo-coretextfontmap.c',
- ]
- endif
-
- install_headers(pangocairo_headers, subdir: pango_api_path)
-
- libpangocairo = library(
- 'pangocairo-@0@'.format(pango_api_version),
- sources: pangocairo_sources,
- version: pango_libversion,
- soversion: pango_soversion,
- darwin_versions : pango_osxversion,
- install: true,
- dependencies: pango_deps + pangocairo_deps,
- include_directories: [ root_inc, pango_inc ],
- c_args: common_cflags + pango_debug_cflags + pango_cflags + [
- '-DPANGO_DISABLE_DEPRECATION_WARNINGS',
- ],
- link_args: common_ldflags
- )
- pangocairo_dep_sources = []
-
- if build_gir
- pangocairo_gir = gnome.generate_gir(
- libpangocairo,
- sources: pangocairo_headers + pangocairo_sources,
- dependencies: [ pangocairo_deps, pango_gir_dep ],
- namespace: 'PangoCairo',
- nsversion: pango_api_version,
- identifier_prefix: 'PangoCairo',
- symbol_prefix: 'pango_cairo',
- export_packages: 'pangocairo',
- includes: [ pango_gir[0], 'GObject-2.0', 'cairo-1.0' ],
- header: 'pango/pangocairo.h',
- install: true,
- extra_args: gir_args,
- )
- pangocairo_dep_sources += pangocairo_gir
- endif
-
- libpangocairo_dep = declare_dependency(
- link_with: libpangocairo,
- include_directories: root_inc,
- dependencies: pango_deps + [ libpango_dep ],
- sources: pangocairo_dep_sources,
- )
- meson.override_dependency('pangocairo', libpangocairo_dep)
-
- # Create pangocairo.pc according to whether we found Cairo
- # manually
- if ['pkgconfig', 'internal'].contains(cairo_found_type)
- pango_cairo_requires = [ 'pango', cairo_pc ]
- else
- pango_cairo_requires = [ 'pango' ]
- endif
-
- pkgconfig.generate(libpangocairo,
- name: 'Pango Cairo',
- description: 'Cairo rendering support for Pango',
- filebase: 'pangocairo',
- subdirs: pango_api_name,
- requires: pango_cairo_requires,
- )
-else
- # For usage as a subproject
- libpangocairo_dep = dependency('', required: false)
-endif
diff --git a/tests/meson.build b/tests/meson.build
index 961abcea..2d9a91dc 100644
--- a/tests/meson.build
+++ b/tests/meson.build
@@ -32,43 +32,43 @@ endif
if cairo_dep.found()
test_cflags += '-DHAVE_CAIRO'
tests += [
- [ 'test-bidi', [ 'test-bidi.c' ], [ libpangocairo_dep ] ],
- [ 'testcontext', [ 'testcontext.c' ], [ libpangocairo_dep ] ],
- [ 'testiter', [ 'testiter.c' ], [ libpangocairo_dep ] ],
- [ 'test-ellipsize', [ 'test-ellipsize.c' ], [ libpangocairo_dep ] ],
- [ 'markup-parse', [ 'markup-parse.c' , 'test-common.c' ], [ libpangocairo_dep ] ],
- [ 'test-itemize', [ 'test-itemize.c', 'test-common.c' ], [ libpangocairo_dep ] ],
- [ 'test-shape', [ 'test-shape.c', 'test-common.c' ], [ libpangocairo_dep ] ],
- [ 'test-font', [ 'test-font.c' ], [ libpangocairo_dep ] ],
- [ 'testattributes', [ 'testattributes.c', 'test-common.c' ], [ libpangocairo_dep ] ],
- [ 'cxx-test', [ 'cxx-test.cpp' ], [ libpangocairo_dep, gobject_dep, harfbuzz_dep ] ],
- [ 'test-harfbuzz', [ 'test-harfbuzz.c' ], [ libpangocairo_dep, gobject_dep, harfbuzz_dep ] ],
- [ 'test-break', [ 'test-break.c', 'test-common.c', 'validate-log-attrs.c' ], [libpangocairo_dep,
glib_dep, harfbuzz_dep ] ],
+ [ 'test-bidi', [ 'test-bidi.c' ] ],
+ [ 'testcontext', [ 'testcontext.c' ] ],
+ [ 'testiter', [ 'testiter.c' ] ],
+ [ 'test-ellipsize', [ 'test-ellipsize.c' ] ],
+ [ 'markup-parse', [ 'markup-parse.c' , 'test-common.c' ] ],
+ [ 'test-itemize', [ 'test-itemize.c', 'test-common.c' ] ],
+ [ 'test-shape', [ 'test-shape.c', 'test-common.c' ] ],
+ [ 'test-font', [ 'test-font.c' ] ],
+ [ 'testattributes', [ 'testattributes.c', 'test-common.c' ] ],
+ [ 'cxx-test', [ 'cxx-test.cpp' ] ],
+ [ 'test-harfbuzz', [ 'test-harfbuzz.c' ] ],
+ [ 'test-break', [ 'test-break.c', 'test-common.c', 'validate-log-attrs.c' ] ],
]
if build_pangoft2
tests += [
- [ 'testmisc', [ 'testmisc.c' ], [ libpangocairo_dep, glib_dep, harfbuzz_dep ] ],
- [ 'testserialize', [ 'testserialize.c' ], [ libpangocairo_dep, libpangoft2_dep ] ],
+ [ 'testmisc', [ 'testmisc.c' ] ],
+ [ 'testserialize', [ 'testserialize.c' ] ],
]
if host_system != 'darwin'
tests += [
- [ 'test-layout', [ 'test-layout.c', 'test-common.c' ], [ libpangocairo_dep, libpangoft2_dep ] ],
- [ 'test-fonts', [ 'test-fonts.c', 'test-common.c' ], [ libpangocairo_dep, libpangoft2_dep ] ],
+ [ 'test-layout', [ 'test-layout.c', 'test-common.c' ] ],
+ [ 'test-fonts', [ 'test-fonts.c', 'test-common.c' ] ],
]
endif
endif
if host_system != 'darwin'
tests += [
- [ 'testrandom', [ 'testrandom.c' ], [ libpangocairo_dep, gio_dep ] ],
+ [ 'testrandom', [ 'testrandom.c' ] ],
]
endif
if pango_cairo_backends.contains('png')
tests += [
- [ 'test-pangocairo-threads', [ 'test-pangocairo-threads.c' ], [ libpangocairo_dep, cairo_dep ] ],
+ [ 'test-pangocairo-threads', [ 'test-pangocairo-threads.c' ] ],
]
endif
endif
@@ -283,7 +283,7 @@ foreach t: tests
install_dir: installed_test_datadir)
bin = executable(name, src,
- dependencies: deps,
+ dependencies: deps + [ libpango_dep ],
include_directories: root_inc,
c_args: common_cflags + pango_debug_cflags + test_cflags,
cpp_args: common_cppflags + pango_debug_cflags + test_cflags,
diff --git a/utils/meson.build b/utils/meson.build
index 03a4eaf8..f3db3492 100644
--- a/utils/meson.build
+++ b/utils/meson.build
@@ -18,8 +18,8 @@ if x11_dep.found()
pango_view_sources += [
'viewer-x.c',
]
- pango_view_deps += [ x11_dep ]
extra_cflags += [ '-DHAVE_X' ]
+ pango_view_deps += [ x11_dep ]
endif
if cairo_dep.found()
@@ -27,7 +27,6 @@ if cairo_dep.found()
'viewer-cairo.c',
'viewer-pangocairo.c',
]
- pango_view_deps += libpangocairo_dep
endif
pango_view = executable('pango-view', pango_view_sources,
@@ -63,8 +62,7 @@ if cairo_dep.found()
pango_list_deps = [
pango_deps,
- libpango_dep,
- libpangocairo_dep
+ libpango_dep
]
pango_list = executable('pango-list', pango_list_sources,
@@ -82,8 +80,7 @@ if cairo_dep.found()
pango_segmentation_deps = [
pango_deps,
- libpango_dep,
- libpangocairo_dep
+ libpango_dep
]
pango_segmentation = executable('pango-segmentation',
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]