Meson: Support Windows builds

Add the necessary machinery into the Meson definition files so that we
can build for Windows.

Since we don't have Wayland or X support for our use case here, disable
them once we know that we are building for Windows, as they are
(otherwise) enabled by default, and enable the items that need to be
built for Windows builds.

Exclude gtk4-launch from Windows builds as that is something that
is not supported on Windows.

As we won't have gio-unix on Windows, and PangoFT2 is optional, don't use
fallbacks for them when we are on Windows (but do use fallbacks for
gio-win32, as it will be used).

Also, clean up meson.build a bit as we can just force-include
msvc_recommended_pragmas.h from GLib since we depend on GLib, and so we
can handle these warnings from msvc_recommended_pragmas.h instead.

https://bugzilla.gnome.org/show_bug.cgi?id=785210
This commit is contained in:
Chun-wei Fan 2017-08-01 16:49:08 +08:00
parent 73ef640736
commit 18abb78bfd
3 changed files with 56 additions and 34 deletions

View File

@ -121,6 +121,7 @@ gdkmarshal_h = gdk_marshalers[1]
gdkconfig_cdata = configuration_data() gdkconfig_cdata = configuration_data()
gdkconfig_cdata.set('GDK_WINDOWING_X11', x11_enabled) gdkconfig_cdata.set('GDK_WINDOWING_X11', x11_enabled)
gdkconfig_cdata.set('GDK_WINDOWING_WAYLAND', wayland_enabled) gdkconfig_cdata.set('GDK_WINDOWING_WAYLAND', wayland_enabled)
gdkconfig_cdata.set('GDK_WINDOWING_WIN32', win32_enabled)
gdkconfig_cdata.set('GDK_WINDOWING_BROADWAY', broadway_enabled) gdkconfig_cdata.set('GDK_WINDOWING_BROADWAY', broadway_enabled)
gdkconfig_cdata.set('GDK_WINDOWING_MIR', mir_enabled) gdkconfig_cdata.set('GDK_WINDOWING_MIR', mir_enabled)
gdkconfig_cdata.set('GDK_RENDERING_VULKAN', have_vulkan) gdkconfig_cdata.set('GDK_RENDERING_VULKAN', have_vulkan)
@ -160,7 +161,7 @@ gdk_deps = [
gobject_dep, gobject_dep,
epoxy_dep, epoxy_dep,
fontconfig_dep, fontconfig_dep,
giounix_dep, platform_gio_dep,
pangocairo_dep, pangocairo_dep,
vulkan_lib vulkan_lib
] ]

View File

