[gnome-control-center/gbsneto/interactive-test-panels: 14/16] build: Reorganize shell libraries and dependencies



commit 14583e9630b2def731ce4128513060a9ba168bdf
Author: Georges Basile Stavracas Neto <georges stavracas gmail com>
Date:   Wed Nov 7 22:16:21 2018 -0200

    build: Reorganize shell libraries and dependencies
    
    This commit does a few different bit interwined things to the
    build steps:
    
     * Make libtestshell and gnome-control-center share more of the
       variables and resouces;
     * Use 'dependencies' instead of 'link_with' for libshell;
     * Add some visual marks as comments;

 shell/meson.build | 109 +++++++++++++++++++++++++++++++++---------------------
 1 file changed, 66 insertions(+), 43 deletions(-)
---
diff --git a/shell/meson.build b/shell/meson.build
index 667faa9b6..1dc181f02 100644
--- a/shell/meson.build
+++ b/shell/meson.build
@@ -34,47 +34,81 @@ i18n.merge_file(
 
 cflags = ['-DGNOMELOCALEDIR="@0@"'.format(control_center_localedir)]
 
-libshell = static_library(
-               'shell',
-              sources : 'cc-shell-model.c',
-  include_directories : [top_inc, common_inc],
-         dependencies : common_deps,
-               c_args : cflags
-)
 
-sources = files(
+# Common sources between gnome-control-center and
+# libtestshell.
+common_sources = files(
   'cc-application.c',
   'cc-log.c',
   'cc-object-storage.c',
   'cc-panel-loader.c',
   'cc-panel.c',
   'cc-shell.c',
-  'main.c'
+  'cc-panel-list.c',
+  'cc-window.c',
 )
 
+
+###################
+# Generated files #
+###################
+
+# Debug
+debug_conf = configuration_data()
+debug_conf.set('BUGREPORT_URL', 'https://gitlab.gnome.org/GNOME/' + meson.project_name() + '/issues/new')
+debug_conf.set10('ENABLE_TRACING', enable_tracing)
+
+common_sources += configure_file(
+          input : 'cc-debug.h.in',
+         output : 'cc-debug.h',
+  configuration : debug_conf
+)
+
+#Resources
 resource_data = files(
   'cc-panel-list.ui',
   'cc-window.ui',
   'help-overlay.ui',
 )
 
-sources += gnome.compile_resources(
-  'resources',
+common_sources += gnome.compile_resources(
+       'resources',
   meson.project_name() + '.gresource.xml',
-  dependencies: resource_data,
-  export: true
+     dependencies : resource_data,
+           export : true
 )
 
-sources += files(
-  'cc-panel-list.c',
-  'cc-window.c'
+
+############
+# libshell #
+############
+
+libshell = static_library(
+               'shell',
+              sources : 'cc-shell-model.c',
+  include_directories : [top_inc, common_inc],
+         dependencies : common_deps,
+               c_args : cflags
 )
 
+libshell_dep = declare_dependency(
+  include_directories : top_inc,
+            link_with : libshell
+)
+
+
+########################
+# gnome-control-center #
+########################
+
+shell_sources = common_sources + files('main.c')
+
 shell_deps = common_deps + [
   libdevice_dep,
   liblanguage_dep,
   libwidgets_dep,
-  x11_dep
+  x11_dep,
+  libshell_dep,
 ]
 
 if enable_cheese
@@ -85,27 +119,21 @@ if host_is_linux_not_s390
   shell_deps += wacom_deps
 endif
 
-# Debug
-debug_conf = configuration_data()
-debug_conf.set('BUGREPORT_URL', 'https://gitlab.gnome.org/GNOME/' + meson.project_name() + '/issues/new')
-debug_conf.set10('ENABLE_TRACING', enable_tracing)
-
-sources += configure_file(
-          input : 'cc-debug.h.in',
-         output : 'cc-debug.h',
-  configuration : debug_conf
-)
-
 executable(
   meson.project_name(),
-               sources,
+         shell_sources,
   include_directories : top_inc,
          dependencies : shell_deps,
                c_args : cflags,
-            link_with : panels_libs + [libshell],
+            link_with : panels_libs,
               install : true
 )
 
+
+##################
+# lipanel_loader #
+##################
+
 # Because it is confusing and somewhat problematic to directly add and compile
 # cc-panel-loader.o by another directory (i.e. the shell search provider), we
 # have to create a library and link it there, just like libshell.la.
@@ -117,23 +145,18 @@ libpanel_loader = static_library(
                c_args : cflags + ['-DCC_PANEL_LOADER_NO_GTYPES']
 )
 
-# libshell_test
-sources = files(
-  'cc-application.c',
-  'cc-log.c',
-  'cc-panel.c',
-  'cc-panel-list.c',
-  'cc-shell.c',
-  'cc-shell-model.c',
-  'cc-object-storage.c',
-)
+
+################
+# libtestshell #
+################
+
 libtestshell = static_library(
            'testshell',
-               sources,
+        common_sources,
   include_directories : top_inc,
-         dependencies : common_deps + [ libwidgets_dep ],
+         dependencies : shell_deps,
                c_args : cflags,
-            link_with : panels_libs
+            link_with : panels_libs,
 )
 libtestshell_dep = declare_dependency(
   include_directories : top_inc,


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]