[pango/pango2: 39/201] Build a single .so




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]