@ -243,7 +243,6 @@ gtk_public_sources = files([
'gtkpopover.c', 'gtkpopover.c',
'gtkpopovermenu.c', 'gtkpopovermenu.c',
'gtkprintcontext.c', 'gtkprintcontext.c',
'gtkprintoperation-portal.c',
'gtkprintoperation.c', 'gtkprintoperation.c',
'gtkprintoperationpreview.c', 'gtkprintoperationpreview.c',
'gtkprintsettings.c', 'gtkprintsettings.c',
@ -812,10 +811,9 @@ gtk_sources += [
gtk_deps = [ gtk_deps = [
gmodule_dep, gmodule_dep,
giounix_dep,
glib_dep, glib_dep,
gobject_dep, gobject_dep,
atkbridge_dep, platform_gio_dep,
pangocairo_dep, pangocairo_dep,
pango_dep, pango_dep,
cairogobj_dep, cairogobj_dep,
@ -840,6 +838,19 @@ if wayland_enabled
gtk_sources += gtk_wayland_sources gtk_sources += gtk_wayland_sources
endif endif
if win32_enabled
gtk_cargs += ['-DGTK_PRINT_BACKENDS="file,lpr"']
gtk_deps += [ giowin32_dep ]
gtk_deps += [cc.find_library('advapi32'),
cc.find_library('comctl32'),
cc.find_library('dwmapi'),
cc.find_library('imm32'),
cc.find_library('setupapi'),
cc.find_library('winmm')]
else
gtk_deps += [ atkbridge_dep, ]
endif
# So we don't add these twice # So we don't add these twice
if x11_enabled or wayland_enabled if x11_enabled or wayland_enabled
gtk_sources += gtk_use_wayland_or_x11_c_sources gtk_sources += gtk_use_wayland_or_x11_c_sources
@ -1012,10 +1023,13 @@ gtk_tools = [
['gtk4-builder-tool', ['gtk-builder-tool.c']], ['gtk4-builder-tool', ['gtk-builder-tool.c']],
['gtk4-update-icon-cache', ['updateiconcache.c']], ['gtk4-update-icon-cache', ['updateiconcache.c']],
['gtk4-encode-symbolic-svg', ['encodesymbolic.c']], ['gtk4-encode-symbolic-svg', ['encodesymbolic.c']],
['gtk4-launch', ['gtk-launch.c']],
['gtk4-query-immodules', ['queryimmodules.c', 'gtkutils.c']], ['gtk4-query-immodules', ['queryimmodules.c', 'gtkutils.c']],
] ]
if os_unix
gtk_tools += ['gtk4-launch', ['gtk-launch.c']]
endif
foreach tool: gtk_tools foreach tool: gtk_tools
tool_name = tool.get(0) tool_name = tool.get(0)
tool_srcs = tool.get(1) tool_srcs = tool.get(1)

View File

@ -104,8 +104,11 @@ os_darwin = false
if host_machine.system().contains('darwin') if host_machine.system().contains('darwin')
os_darwin = true os_darwin = true
elif host_machine.system().contains('mingw') elif host_machine.system() == 'windows'
os_win32 = true os_win32 = true
win32_enabled = true
x11_enabled = false
wayland_enabled = false
elif host_machine.system().contains('linux') elif host_machine.system().contains('linux')
os_linux = true os_linux = true
endif endif
@ -208,25 +211,9 @@ endif
if cc.get_id() == 'msvc' if cc.get_id() == 'msvc'
# Compiler options taken from msvc_recommended_pragmas.h # Compiler options taken from msvc_recommended_pragmas.h
# in GLib, based on _Win32_Programming_ by Rector and Newcomer # in GLib, based on _Win32_Programming_ by Rector and Newcomer
test_cflags = [ test_cflags = []
'-we4002', # too many actual parameters for macro add_project_arguments('-FImsvc_recommended_pragmas.h', language: 'c')
'-we4003', # not enough actual parameters for macro add_project_arguments('-D_USE_MATH_DEFINES', language: 'c')
'-w14010', # single-line comment contains line-continuation character
'-we4013', # 'function' undefined; assuming extern returning int
'-w14016', # no function return type; using int as default
'-we4020', # too many actual parameters
'-we4021', # too few actual parameters
'-we4027', # function declared without formal parameter list
'-we4029', # declared formal parameter list different from definition
'-we4033', # 'function' must return a value
'-we4035', # 'function' : no return value
'-we4045', # array bounds overflow
'-we4047', # different levels of indirection
'-we4049', # terminating line number emission
'-we4053', # an expression of type void was used as an operand
'-we4071', # no function prototype given
'-we4819', # the file contains a character that cannot be represented in the current code page
]
elif cc.get_id() == 'gcc' or cc.get_id() == 'clang' elif cc.get_id() == 'gcc' or cc.get_id() == 'clang'
test_cflags = [ test_cflags = [
'-fno-strict-aliasing', '-fno-strict-aliasing',
@ -317,17 +304,27 @@ glib_dep = dependency('glib-2.0', version: glib_req,
fallback : ['glib', 'libglib_dep']) fallback : ['glib', 'libglib_dep'])
gobject_dep = dependency('gobject-2.0', version: glib_req, gobject_dep = dependency('gobject-2.0', version: glib_req,
fallback : ['glib', 'libgobject_dep']) fallback : ['glib', 'libgobject_dep'])
giounix_dep = dependency('gio-unix-2.0', version: glib_req, required: false, if host_machine.system() == 'windows'
giowin32_dep = dependency('gio-windows-2.0', version: glib_req, required: win32_enabled,
fallback : ['glib', 'libgio_dep']) fallback : ['glib', 'libgio_dep'])
else
giounix_dep = dependency('gio-unix-2.0', version: glib_req, required: false,
fallback : ['glib', 'libgio_dep'])
endif
gmodule_dep = dependency('gmodule-2.0', version: glib_req, gmodule_dep = dependency('gmodule-2.0', version: glib_req,
fallback : ['glib', 'libgmodule_dep']) fallback : ['glib', 'libgmodule_dep'])
cairo_dep = dependency('cairo', version: cairo_req, required : cc.get_id() != 'msvc') cairo_dep = dependency('cairo', version: cairo_req, required : cc.get_id() != 'msvc')
cairogobj_dep = dependency('cairo-gobject', version: cairo_req, required : cc.get_id() != 'msvc') cairogobj_dep = dependency('cairo-gobject', version: cairo_req, required : cc.get_id() != 'msvc')
pango_dep = dependency('pango', version: pango_req, pango_dep = dependency('pango', version: pango_req,
fallback : ['pango', 'libpango_dep']) fallback : ['pango', 'libpango_dep'])
pangoft_dep = dependency('pangoft2', required: wayland_enabled or x11_enabled,
fallback : ['pango', 'libpangoft2_dep']) if wayland_enabled or x11_enabled
pangocairo_dep = dependency('pangocairo', version: pango_req, pangoft_dep = dependency('pangoft2', fallback : ['pango', 'libpangoft2_dep'])
else
pangoft_dep = dependency('pangoft2', required: false)
endif
pangocairo_dep = dependency('pangocairo', version: cairo_req,
fallback : ['pango', 'libpangocairo_dep']) fallback : ['pango', 'libpangocairo_dep'])
pixbuf_dep = dependency('gdk-pixbuf-2.0', version: gdk_pixbuf_req, pixbuf_dep = dependency('gdk-pixbuf-2.0', version: gdk_pixbuf_req,
fallback : ['gdk-pixbuf', 'gdkpixbuf_dep']) fallback : ['gdk-pixbuf', 'gdkpixbuf_dep'])
@ -335,13 +332,19 @@ epoxy_dep = dependency('epoxy', version: epoxy_req,
fallback: ['libepoxy', 'libepoxy_dep']) fallback: ['libepoxy', 'libepoxy_dep'])
atk_dep = dependency('atk', version: atk_req) atk_dep = dependency('atk', version: atk_req)
harfbuzz_dep = dependency('harfbuzz', version: '>= 0.9', required: false) harfbuzz_dep = dependency('harfbuzz', version: '>= 0.9', required: false)
xkbdep = dependency('xkbcommon', version: xkbcommon_req) xkbdep = dependency('xkbcommon', version: xkbcommon_req, required: wayland_enabled)
graphene_dep = dependency('graphene-gobject-1.0', version: graphene_req, graphene_dep = dependency('graphene-gobject-1.0', version: graphene_req,
fallback: ['graphene', 'graphene_dep']) fallback: ['graphene', 'graphene_dep'])
fontconfig_dep = [] # only used in x11 backend fontconfig_dep = [] # only used in x11 backend
atkbridge_dep = [] # only used in x11 backend atkbridge_dep = [] # only used in x11 backend
if host_machine.system() == 'windows'
platform_gio_dep = giowin32_dep
else
platform_gio_dep = giounix_dep
endif
backend_immodules = [] backend_immodules = []
pc_gdk_extra_libs = [] pc_gdk_extra_libs = []
@ -529,9 +532,11 @@ if quartz_enabled
endif endif
if win32_enabled if win32_enabled
pc_gdk_extra_libs += ['-lgdi32', '-limm32', '-lshell32', '-lole32', pc_gdk_extra_libs += ['-lgdi32', '-limm32', '-lshell32', '-lole32']
'-Wl,-luuid', '-lwinmm', '-ldwmapi', '-lsetupapi', if cc.get_id() != 'msvc'
'-lcfgmgr32'] pc_gdk_extra_libs += ['-Wl,-luuid']
endif
pc_gdk_extra_libs += ['-lwinmm', '-ldwmapi', '-lsetupapi', '-lcfgmgr32']
backend_immodules += ['ime'] backend_immodules += ['ime']
endif endif
@ -543,7 +548,9 @@ if cc.has_function('bind_textdomain_codeset', dependencies: libintl_dep)
cdata.set('HAVE_BIND_TEXTDOMAIN_CODESET', 1) cdata.set('HAVE_BIND_TEXTDOMAIN_CODESET', 1)
endif endif
cdata.set('HAVE_GIO_UNIX', giounix_dep.found()) if host_machine.system() != 'windows'
cdata.set('HAVE_GIO_UNIX', giounix_dep.found())
endif
# Check for Vulkan support # Check for Vulkan support
# TODO: move to gsk subfolder maybe? Or will it be used elsewhere too? # TODO: move to gsk subfolder maybe? Or will it be used elsewhere too?