[gtk+/wip/meson: 68/181] meson: make gtk buildable
- From: Emmanuele Bassi <ebassi src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/meson: 68/181] meson: make gtk buildable
- Date: Wed, 26 Apr 2017 16:33:20 +0000 (UTC)
commit 558cf60882b5e7cc777848deda47dae1bfde40a4
Author: Timm Bäder <mail baedert org>
Date: Tue Aug 23 08:21:54 2016 +0200
meson: make gtk buildable
x11 only
gdk/build_enum.py => build_enum.py | 17 +-
build_marshal.py | 1 -
gdk/Makefile.am | 3 +-
gdk/gdk.gresource.xml | 15 ++
gdk/gdk.gresource.xml.meson | 6 +
gdk/gdkversionmacros.h.meson | 415 ++++++++++++++++++++++++++++++++++++
gdk/meson.build | 279 +++++++++++++++----------
gtk/gentypefuncs.d | 45 ++++
gtk/gtk.gresource.xml | 269 +++++++++++++++++++++++
gtk/gtkwindow.c | 11 +-
gtk/meson.build | 367 ++++++++++++++++++++++++++++++-
meson.build | 77 +++++---
12 files changed, 1338 insertions(+), 167 deletions(-)
---
diff --git a/gdk/build_enum.py b/build_enum.py
similarity index 61%
rename from gdk/build_enum.py
rename to build_enum.py
index 9705497..c8e8322 100755
--- a/gdk/build_enum.py
+++ b/build_enum.py
@@ -6,21 +6,14 @@
# backends is a fool's errand.
import sys, os, shutil, subprocess
-
-# HORRIBLE, use current_source_dir() as an argument instead.
-h_array = ['--template', '../gdk/gdkenumtypes.h.template']
-
-c_array = ['--template', '../gdk/gdkenumtypes.c.template']
-
# [perl, glib-mkenums]
cmd = [sys.argv[1], sys.argv[2]]
-ofilename = sys.argv[3]
-headers = sys.argv[4:]
+template = sys.argv[3]
+ofilename = sys.argv[4]
+headers = sys.argv[5:]
+
-if ofilename.endswith('.h'):
- arg_array = h_array
-else:
- arg_array = c_array
+arg_array = ['--template', template];
pc = subprocess.Popen(cmd + arg_array + headers, stdout=subprocess.PIPE)
(stdo, _) = pc.communicate()
diff --git a/build_marshal.py b/build_marshal.py
index 5ec9cd0..ac09664 100755
--- a/build_marshal.py
+++ b/build_marshal.py
@@ -13,7 +13,6 @@ prefix = sys.argv[2]
ifilename = sys.argv[3]
ofilename = sys.argv[4]
-# HORRIBLE, use current_source_dir() as an argument instead.
h_array = ['--prefix=' + prefix, '--header', '--valist-marshallers']
c_array = ['--prefix=' + prefix, '--body', '--valist-marshallers']
diff --git a/gdk/Makefile.am b/gdk/Makefile.am
index 162016a..2a5b051 100644
--- a/gdk/Makefile.am
+++ b/gdk/Makefile.am
@@ -51,7 +51,8 @@ AM_CPPFLAGS = \
# setup source file variables
#
#
-# GDK header files for public installation (non-generated)
+#
+#GDK header files for public installation (non-generated)
#
#
gdk_public_h_sources = \
diff --git a/gdk/gdk.gresource.xml b/gdk/gdk.gresource.xml
new file mode 100644
index 0000000..6eff39c
--- /dev/null
+++ b/gdk/gdk.gresource.xml
@@ -0,0 +1,15 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<gresources>
+ <gresource prefix='/org/gtk/libgdk'>
+ <file alias='glsl/gl2-texture-2d.fs.glsl'>resources/glsl/gl2-texture-2d.fs.glsl</file>
+ <file alias='glsl/gl2-texture-2d.vs.glsl'>resources/glsl/gl2-texture-2d.vs.glsl</file>
+ <file alias='glsl/gl2-texture-rect.fs.glsl'>resources/glsl/gl2-texture-rect.fs.glsl</file>
+ <file alias='glsl/gl2-texture-rect.vs.glsl'>resources/glsl/gl2-texture-rect.vs.glsl</file>
+ <file alias='glsl/gl3-texture-2d.fs.glsl'>resources/glsl/gl3-texture-2d.fs.glsl</file>
+ <file alias='glsl/gl3-texture-2d.vs.glsl'>resources/glsl/gl3-texture-2d.vs.glsl</file>
+ <file alias='glsl/gl3-texture-rect.fs.glsl'>resources/glsl/gl3-texture-rect.fs.glsl</file>
+ <file alias='glsl/gl3-texture-rect.vs.glsl'>resources/glsl/gl3-texture-rect.vs.glsl</file>
+ <file alias='glsl/gles2-texture.fs.glsl'>resources/glsl/gles2-texture.fs.glsl</file>
+ <file alias='glsl/gles2-texture.vs.glsl'>resources/glsl/gles2-texture.vs.glsl</file>
+ </gresource>
+</gresources>
diff --git a/gdk/gdk.gresource.xml.meson b/gdk/gdk.gresource.xml.meson
new file mode 100644
index 0000000..96cbff4
--- /dev/null
+++ b/gdk/gdk.gresource.xml.meson
@@ -0,0 +1,6 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<gresources>
+ <gresource prefix='/org/gtk/libgdk'>
+@GDK_GRESOURCE_XML_FILES@
+ </gresource>
+</gresources>
diff --git a/gdk/gdkversionmacros.h.meson b/gdk/gdkversionmacros.h.meson
new file mode 100644
index 0000000..1720a08
--- /dev/null
+++ b/gdk/gdkversionmacros.h.meson
@@ -0,0 +1,415 @@
+/* gdkversionmacros.h - version boundaries checks
+ * Copyright (C) 2012 Red Hat, Inc.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.▸ See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, see <http://www.gnu.org/licenses/>.
+ */
+
+#if !defined (__GDK_H_INSIDE__) && !defined (GDK_COMPILATION)
+#error "Only <gdk/gdk.h> can be included directly."
+#endif
+
+#ifndef __GDK_VERSION_MACROS_H__
+#define __GDK_VERSION_MACROS_H__
+
+#include <glib.h>
+
+#mesondefine GDK_MAJOR_VERSION
+#mesondefine GDK_MINOR_VERSION
+#mesondefine GDK_MICRO_VERSION
+
+#ifndef _GDK_EXTERN
+#define _GDK_EXTERN extern
+#endif
+
+/**
+ * GDK_DISABLE_DEPRECATION_WARNINGS:
+ *
+ * A macro that should be defined before including the gdk.h header.
+ * If it is defined, no compiler warnings will be produced for uses
+ * of deprecated GDK and GTK+ APIs.
+ */
+
+#ifdef GDK_DISABLE_DEPRECATION_WARNINGS
+#define GDK_DEPRECATED _GDK_EXTERN
+#define GDK_DEPRECATED_FOR(f) _GDK_EXTERN
+#define GDK_UNAVAILABLE(maj,min) _GDK_EXTERN
+#else
+#define GDK_DEPRECATED G_DEPRECATED _GDK_EXTERN
+#define GDK_DEPRECATED_FOR(f) G_DEPRECATED_FOR(f) _GDK_EXTERN
+#define GDK_UNAVAILABLE(maj,min) G_UNAVAILABLE(maj,min) _GDK_EXTERN
+#endif
+
+/* XXX: Every new stable minor release bump should add a macro here */
+
+/**
+ * GDK_VERSION_3_0:
+ *
+ * A macro that evaluates to the 3.0 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.4
+ */
+#define GDK_VERSION_3_0 (G_ENCODE_VERSION (3, 0))
+
+/**
+ * GDK_VERSION_3_2:
+ *
+ * A macro that evaluates to the 3.2 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.4
+ */
+#define GDK_VERSION_3_2 (G_ENCODE_VERSION (3, 2))
+
+/**
+ * GDK_VERSION_3_4:
+ *
+ * A macro that evaluates to the 3.4 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.4
+ */
+#define GDK_VERSION_3_4 (G_ENCODE_VERSION (3, 4))
+
+/**
+ * GDK_VERSION_3_6:
+ *
+ * A macro that evaluates to the 3.6 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.6
+ */
+#define GDK_VERSION_3_6 (G_ENCODE_VERSION (3, 6))
+
+/**
+ * GDK_VERSION_3_8:
+ *
+ * A macro that evaluates to the 3.8 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.8
+ */
+#define GDK_VERSION_3_8 (G_ENCODE_VERSION (3, 8))
+
+/**
+ * GDK_VERSION_3_10:
+ *
+ * A macro that evaluates to the 3.10 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.10
+ */
+#define GDK_VERSION_3_10 (G_ENCODE_VERSION (3, 10))
+
+/**
+ * GDK_VERSION_3_12:
+ *
+ * A macro that evaluates to the 3.12 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.12
+ */
+#define GDK_VERSION_3_12 (G_ENCODE_VERSION (3, 12))
+
+/**
+ * GDK_VERSION_3_14:
+ *
+ * A macro that evaluates to the 3.14 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.14
+ */
+#define GDK_VERSION_3_14 (G_ENCODE_VERSION (3, 14))
+
+/**
+ * GDK_VERSION_3_16:
+ *
+ * A macro that evaluates to the 3.16 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.16
+ */
+#define GDK_VERSION_3_16 (G_ENCODE_VERSION (3, 16))
+
+/**
+ * GDK_VERSION_3_18:
+ *
+ * A macro that evaluates to the 3.18 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.18
+ */
+#define GDK_VERSION_3_18 (G_ENCODE_VERSION (3, 18))
+
+/**
+ * GDK_VERSION_3_20:
+ *
+ * A macro that evaluates to the 3.20 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.18
+ */
+#define GDK_VERSION_3_20 (G_ENCODE_VERSION (3, 20))
+
+/**
+ * GDK_VERSION_3_22:
+ *
+ * A macro that evaluates to the 3.22 version of GDK, in a format
+ * that can be used by the C pre-processor.
+ *
+ * Since: 3.20
+ */
+#define GDK_VERSION_3_22 (G_ENCODE_VERSION (3, 22))
+
+/* evaluates to the current stable version; for development cycles,
+ * this means the next stable target
+ */
+#if (GDK_MINOR_VERSION % 2)
+#define GDK_VERSION_CUR_STABLE (G_ENCODE_VERSION (GDK_MAJOR_VERSION, GDK_MINOR_VERSION + 1))
+#else
+#define GDK_VERSION_CUR_STABLE (G_ENCODE_VERSION (GDK_MAJOR_VERSION, GDK_MINOR_VERSION))
+#endif
+
+/* evaluates to the previous stable version */
+#if (GDK_MINOR_VERSION % 2)
+#define GDK_VERSION_PREV_STABLE (G_ENCODE_VERSION (GDK_MAJOR_VERSION, GDK_MINOR_VERSION - 1))
+#else
+#define GDK_VERSION_PREV_STABLE (G_ENCODE_VERSION (GDK_MAJOR_VERSION, GDK_MINOR_VERSION - 2))
+#endif
+
+/**
+ * GDK_VERSION_MIN_REQUIRED:
+ *
+ * A macro that should be defined by the user prior to including
+ * the gdk.h header.
+ * The definition should be one of the predefined GDK version
+ * macros: %GDK_VERSION_3_0, %GDK_VERSION_3_2,...
+ *
+ * This macro defines the lower bound for the GDK API to use.
+ *
+ * If a function has been deprecated in a newer version of GDK,
+ * it is possible to use this symbol to avoid the compiler warnings
+ * without disabling warning for every deprecated function.
+ *
+ * Since: 3.4
+ */
+#ifndef GDK_VERSION_MIN_REQUIRED
+# define GDK_VERSION_MIN_REQUIRED (GDK_VERSION_CUR_STABLE)
+#endif
+
+/**
+ * GDK_VERSION_MAX_ALLOWED:
+ *
+ * A macro that should be defined by the user prior to including
+ * the gdk.h header.
+ * The definition should be one of the predefined GDK version
+ * macros: %GDK_VERSION_3_0, %GDK_VERSION_3_2,...
+ *
+ * This macro defines the upper bound for the GDK API to use.
+ *
+ * If a function has been introduced in a newer version of GDK,
+ * it is possible to use this symbol to get compiler warnings when
+ * trying to use that function.
+ *
+ * Since: 3.4
+ */
+#ifndef GDK_VERSION_MAX_ALLOWED
+# if GDK_VERSION_MIN_REQUIRED > GDK_VERSION_PREV_STABLE
+# define GDK_VERSION_MAX_ALLOWED GDK_VERSION_MIN_REQUIRED
+# else
+# define GDK_VERSION_MAX_ALLOWED GDK_VERSION_CUR_STABLE
+# endif
+#endif
+
+/* sanity checks */
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_MIN_REQUIRED
+#error "GDK_VERSION_MAX_ALLOWED must be >= GDK_VERSION_MIN_REQUIRED"
+#endif
+#if GDK_VERSION_MIN_REQUIRED < GDK_VERSION_3_0
+#error "GDK_VERSION_MIN_REQUIRED must be >= GDK_VERSION_3_0"
+#endif
+
+#define GDK_AVAILABLE_IN_ALL _GDK_EXTERN
+
+/* XXX: Every new stable minor release should add a set of macros here */
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_0
+# define GDK_DEPRECATED_IN_3_0 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_0_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_0 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_0_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_0
+# define GDK_AVAILABLE_IN_3_0 GDK_UNAVAILABLE(3, 0)
+#else
+# define GDK_AVAILABLE_IN_3_0 _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_2
+# define GDK_DEPRECATED_IN_3_2 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_2_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_2 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_2_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_2
+# define GDK_AVAILABLE_IN_3_2 GDK_UNAVAILABLE(3, 2)
+#else
+# define GDK_AVAILABLE_IN_3_2 _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_4
+# define GDK_DEPRECATED_IN_3_4 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_4_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_4 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_4_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_4
+# define GDK_AVAILABLE_IN_3_4 GDK_UNAVAILABLE(3, 4)
+#else
+# define GDK_AVAILABLE_IN_3_4 _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_6
+# define GDK_DEPRECATED_IN_3_6 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_6_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_6 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_6_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_6
+# define GDK_AVAILABLE_IN_3_6 GDK_UNAVAILABLE(3, 6)
+#else
+# define GDK_AVAILABLE_IN_3_6 _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_8
+# define GDK_DEPRECATED_IN_3_8 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_8_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_8 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_8_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_8
+# define GDK_AVAILABLE_IN_3_8 GDK_UNAVAILABLE(3, 8)
+#else
+# define GDK_AVAILABLE_IN_3_8 _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_10
+# define GDK_DEPRECATED_IN_3_10 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_10_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_10 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_10_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_10
+# define GDK_AVAILABLE_IN_3_10 GDK_UNAVAILABLE(3, 10)
+#else
+# define GDK_AVAILABLE_IN_3_10 _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_12
+# define GDK_DEPRECATED_IN_3_12 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_12_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_12 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_12_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_12
+# define GDK_AVAILABLE_IN_3_12 GDK_UNAVAILABLE(3, 12)
+#else
+# define GDK_AVAILABLE_IN_3_12 _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_14
+# define GDK_DEPRECATED_IN_3_14 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_14_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_14 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_14_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_14
+# define GDK_AVAILABLE_IN_3_14 GDK_UNAVAILABLE(3, 14)
+#else
+# define GDK_AVAILABLE_IN_3_14 _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_16
+# define GDK_DEPRECATED_IN_3_16 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_16_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_16 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_16_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_16
+# define GDK_AVAILABLE_IN_3_16 GDK_UNAVAILABLE(3, 16)
+#else
+# define GDK_AVAILABLE_IN_3_16 _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_18
+# define GDK_DEPRECATED_IN_3_18 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_18_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_18 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_18_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_18
+# define GDK_AVAILABLE_IN_3_18 GDK_UNAVAILABLE(3, 18)
+#else
+# define GDK_AVAILABLE_IN_3_18 _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_20
+# define GDK_DEPRECATED_IN_3_20 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_20_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_20 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_20_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_20
+# define GDK_AVAILABLE_IN_3_20 GDK_UNAVAILABLE(3, 20)
+#else
+# define GDK_AVAILABLE_IN_3_20 _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MIN_REQUIRED >= GDK_VERSION_3_22
+# define GDK_DEPRECATED_IN_3_22 GDK_DEPRECATED
+# define GDK_DEPRECATED_IN_3_22_FOR(f) GDK_DEPRECATED_FOR(f)
+#else
+# define GDK_DEPRECATED_IN_3_22 _GDK_EXTERN
+# define GDK_DEPRECATED_IN_3_22_FOR(f) _GDK_EXTERN
+#endif
+
+#if GDK_VERSION_MAX_ALLOWED < GDK_VERSION_3_22
+# define GDK_AVAILABLE_IN_3_22 GDK_UNAVAILABLE(3, 22)
+#else
+# define GDK_AVAILABLE_IN_3_22 _GDK_EXTERN
+#endif
+
+#endif /* __GDK_VERSION_MACROS_H__ */
diff --git a/gdk/meson.build b/gdk/meson.build
index 031b7b7..779f824 100644
--- a/gdk/meson.build
+++ b/gdk/meson.build
@@ -1,5 +1,5 @@
deprecated_gdk_sources = ['deprecated/gdkcolor.c']
-gdk_sources = [
+gdk_sources = files([
'gdk-private.c',
'gdk.c',
'gdkapplaunchcontext.c',
@@ -8,6 +8,7 @@ gdk_sources = [
'gdkdeprecated.c',
'gdkdevice.c',
'gdkdevicemanager.c',
+ 'gdkdevicepad.c',
'gdkdisplay.c',
'gdkdisplaymanager.c',
'gdkdnd.c',
@@ -36,19 +37,22 @@ gdk_sources = [
'gdkdevicetool.c',
'gdkdrawingcontext.c',
'gdkmonitor.c'
-]
+])
-gdk_public_h_sources = [
+gdk_public_h_sources = files([
'gdk.h',
'gdk-autocleanup.h',
'gdkapplaunchcontext.h',
'gdkcairo.h',
'gdkcursor.h',
'gdkdevice.h',
+ 'gdkdevicetool.h',
'gdkdevicemanager.h',
+ 'gdkdevicepad.h',
'gdkdisplay.h',
'gdkdisplaymanager.h',
'gdkdnd.h',
+ 'gdkdrawingcontext.h',
'gdkevents.h',
'gdkframetimings.h',
'gdkglcontext.h',
@@ -56,32 +60,31 @@ gdk_public_h_sources = [
'gdkkeysyms.h',
'gdkkeysyms-compat.h',
'gdkmain.h',
+ 'gdkmonitor.h',
'gdkpango.h',
'gdkframeclock.h',
'gdkpixbuf.h',
+ 'gdkprivate.h',
'gdkproperty.h',
'gdkrectangle.h',
'gdkrgba.h',
'gdkscreen.h',
+ 'gdkseat.h',
'gdkselection.h',
'gdktestutils.h',
'gdkthreads.h',
'gdktypes.h',
'gdkvisual.h',
'gdkwindow.h',
- 'gdkseat.h',
- 'gdkmonitor.h',
- 'gdkdrawingcontext.h',
- 'gdkdevicetool.h'
-]
+])
-gdk_private_h_sources = [
+gdk_private_h_sources = files([
'gdkseatdefaultprivate.h',
'gdkdevicetoolprivate.h',
'gdkdrawingcontextprivate.h',
'gdkmonitorprivate.h',
'gdkprivate.h',
-]
+])
gdk_x_sources = [
'x11/MwmUtil.h',
@@ -130,82 +133,106 @@ gdk_x_private_sources = [
'x11/gdkdevicemanagerprivate-core.h',
]
-gdk_wayland_sources = [
- 'wayland/gdkapplaunchcontext-wayland.c',
- 'wayland/gdkcursor-wayland.c',
- 'wayland/gdkdevice-wayland.c',
- 'wayland/gdkdisplay-wayland.c',
- 'wayland/gdkdisplay-wayland.h',
- 'wayland/gdkdnd-wayland.c',
- 'wayland/gdkeventsource.c',
- 'wayland/gdkglcontext-wayland.c',
- 'wayland/gdkglcontext-wayland.h',
- 'wayland/gdkkeys-wayland.c',
- 'wayland/gdkmonitor-wayland.c',
- 'wayland/gdkmonitor-wayland.h',
- 'wayland/gdkscreen-wayland.c',
- 'wayland/gdkseat-wayland.h',
- 'wayland/gdkselection-wayland.c',
- 'wayland/gdkwaylanddevice.h',
- 'wayland/gdkwaylanddisplay.h',
- 'wayland/gdkwaylandglcontext.h',
- 'wayland/gdkwayland.h',
- 'wayland/gdkwaylandmonitor.h',
- 'wayland/gdkwaylandselection.h',
- 'wayland/gdkwaylandwindow.h',
- 'wayland/gdkwindow-wayland.c',
- 'wayland/wm-button-layout-translation.c',
- 'wayland/gtk-primary-selection-protocol.c',
- 'wayland/gtk-shell-protocol.c',
- 'wayland/xdg-shell-unstable-v5-protocol.c',
- 'wayland/pointer-gestures-unstable-v1-protocol.c',
- 'wayland/tablet-unstable-v2-protocol.c',
-]
-
-gdk_wayland_private_sources = [
- 'wayland/gdkprivate-wayland.h',
-]
-
-
-
-gdk_broadway_sources = [
- 'broadway/gdkdisplay-broadway.c',
- 'broadway/gdkdisplay-broadway.h',
- 'broadway/gdkscreen-broadway.c',
- 'broadway/gdkscreen-broadway.h',
- 'broadway/broadway-output.c',
- 'broadway/broadway-output.h',
- 'broadway/broadway-server.h',
- 'broadway/broadway-server.c',
- 'broadway/gdkbroadway-server.c',
- 'broadway/gdkcursor-broadway.c',
- 'broadway/gdkvisual-broadway.c',
- 'broadway/gdkselection-broadway.c',
- 'broadway/gdkwindow-broadway.c',
- 'broadway/gdkwindow-broadway.h',
- 'broadway/gdkmonitor-broadway.c',
- 'broadway/gdkmonitor-broadway.h',
- 'broadway/gdkkeys-broadway.c',
- 'broadway/gdkglobals-broadway.c',
- 'broadway/gdkeventsource.c',
- 'broadway/gdkeventsource.h',
- 'broadway/gdkdnd-broadway.c',
- 'broadway/broadwayd.c',
- 'broadway/gdkdevicemanager-broadway.c',
- 'broadway/gdkdevicemanager-broadway.h',
- 'broadway/gdkdevice-broadway.c',
- 'broadway/gdkdevice-broadway.h',
- 'broadway/broadway-buffer.c',
- 'broadway/broadway-buffer.h',
- 'broadway/gdktestutils-broadway.c',
- 'broadway/gdkproperty-broadway.c'
-]
-
-gdk_broadway_private_sources = [
- 'broadway/gdkprivate-broadway.h'
-]
-
-
+# gdk_wayland_sources = [
+ # 'wayland/gdkapplaunchcontext-wayland.c',
+ # 'wayland/gdkcursor-wayland.c',
+ # 'wayland/gdkdevice-wayland.c',
+ # 'wayland/gdkdisplay-wayland.c',
+ # 'wayland/gdkdisplay-wayland.h',
+ # 'wayland/gdkdnd-wayland.c',
+ # 'wayland/gdkeventsource.c',
+ # 'wayland/gdkglcontext-wayland.c',
+ # 'wayland/gdkglcontext-wayland.h',
+ # 'wayland/gdkkeys-wayland.c',
+ # 'wayland/gdkmonitor-wayland.c',
+ # 'wayland/gdkmonitor-wayland.h',
+ # 'wayland/gdkscreen-wayland.c',
+ # 'wayland/gdkseat-wayland.h',
+ # 'wayland/gdkselection-wayland.c',
+ # 'wayland/gdkwaylanddevice.h',
+ # 'wayland/gdkwaylanddisplay.h',
+ # 'wayland/gdkwaylandglcontext.h',
+ # 'wayland/gdkwayland.h',
+ # 'wayland/gdkwaylandmonitor.h',
+ # 'wayland/gdkwaylandselection.h',
+ # 'wayland/gdkwaylandwindow.h',
+ # 'wayland/gdkwindow-wayland.c',
+ # 'wayland/wm-button-layout-translation.c',
+ # 'wayland/gtk-primary-selection-protocol.c',
+ # 'wayland/gtk-shell-protocol.c',
+ # 'wayland/xdg-shell-unstable-v5-protocol.c',
+ # 'wayland/pointer-gestures-unstable-v1-protocol.c',
+ # 'wayland/tablet-unstable-v2-protocol.c',
+# ]
+
+# gdk_wayland_private_sources = [
+ # 'wayland/gdkprivate-wayland.h',
+# ]
+
+
+
+# gdk_broadway_sources = [
+ # 'broadway/gdkdisplay-broadway.c',
+ # 'broadway/gdkdisplay-broadway.h',
+ # 'broadway/gdkscreen-broadway.c',
+ # 'broadway/gdkscreen-broadway.h',
+ # 'broadway/broadway-output.c',
+ # 'broadway/broadway-output.h',
+ # 'broadway/broadway-server.h',
+ # 'broadway/broadway-server.c',
+ # 'broadway/gdkbroadway-server.c',
+ # 'broadway/gdkcursor-broadway.c',
+ # 'broadway/gdkvisual-broadway.c',
+ # 'broadway/gdkselection-broadway.c',
+ # 'broadway/gdkwindow-broadway.c',
+ # 'broadway/gdkwindow-broadway.h',
+ # 'broadway/gdkmonitor-broadway.c',
+ # 'broadway/gdkmonitor-broadway.h',
+ # 'broadway/gdkkeys-broadway.c',
+ # 'broadway/gdkglobals-broadway.c',
+ # 'broadway/gdkeventsource.c',
+ # 'broadway/gdkeventsource.h',
+ # 'broadway/gdkdnd-broadway.c',
+ # 'broadway/broadwayd.c',
+ # 'broadway/gdkdevicemanager-broadway.c',
+ # 'broadway/gdkdevicemanager-broadway.h',
+ # 'broadway/gdkdevice-broadway.c',
+ # 'broadway/gdkdevice-broadway.h',
+ # 'broadway/broadway-buffer.c',
+ # 'broadway/broadway-buffer.h',
+ # 'broadway/gdktestutils-broadway.c',
+ # 'broadway/gdkproperty-broadway.c'
+# ]
+
+# gdk_broadway_private_sources = [
+ # 'broadway/gdkprivate-broadway.h'
+# ]
+
+# glsl_sources = [
+ # 'gl3-texture-2d.fs.glsl',
+ # 'gl3-texture-2d.vs.glsl',
+ # 'gl3-texture-rect.fs.glsl',
+ # 'gl3-texture-rect.vs.glsl',
+ # 'gl2-texture-2d.fs.glsl',
+ # 'gl2-texture-2d.fs.glsl',
+ # 'gl2-texture-rect.vs.glsl',
+ # 'gl2-texture-rect.vs.glsl',
+ # 'gles2-texture.fs.glsl',
+ # 'gles2-texture.vs.glsl',
+# ]
+# resource_xml = ''
+# foreach glsl_file : glsl_sources
+ # resource_xml += ' <file alias="glsl/@0@">resources/glsl/@0@</file>\n'.format(glsl_file)
+# endforeach
+
+
+# cdata = configuration_data()
+# cdata.set('GDK_GRESOURCE_XML_FILES', resource_xml)
+# gdkresources_xml = configure_file(
+ # input : 'gdk.gresource.xml.meson',
+ # output : 'gdk.gresource.xml',
+ # configuration : cdata
+# )
gdkresources = gnome.compile_resources(
'gdkresources',
@@ -216,47 +243,59 @@ gdkresources = gnome.compile_resources(
)
-deprecated_h_sources = ['deprecated/gdkcolor.h']
-
-gdk_headers = gdk_public_h_sources + deprecated_h_sources
+deprecated_h_sources = files(['deprecated/gdkcolor.h'])
-mkenum = find_program('build_enum.py')
-perl = find_program('perl')
-glib_mkenums = find_program('glib-mkenums')
+gdk_headers = gdk_public_h_sources + deprecated_h_sources + gdk_private_h_sources
-
-gdkenum_h = custom_target('gdkenum_h',
+gdkenum_h = custom_target(
+ 'gdkenum_h',
output : 'gdkenumtypes.h',
input : gdk_headers,
- command : [mkenum, perl, glib_mkenums, '@OUTPUT@', '@INPUT@'])
+ command : [mkenum, perl, glib_mkenums, meson.current_source_dir() + '/gdkenumtypes.h.template',
'@OUTPUT@', '@INPUT@'])
-gdkenum_c = custom_target('gdkenum_c',
+gdkenum_c = custom_target(
+ 'gdkenum_c',
output : 'gdkenumtypes.c',
input : gdk_headers,
- depends : [gdkenum_h],
- command : [mkenum, perl, glib_mkenums, '@OUTPUT@', '@INPUT@'])
+ depends : gdkenum_h,
+ command : [mkenum, perl, glib_mkenums, meson.current_source_dir() + '/gdkenumtypes.c.template',
'@OUTPUT@', '@INPUT@'])
-gdkmarshal_h = custom_target('gdkmarshal_h',
- output : 'gdkmarshall.h',
+gdkmarshal_h = custom_target(
+ 'gdkmarshal_h',
+ output : 'gdkmarshalers.h',
input : 'gdkmarshalers.list',
- command : [mkmarshal, glib_marshal, '_gdk_marshal', '@INPUT@', '@OUTPUT@'])
+ command : [mkmarshal, glib_marshal, '_gdk_marshal', '@INPUT@', '@OUTPUT@']
+)
-gdkmarshal_c = custom_target('gdkmarshal_c',
- output : 'gdkmarshall.c',
+gdkmarshal_c = custom_target(
+ 'gdkmarshal_c',
+ output : 'gdkmarshalers.c',
input : 'gdkmarshalers.list',
- command : [mkmarshal, glib_marshal, '_gdk_marshal', '@INPUT@', '@OUTPUT@'])
-
+ command : [mkmarshal, glib_marshal, '_gdk_marshal', '@INPUT@', '@OUTPUT@']
+)
cdata = configuration_data()
-if x11_enabled cdata.set('GDK_WINDOWING_X11', 1) endif
-if wayland_enabled cdata.set('GDK_WINDOWING_WAYLAND', 1) endif
-if broadway_enabled cdata.set('GDK_WINDOWING_BROADWAY', 1) endif
+cdata.set('GTK_MAJOR_VERSION', gtk_major_version)
+cdata.set('GTK_MINOR_VERSION', gtk_minor_version)
+cdata.set('GTK_MICRO_VERSION', gtk_micro_version)
+
+
+
+if x11_enabled cdata.set('GDK_WINDOWING_X11', '') endif
+if wayland_enabled cdata.set('GDK_WINDOWING_WAYLAND', '') endif
+if broadway_enabled cdata.set('GDK_WINDOWING_BROADWAY', '') endif
gdkconfig = configure_file(
input : 'gdkconfig.h.meson',
output : 'gdkconfig.h',
configuration : cdata
)
+gdkversionmacros = configure_file(
+ input : 'gdkversionmacros.h.in',
+ output : 'gdkversionmacros.h',
+ configuration: cdata
+)
+
xinc = include_directories('x11')
wlinc = include_directories('wayland')
@@ -280,7 +319,9 @@ gdk_sources = [
deprecated_gdk_sources,
gdkenum_c, gdkenum_h,
gdkmarshal_c, gdkmarshal_h,
- gdkresources
+ gdkresources,
+ gdkversionmacros,
+ gdk_headers
]
if x11_enabled
@@ -289,6 +330,10 @@ if x11_enabled
xi_dep,
xext_dep,
x11_dep,
+ xcursor_dep,
+ xdamage_dep,
+ xfixes_dep,
+ xcomposite_dep
]
gdk_sources += [
gdk_x_sources,
@@ -311,19 +356,29 @@ if wayland_enabled
]
endif
+if broadway_enabled
+ gdk_deps += [
+ shmlib,
+ ]
+ gdk_sources += [
+ gdk_broadway_sources,
+ gdk_broadway_private_sources
+ ]
+endif
+
libgdk = shared_library('gdk',
gdk_sources,
c_args: ['-DHAVE_CONFIG_H', '-DGDK_COMPILATION'],
- include_directories: [confinc, xinc, wlinc],
+ include_directories: [confinc, xinc],
dependencies: gdk_deps,
)
libgdk_dep = declare_dependency(
- sources: ['gdk.h', gdkenum_h],
+ sources: ['gdk.h', gdkconfig, gdkenum_h],
depends: gdk_sources,
- include_directories: [confinc, xinc, wlinc],
+ include_directories: [confinc, xinc],
dependencies: gdk_deps,
link_with: libgdk
)
diff --git a/gtk/gentypefuncs.d b/gtk/gentypefuncs.d
new file mode 100755
index 0000000..f7a0528
--- /dev/null
+++ b/gtk/gentypefuncs.d
@@ -0,0 +1,45 @@
+#!/usr/bin/rdmd
+
+import std.stdio;
+import std.file;
+import std.process;
+import std.regex;
+import std.array;
+import std.algorithm;
+
+void main(string[] args) {
+ string out_file = args[1];
+ string[] in_files = args[3..$];
+
+ auto regex = ctRegex!("g[td]k_[a-zA-Z0-9_]*_get_type");
+
+ string[] funcs;
+
+ foreach (filename; in_files) {
+ auto file = File(filename);
+ foreach (line; file.byLine()) {
+ auto match = line.matchFirst(regex);
+ if (!match.empty) {
+ // *cough*, not exactly the fastest way to do this...
+ if (!funcs.canFind(match.hit))
+ funcs ~= cast(string)match.hit.idup;
+ }
+ }
+ }
+
+ funcs.sort();
+
+ //writeln(funcs);
+ //writeln(funcs.length);
+
+ string file_output = "G_GNUC_BEGIN_IGNORE_DEPRECATIONS\n";
+ foreach (func; funcs) {
+ if (func.startsWith("gdk_x11") || func.startsWith("gtk_socket") ||
func.startsWith("gtk_plug")) {
+ file_output ~= "#ifdef GDK_WINDOWING_X11\n*tp++ = " ~ func ~ "();\n#endif\n";
+ } else if (func != ("gtk_text_handle_get_type")){
+ file_output ~= "*tp++ = " ~ func ~ "();\n";
+ }
+ }
+
+ std.file.write(out_file, file_output);
+}
diff --git a/gtk/gtk.gresource.xml b/gtk/gtk.gresource.xml
new file mode 100644
index 0000000..1f9992a
--- /dev/null
+++ b/gtk/gtk.gresource.xml
@@ -0,0 +1,269 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<gresources>
+ <gresource prefix='/org/gtk/libgtk'>
+ <file alias='theme/Raleigh/gtk.css'>theme/Raleigh/gtk-default.css</file>
+ <file>theme/Adwaita/gtk.css</file>
+ <file>theme/Adwaita/gtk-dark.css</file>
+ <file>theme/Adwaita/gtk-contained.css</file>
+ <file>theme/Adwaita/gtk-contained-dark.css</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/bullet-symbolic.symbolic.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-active-selectionmode 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-active-selectionmode.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-backdrop-selectionmode 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-backdrop-selectionmode.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-checked-active-selectionmode 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-checked-active-selectionmode.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-checked-backdrop-selectionmode 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-checked-backdrop-selectionmode.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-checked-hover-selectionmode 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-checked-hover-selectionmode.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-checked-selectionmode 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-checked-selectionmode.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-hover-selectionmode 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-hover-selectionmode.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-selectionmode 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/checkbox-selectionmode.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/check-symbolic.symbolic.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/dash-symbolic.symbolic.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-active 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-active-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-active-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-active.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-backdrop 2
png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-backdrop-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-backdrop-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-backdrop-insensitive 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-backdrop-insensitive-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-backdrop-insensitive-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-backdrop-insensitive.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-backdrop.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-dark 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-hover 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-hover-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-hover-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-hover.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-insensitive 2
png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-insensitive-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-insensitive-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above-insensitive.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-above.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-active 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-active-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-active-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-active.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-backdrop 2
png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-backdrop-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-backdrop-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-backdrop-insensitive 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-backdrop-insensitive-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-backdrop-insensitive-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-backdrop-insensitive.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-backdrop.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-dark 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-hover 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-hover-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-hover-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-hover.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-insensitive 2
png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-insensitive-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-insensitive-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below-insensitive.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-horz-scale-has-marks-below.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-active 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-active-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-active-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-active.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-backdrop 2
png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-backdrop-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-backdrop-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-backdrop-insensitive 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-backdrop-insensitive-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-backdrop-insensitive-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-backdrop-insensitive.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-backdrop.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-dark 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-hover 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-hover-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-hover-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-hover.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-insensitive 2
png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-insensitive-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-insensitive-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above-insensitive.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-above.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-active 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-active-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-active-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-active.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-backdrop 2
png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-backdrop-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-backdrop-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-backdrop-insensitive 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-backdrop-insensitive-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-backdrop-insensitive-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-backdrop-insensitive.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-backdrop.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-dark 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-hover 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-hover-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-hover-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-hover.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-insensitive 2
png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-insensitive-dark 2
png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-insensitive-dark.png</file>
+ <file
preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below-insensitive.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/slider-vert-scale-has-marks-below.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end-active 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end-active-dark 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end-active-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end-active.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end-dark 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end-hover 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end-hover-dark 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end-hover-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end-hover.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-end.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start-active 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start-active-dark 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start-active-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start-active.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start-dark 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start-hover 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start-hover-dark 2 png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start-hover-dark.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start-hover.png</file>
+ <file preprocess='to-pixdata'>theme/Adwaita/assets/text-select-start.png</file>
+ <file>theme/Adwaita/assets/bullet-symbolic.svg</file>
+ <file>theme/Adwaita/assets/check-symbolic.svg</file>
+ <file>theme/Adwaita/assets/dash-symbolic.svg</file>
+ <file>theme/HighContrast/gtk.css</file>
+ <file alias='theme/HighContrastInverse/gtk.css'>theme/HighContrast/gtk-inverse.css</file>
+ <file>theme/HighContrast/gtk-contained.css</file>
+ <file>theme/HighContrast/gtk-contained-inverse.css</file>
+ <file preprocess='to-pixdata'>theme/HighContrast/assets/bullet-symbolic.symbolic.png</file>
+ <file preprocess='to-pixdata'>theme/HighContrast/assets/check-symbolic.symbolic.png</file>
+ <file preprocess='to-pixdata'>theme/HighContrast/assets/dash-symbolic.symbolic.png</file>
+ <file>theme/HighContrast/assets/bullet-symbolic.svg</file>
+ <file>theme/HighContrast/assets/check-symbolic.svg</file>
+ <file>theme/HighContrast/assets/dash-symbolic.svg</file>
+ <file>theme/win32/gtk-win32-base.css</file>
+ <file>theme/win32/gtk.css</file>
+ <file>cursor/dnd-ask.png</file>
+ <file>cursor/dnd-copy.png</file>
+ <file>cursor/dnd-link.png</file>
+ <file>cursor/dnd-move.png</file>
+ <file>cursor/dnd-none.png</file>
+ <file
alias='icons/64x64/actions/gesture-pinch-symbolic.symbolic.png'>gesture/gesture-pinch-symbolic.symbolic.png</file>
+ <file
alias='icons/64x64/actions/gesture-rotate-anticlockwise-symbolic.symbolic.png'>gesture/gesture-rotate-anticlockwise-symbolic.symbolic.png</file>
+ <file
alias='icons/64x64/actions/gesture-rotate-clockwise-symbolic.symbolic.png'>gesture/gesture-rotate-clockwise-symbolic.symbolic.png</file>
+ <file
alias='icons/64x64/actions/gesture-stretch-symbolic.symbolic.png'>gesture/gesture-stretch-symbolic.symbolic.png</file>
+ <file
alias='icons/64x64/actions/gesture-two-finger-swipe-left-symbolic.symbolic.png'>gesture/gesture-two-finger-swipe-left-symbolic.symbolic.png</file>
+ <file
alias='icons/64x64/actions/gesture-two-finger-swipe-right-symbolic.symbolic.png'>gesture/gesture-two-finger-swipe-right-symbolic.symbolic.png</file>
+ <file compressed='true'>ui/gtkaboutdialog.ui</file>
+ <file compressed='true'>ui/gtkactionbar.ui</file>
+ <file compressed='true'>ui/gtkappchooserdialog.ui</file>
+ <file compressed='true'>ui/gtkappchooserwidget.ui</file>
+ <file compressed='true'>ui/gtkapplication-quartz.ui</file>
+ <file compressed='true'>ui/gtkassistant.ui</file>
+ <file compressed='true'>ui/gtkcolorchooserdialog.ui</file>
+ <file compressed='true'>ui/gtkcoloreditor.ui</file>
+ <file compressed='true'>ui/gtkcombobox.ui</file>
+ <file compressed='true'>ui/gtkdialog.ui</file>
+ <file compressed='true'>ui/gtkfilechooserbutton.ui</file>
+ <file compressed='true'>ui/gtkfilechooserdialog.ui</file>
+ <file compressed='true'>ui/gtkfilechooserwidget.ui</file>
+ <file compressed='true'>ui/gtkfontbutton.ui</file>
+ <file compressed='true'>ui/gtkfontchooserdialog.ui</file>
+ <file compressed='true'>ui/gtkfontchooserwidget.ui</file>
+ <file compressed='true'>ui/gtkinfobar.ui</file>
+ <file compressed='true'>ui/gtklockbutton.ui</file>
+ <file compressed='true'>ui/gtkmessagedialog.ui</file>
+ <file compressed='true'>ui/gtkpagesetupunixdialog.ui</file>
+ <file compressed='true'>ui/gtkpathbar.ui</file>
+ <file compressed='true'>ui/gtkplacesviewrow.ui</file>
+ <file compressed='true'>ui/gtkplacesview.ui</file>
+ <file compressed='true'>ui/gtkprintunixdialog.ui</file>
+ <file compressed='true'>ui/gtkrecentchooserdefault.ui</file>
+ <file compressed='true'>ui/gtkscalebutton.ui</file>
+ <file compressed='true'>ui/gtksearchbar.ui</file>
+ <file compressed='true'>ui/gtksidebarrow.ui</file>
+ <file compressed='true'>ui/gtkstatusbar.ui</file>
+ <file compressed='true'>ui/gtktooltipwindow.ui</file>
+ <file compressed='true'>ui/gtkvolumebutton.ui</file>
+ <file>icons/16x16/actions/gtk-caps-lock-warning.png</file>
+ <file>icons/16x16/actions/gtk-color-picker.png</file>
+ <file>icons/16x16/actions/gtk-connect.png</file>
+ <file>icons/16x16/actions/gtk-convert.png</file>
+ <file>icons/16x16/actions/gtk-disconnect.png</file>
+ <file>icons/16x16/actions/gtk-edit.png</file>
+ <file>icons/16x16/actions/gtk-index.png</file>
+ <file>icons/16x16/actions/gtk-orientation-landscape.png</file>
+ <file>icons/16x16/actions/gtk-orientation-portrait.png</file>
+ <file>icons/16x16/actions/gtk-orientation-reverse-landscape.png</file>
+ <file>icons/16x16/actions/gtk-orientation-reverse-portrait.png</file>
+ <file>icons/16x16/actions/gtk-page-setup.png</file>
+ <file>icons/16x16/actions/gtk-preferences.png</file>
+ <file>icons/16x16/actions/gtk-select-color.png</file>
+ <file>icons/16x16/actions/gtk-select-font.png</file>
+ <file>icons/16x16/actions/gtk-undelete.png</file>
+ <file>icons/16x16/actions/gtk-undelete-rtl.png</file>
+ <file>icons/16x16/status/image-missing.png</file>
+ <file>icons/22x22/actions/gtk-apply.png</file>
+ <file>icons/22x22/actions/gtk-cancel.png</file>
+ <file>icons/22x22/actions/gtk-no.png</file>
+ <file>icons/22x22/actions/gtk-ok.png</file>
+ <file>icons/22x22/actions/gtk-yes.png</file>
+ <file>icons/24x24/actions/gtk-caps-lock-warning.png</file>
+ <file>icons/24x24/actions/gtk-color-picker.png</file>
+ <file>icons/24x24/actions/gtk-connect.png</file>
+ <file>icons/24x24/actions/gtk-convert.png</file>
+ <file>icons/24x24/actions/gtk-disconnect.png</file>
+ <file>icons/24x24/actions/gtk-edit.png</file>
+ <file>icons/24x24/actions/gtk-index.png</file>
+ <file>icons/24x24/actions/gtk-orientation-landscape.png</file>
+ <file>icons/24x24/actions/gtk-orientation-portrait.png</file>
+ <file>icons/24x24/actions/gtk-orientation-reverse-landscape.png</file>
+ <file>icons/24x24/actions/gtk-orientation-reverse-portrait.png</file>
+ <file>icons/24x24/actions/gtk-page-setup.png</file>
+ <file>icons/24x24/actions/gtk-preferences.png</file>
+ <file>icons/24x24/actions/gtk-select-color.png</file>
+ <file>icons/24x24/actions/gtk-select-font.png</file>
+ <file>icons/24x24/actions/gtk-undelete.png</file>
+ <file>icons/24x24/actions/gtk-undelete-rtl.png</file>
+ <file>icons/24x24/status/image-missing.png</file>
+ <file>icons/32x32/actions/gtk-dnd-multiple.png</file>
+ <file>icons/32x32/actions/gtk-dnd.png</file>
+ <file>icons/32x32/status/image-missing.png</file>
+ <file>icons/48x48/status/image-missing.png</file>
+ <file compressed='true'>inspector/actions.ui</file>
+ <file compressed='true'>inspector/css-editor.ui</file>
+ <file compressed='true'>inspector/css-node-tree.ui</file>
+ <file compressed='true'>inspector/data-list.ui</file>
+ <file compressed='true'>inspector/general.ui</file>
+ <file compressed='true'>inspector/magnifier.ui</file>
+ <file compressed='true'>inspector/menu.ui</file>
+ <file compressed='true'>inspector/misc-info.ui</file>
+ <file compressed='true'>inspector/object-hierarchy.ui</file>
+ <file compressed='true'>inspector/object-tree.ui</file>
+ <file compressed='true'>inspector/prop-list.ui</file>
+ <file compressed='true'>inspector/resource-list.ui</file>
+ <file compressed='true'>inspector/selector.ui</file>
+ <file compressed='true'>inspector/signals-list.ui</file>
+ <file compressed='true'>inspector/statistics.ui</file>
+ <file compressed='true'>inspector/visual.ui</file>
+ <file compressed='true'>inspector/window.ui</file>
+ <file>inspector/logo.png</file>
+ </gresource>
+</gresources>
diff --git a/gtk/gtkwindow.c b/gtk/gtkwindow.c
index 56da76f..e803e10 100644
--- a/gtk/gtkwindow.c
+++ b/gtk/gtkwindow.c
@@ -9020,8 +9020,9 @@ gtk_window_move_resize (GtkWindow *window)
/* handle resizing/moving and widget tree allocation
*/
if (priv->configure_notify_received)
- {
+ {
GtkAllocation allocation;
+ int min, nat;
/* If we have received a configure event since
* the last time in this function, we need to
@@ -9038,8 +9039,12 @@ gtk_window_move_resize (GtkWindow *window)
allocation.x = 0;
allocation.y = 0;
- allocation.width = current_width;
- allocation.height = current_height;
+ /*allocation.width = current_width;*/
+
+ gtk_widget_get_preferred_width (widget, &min, &nat);
+ allocation.width = MAX (min, current_width);
+ gtk_widget_get_preferred_height_for_width (widget, allocation.width, &min, &nat);
+ allocation.height = MAX (min, current_height);
gtk_widget_size_allocate (widget, &allocation);
diff --git a/gtk/meson.build b/gtk/meson.build
index a6a56b9..366d0dc 100644
--- a/gtk/meson.build
+++ b/gtk/meson.build
@@ -254,6 +254,7 @@ gtk_sources = [
'gtkoffscreenwindow.c',
'gtkorientable.c',
'gtkoverlay.c',
+ 'gtkpadcontroller.c',
'gtkpagesetup.c',
'gtkpaned.c',
'gtkpango.c',
@@ -268,7 +269,6 @@ gtk_sources = [
'gtkprintsettings.c',
'gtkprintutils.c',
'gtkprivate.c',
- 'gtkprivatetypebuiltins.c',
'gtkprogressbar.c',
'gtkpixelcache.c',
'gtkpopover.c',
@@ -359,7 +359,6 @@ gtk_sources = [
'gtktreestore.c',
'gtktreeview.c',
'gtktreeviewcolumn.c',
- 'gtktypebuiltins.c',
'gtkvolumebutton.c',
'gtkviewport.c',
'gtkwidget.c',
@@ -371,6 +370,284 @@ gtk_sources = [
'fallback-c89.c'
]
+gtk_private_type_headers = [
+ 'gtkcsstypesprivate.h',
+ 'gtktexthandleprivate.h',
+]
+
+gtk_private_h_sources = files([
+ gtk_private_type_headers,
+ 'gtkrecentchooserutils.h',
+ 'gtkrbtree.h',
+])
+
+gtk_public_h_sources = files([
+ 'gtk.h',
+ 'gtk-autocleanups.h',
+ 'gtkx.h',
+ 'gtkx-autocleanups.h',
+ 'gtk-a11y.h',
+ 'gtkaboutdialog.h',
+ 'gtkaccelgroup.h',
+ 'gtkaccellabel.h',
+ 'gtkaccelmap.h',
+ 'gtkaccessible.h',
+ 'gtkactionable.h',
+ 'gtkactionbar.h',
+ 'gtkadjustment.h',
+ 'gtkappchooser.h',
+ 'gtkappchooserbutton.h',
+ 'gtkappchooserdialog.h',
+ 'gtkappchooserwidget.h',
+ 'gtkapplication.h',
+ 'gtkapplicationwindow.h',
+ 'gtkaspectframe.h',
+ 'gtkassistant.h',
+ 'gtkbbox.h',
+ 'gtkbin.h',
+ 'gtkbindings.h',
+ 'gtkborder.h',
+ 'gtkbox.h',
+ 'gtkbuilder.h',
+ 'gtkbuildable.h',
+ 'gtkbutton.h',
+ 'gtkcalendar.h',
+ 'gtkcellarea.h',
+ 'gtkcellareacontext.h',
+ 'gtkcellareabox.h',
+ 'gtkcelleditable.h',
+ 'gtkcelllayout.h',
+ 'gtkcellrenderer.h',
+ 'gtkcellrendereraccel.h',
+ 'gtkcellrenderercombo.h',
+ 'gtkcellrendererpixbuf.h',
+ 'gtkcellrendererprogress.h',
+ 'gtkcellrendererspin.h',
+ 'gtkcellrendererspinner.h',
+ 'gtkcellrenderertext.h',
+ 'gtkcellrenderertoggle.h',
+ 'gtkcellview.h',
+ 'gtkcheckbutton.h',
+ 'gtkcheckmenuitem.h',
+ 'gtkclipboard.h',
+ 'gtkcolorbutton.h',
+ 'gtkcolorchooser.h',
+ 'gtkcolorchooserwidget.h',
+ 'gtkcolorchooserdialog.h',
+ 'gtkcolorutils.h',
+ 'gtkcombobox.h',
+ 'gtkcomboboxtext.h',
+ 'gtkcontainer.h',
+ 'gtkcssprovider.h',
+ 'gtkcsssection.h',
+ 'gtkdebug.h',
+ 'gtkdialog.h',
+ 'gtkdnd.h',
+ 'gtkdragdest.h',
+ 'gtkdragsource.h',
+ 'gtkdrawingarea.h',
+ 'gtkeditable.h',
+ 'gtkentry.h',
+ 'gtkentrybuffer.h',
+ 'gtkentrycompletion.h',
+ 'gtkenums.h',
+ 'gtkeventbox.h',
+ 'gtkeventcontroller.h',
+ 'gtkexpander.h',
+ 'gtkfilechooser.h',
+ 'gtkfilechooserbutton.h',
+ 'gtkfilechooserdialog.h',
+ 'gtkfilechoosernative.h',
+ 'gtkfilechooserwidget.h',
+ 'gtkfilefilter.h',
+ 'gtkfixed.h',
+ 'gtkflowbox.h',
+ 'gtkfontbutton.h',
+ 'gtkfontchooser.h',
+ 'gtkfontchooserdialog.h',
+ 'gtkfontchooserwidget.h',
+ 'gtkframe.h',
+ 'gtkgesture.h',
+ 'gtkgesturedrag.h',
+ 'gtkgesturelongpress.h',
+ 'gtkgesturemultipress.h',
+ 'gtkgesturepan.h',
+ 'gtkgesturerotate.h',
+ 'gtkgesturesingle.h',
+ 'gtkgestureswipe.h',
+ 'gtkgesturezoom.h',
+ 'gtkglarea.h',
+ 'gtkgrid.h',
+ 'gtkheaderbar.h',
+ 'gtkicontheme.h',
+ 'gtkiconview.h',
+ 'gtkimage.h',
+ 'gtkimcontext.h',
+ 'gtkimcontextinfo.h',
+ 'gtkimcontextsimple.h',
+ 'gtkimmodule.h',
+ 'gtkimmulticontext.h',
+ 'gtkinfobar.h',
+ 'gtkinvisible.h',
+ 'gtklabel.h',
+ 'gtklayout.h',
+ 'gtklevelbar.h',
+ 'gtklinkbutton.h',
+ 'gtklistbox.h',
+ 'gtkliststore.h',
+ 'gtklockbutton.h',
+ 'gtkmain.h',
+ 'gtkmenu.h',
+ 'gtkmenubar.h',
+ 'gtkmenubutton.h',
+ 'gtkmenuitem.h',
+ 'gtkmenushell.h',
+ 'gtkmenutoolbutton.h',
+ 'gtkmessagedialog.h',
+ 'gtkmodelbutton.h',
+ 'gtkmodules.h',
+ 'gtkmountoperation.h',
+ 'gtknativedialog.h',
+ 'gtknotebook.h',
+ 'gtkoffscreenwindow.h',
+ 'gtkorientable.h',
+ 'gtkoverlay.h',
+ 'gtkpadcontroller.h',
+ 'gtkpagesetup.h',
+ 'gtkpaned.h',
+ 'gtkpapersize.h',
+ 'gtkplacessidebar.h',
+ 'gtkplug.h',
+ 'gtkpopover.h',
+ 'gtkpopovermenu.h',
+ 'gtkprintcontext.h',
+ 'gtkprintoperation.h',
+ 'gtkprintoperationpreview.h',
+ 'gtkprintsettings.h',
+ 'gtkprogressbar.h',
+ 'gtkradiobutton.h',
+ 'gtkradiomenuitem.h',
+ 'gtkradiotoolbutton.h',
+ 'gtkrange.h',
+ 'gtkrecentchooser.h',
+ 'gtkrecentchooserdialog.h',
+ 'gtkrecentchoosermenu.h',
+ 'gtkrecentchooserwidget.h',
+ 'gtkrecentfilter.h',
+ 'gtkrecentmanager.h',
+ 'gtkrender.h',
+ 'gtkrevealer.h',
+ 'gtkscale.h',
+ 'gtkscalebutton.h',
+ 'gtkscrollable.h',
+ 'gtkscrollbar.h',
+ 'gtkscrolledwindow.h',
+ 'gtksearchbar.h',
+ 'gtksearchentry.h',
+ 'gtkselection.h',
+ 'gtkseparator.h',
+ 'gtkseparatormenuitem.h',
+ 'gtkseparatortoolitem.h',
+ 'gtksettings.h',
+ 'gtkshortcutlabel.h',
+ 'gtkshortcutsgroup.h',
+ 'gtkshortcutssection.h',
+ 'gtkshortcutsshortcut.h',
+ 'gtkshortcutswindow.h',
+ 'gtkshow.h',
+ 'gtkstacksidebar.h',
+ 'gtksizegroup.h',
+ 'gtksizerequest.h',
+ 'gtksocket.h',
+ 'gtkspinbutton.h',
+ 'gtkspinner.h',
+ 'gtkstack.h',
+ 'gtkstackswitcher.h',
+ 'gtkstatusbar.h',
+ 'gtkstylecontext.h',
+ 'gtkstyleprovider.h',
+ 'gtkswitch.h',
+ 'gtktestutils.h',
+ 'gtktextattributes.h',
+ 'gtktextbuffer.h',
+ 'gtktextbufferrichtext.h',
+ 'gtktextchild.h',
+ 'gtktextdisplay.h',
+ 'gtktextiter.h',
+ 'gtktextmark.h',
+ 'gtktexttag.h',
+ 'gtktexttagtable.h',
+ 'gtktextview.h',
+ 'gtktogglebutton.h',
+ 'gtktoggletoolbutton.h',
+ 'gtktoolbar.h',
+ 'gtktoolbutton.h',
+ 'gtktoolitem.h',
+ 'gtktoolitemgroup.h',
+ 'gtktoolpalette.h',
+ 'gtktoolshell.h',
+ 'gtktooltip.h',
+ 'gtktreednd.h',
+ 'gtktreemodel.h',
+ 'gtktreemodelfilter.h',
+ 'gtktreemodelsort.h',
+ 'gtktreeselection.h',
+ 'gtktreesortable.h',
+ 'gtktreestore.h',
+ 'gtktreeview.h',
+ 'gtktreeviewcolumn.h',
+ 'gtktypes.h',
+ 'gtkviewport.h',
+ 'gtkvolumebutton.h',
+ 'gtkwidget.h',
+ 'gtkwidgetpath.h',
+ 'gtkwindow.h',
+ 'gtkwindowgroup.h',
+])
+
+gtk_deprecated_type_headers = ([
+ 'deprecated/gtkactivatable.h',
+ 'deprecated/gtkaction.h',
+ 'deprecated/gtkactiongroup.h',
+ 'deprecated/gtkalignment.h',
+ 'deprecated/gtkarrow.h',
+ 'deprecated/gtkcolorsel.h',
+ 'deprecated/gtkcolorseldialog.h',
+ 'deprecated/gtkfontsel.h',
+ 'deprecated/gtkgradient.h',
+ 'deprecated/gtkhandlebox.h',
+ 'deprecated/gtkhbbox.h',
+ 'deprecated/gtkhbox.h',
+ 'deprecated/gtkhpaned.h',
+ 'deprecated/gtkhscale.h',
+ 'deprecated/gtkhscrollbar.h',
+ 'deprecated/gtkhseparator.h',
+ 'deprecated/gtkhsv.h',
+ 'deprecated/gtkiconfactory.h',
+ 'deprecated/gtkimagemenuitem.h',
+ 'deprecated/gtkmisc.h',
+ 'deprecated/gtknumerableicon.h',
+ 'deprecated/gtkradioaction.h',
+ 'deprecated/gtkrc.h',
+ 'deprecated/gtkrecentaction.h',
+ 'deprecated/gtkstatusicon.h',
+ 'deprecated/gtkstock.h',
+ 'deprecated/gtkstyle.h',
+ 'deprecated/gtkstyleproperties.h',
+ 'deprecated/gtksymboliccolor.h',
+ 'deprecated/gtktable.h',
+ 'deprecated/gtktearoffmenuitem.h',
+ 'deprecated/gtkthemingengine.h',
+ 'deprecated/gtktoggleaction.h',
+ 'deprecated/gtkuimanager.h',
+ 'deprecated/gtkvbbox.h',
+ 'deprecated/gtkvbox.h',
+ 'deprecated/gtkvscale.h',
+ 'deprecated/gtkvscrollbar.h',
+ 'deprecated/gtkvseparator.h',
+ 'deprecated/gtkvpaned.h',
+])
+
gtk_unix_sources = [
'gtkcustompaperunixdialog.c',
'gtkpagesetupunixdialog.c',
@@ -393,7 +670,6 @@ gtkresources = gnome.compile_resources(
extra_args: '--manual-register'
)
-
gtk_x11_sources = [
'gtkplug.c',
'gtksocket.c',
@@ -418,18 +694,78 @@ gtk_dbus_src = gnome.gdbus_codegen('gtkdbusgenerated', 'gtkdbusinterfaces.xml',
interface_prefix: 'org.Gtk.',
namespace: '_Gtk')
-gtkmarshal_h = custom_target('gtkmarshal_h',
+gtkmarshal_h = custom_target(
+ 'gtkmarshal_h',
output : 'gtkmarshalers.h',
input : 'gtkmarshalers.list',
command : [mkmarshal, glib_marshal, '_gtk_marshal', '@INPUT@', '@OUTPUT@']
)
-gtkmarshal_c = custom_target('gtkmarshal_c',
+gtkmarshal_c = custom_target(
+ 'gtkmarshal_c',
output : 'gtkmarshalers.c',
input : 'gtkmarshalers.list',
command : [mkmarshal, glib_marshal, '_gtk_marshal', '@INPUT@', '@OUTPUT@']
)
+
+
+gtktypebuiltins_h = custom_target(
+ 'gtkypebuiltins_h',
+ output : 'gtktypebuiltins.h',
+ input : gtk_public_h_sources + gtk_deprecated_type_headers,
+ command : [mkenum, perl, glib_mkenums, meson.current_source_dir() + '/gtktypebuiltins.h.template',
'@OUTPUT@', '@INPUT@']
+)
+
+gtktypebuiltins_c = custom_target(
+ 'gtkypebuiltins_c',
+ output : 'gtktypebuiltins.c',
+ input : gtk_public_h_sources + gtk_deprecated_type_headers,
+ depends : gtktypebuiltins_h,
+ command : [mkenum, perl, glib_mkenums, meson.current_source_dir() + '/gtktypebuiltins.c.template',
'@OUTPUT@', '@INPUT@']
+)
+
+gtkprivatetypebuiltins_h = custom_target(
+ 'gtkprivateypebuiltins_h',
+ output : 'gtkprivatetypebuiltins.h',
+ input : gtk_private_type_headers,
+ command : [mkenum, perl, glib_mkenums, meson.current_source_dir() + '/gtkprivatetypebuiltins.h.template',
'@OUTPUT@', '@INPUT@']
+)
+
+gtkprivatetypebuiltins_c = custom_target(
+ 'gtkprivateypebuiltins_c',
+ output : 'gtkprivatetypebuiltins.c',
+ input : gtk_private_type_headers,
+ depends : [gtkprivatetypebuiltins_h, gtktypebuiltins_h],
+ command : [mkenum, perl, glib_mkenums, meson.current_source_dir() + '/gtkprivatetypebuiltins.c.template',
'@OUTPUT@', '@INPUT@']
+)
+
+d_compiler = find_program('dmd')
+gentypefuncs_prog = find_program('gentypefuncs.d')
+# Generate gtktypefuncs.c
+typefuncs = custom_target(
+ 'typefuncs',
+ depends: gdkenum_h,
+ output : 'gtktypefuncs.c',
+ input : gdk_headers + gtk_public_h_sources + gtk_deprecated_type_headers + gtk_private_h_sources +
[gtktypebuiltins_h] + [gdkenum_h],
+ command: [gentypefuncs_prog, '@OUTPUT@', '@INPUT@'],
+ install: true,
+ install_dir: '.'
+)
+
+cdata = configuration_data()
+cdata.set('GTK_MAJOR_VERSION', gtk_major_version)
+cdata.set('GTK_MINOR_VERSION', gtk_minor_version)
+cdata.set('GTK_MICRO_VERSION', gtk_micro_version)
+cdata.set('GTK_BINARY_AGE', gtk_binary_age)
+cdata.set('GTK_INTERFACE_AGE', gtk_interface_age)
+
+gtkversion = configure_file(
+ input : 'gtkversion.h.in',
+ output : 'gtkversion.h',
+ configuration: cdata
+)
+
gtk_sources = [
gtk_sources,
gtk_dbus_src,
@@ -441,6 +777,10 @@ gtk_sources = [
gtkresources,
gtkmarshal_c,
gtkmarshal_h,
+ gtkprivatetypebuiltins_c,
+ gtkprivatetypebuiltins_h,
+ gtktypebuiltins_c,
+ gtktypebuiltins_h,
]
gtk_deps = [
@@ -461,7 +801,7 @@ gtk_deps = [
libgdk_dep
]
-if x11_enabled
+# if x11_enabled
gtk_sources += [
gtk_x11_sources,
gtk_use_wayland_or_x11_c_sources
@@ -470,7 +810,7 @@ if x11_enabled
xi_dep,
x11_dep,
]
-endif
+# endif
if wayland_enabled
gtk_sources += [
@@ -487,18 +827,21 @@ libgtk = shared_library('gtk',
'-DGTK_SYSCONFDIR="sysconfdir"',
'-DGTK_DATA_PREFIX="dataprefix"',
'-DGTK_PRINT_BACKENDS="null"', '-DGTK_VERSION="3"',
- '-DX11_DATA_PREFIX="/share/x11/locale"'
+ '-DX11_DATA_PREFIX="/usr"'
],
- include_directories: [ confinc, gdkinc ],
+ include_directories: [ confinc, gdkinc, gtkinc ],
dependencies: [gtk_deps, libgdk_dep],
link_with: libgdk
)
libgtk_dep = declare_dependency(
sources: [
- 'gtk.h'
+ 'gtk.h',
+ gtkversion,
+ gtktypebuiltins_c,
+ gtktypebuiltins_h,
],
dependencies: gtk_deps,
- link_with: [libgdk, libgtk],
- include_directories: confinc
+ link_with: [libgtk, libgdk],
+ include_directories: [confinc, gtkinc]
)
diff --git a/meson.build b/meson.build
index d70de78..c39acc8 100644
--- a/meson.build
+++ b/meson.build
@@ -10,11 +10,14 @@ project('gtk+-3.0', 'c',
gnome = import('gnome')
add_global_arguments('-DG_LOG_USE_STRUCTURED=1', language: 'c')
+add_global_arguments('-DG_ENABLE_DEBUG', language: 'c')
+add_global_arguments('-DG_ENABLE_CONSISTENCY_CHECKS', language: 'c')
gtk_version = meson.project_version().split('.')
gtk_major_version = gtk_version[0]
gtk_minor_version = gtk_version[1]
gtk_micro_version = gtk_version[2]
+gtk_interface_age = 0
gtk_binary_age = 100 * gtk_minor_version.to_int() + gtk_micro_version.to_int()
gtk_api_version = '@0@.0'.format(gtk_major_version)
@@ -26,6 +29,10 @@ broadway_enabled = get_option('enable-broadway-backend')
mkmarshal = find_program('build_marshal.py')
glib_marshal = find_program('glib-genmarshal')
+mkenum = find_program('build_enum.py')
+perl = find_program('perl')
+glib_mkenums = find_program('glib-mkenums')
+
cc = meson.get_compiler('c')
cdata = configuration_data()
@@ -33,6 +40,11 @@ cdata.set('PACKAGE_VERSION', '"'+meson.project_version()+'"')
cdata.set('GTK_LOCALEDIR', '"'+get_option('localedir')+'"')
cdata.set('GTK_DATADIR', '"'+get_option('datadir')+'"')
cdata.set('GTK_LIBDIR', '"'+get_option('libdir')+'"')
+cdata.set('GTK_MAJOR_VERSION', 'aaa')
+cdata.set('GTK_MINOR_VERSION', gtk_minor_version)
+cdata.set('GTK_MICRO_VERSION', gtk_micro_version)
+cdata.set('GTK_BINARY_AGE', gtk_binary_age)
+cdata.set('GTK_INTERFACE_AGE', gtk_interface_age)
check_headers = [
['HAVE_CRT_EXTERNS_H', 'crt/externs.h'],
['HAVE_DLFCN_H', 'dlfcn.h'],
@@ -121,43 +133,56 @@ cdata.set('GETTEXT_PACKAGE', '"gtk-3.0"')
cdata.set('HAVE_XSYNC', 1)
cdata.set('XINPUT_2', 1)
cdata.set('XINPUT_2_2', 1)
+cdata.set('HAVE_XKB', 1)
+cdata.set('HAVE_XDAMAGE', 1)
+cdata.set('HAVE_XCURSOR', 1)
+cdata.set('HAVE_XGENERICEVENTS', 1)
confinc = include_directories('.')
gdkinc = include_directories('gdk')
-
-x11_dep = dependency('x11')
-xrender_dep = dependency('xrender')
-xi_dep = dependency('xi')
-xext_dep = dependency('xext')
-glib_dep = dependency('glib-2.0')
-giounix_dep = dependency('gio-unix-2.0', required : false)
-pango_dep = dependency('pango')
-pangoft_dep = dependency('pangoft2')
-cairo_dep = dependency('cairo')
+gtkinc = include_directories('gtk')
+
+x11_dep = dependency('x11')
+xrender_dep = dependency('xrender')
+xi_dep = dependency('xi')
+xext_dep = dependency('xext')
+xcursor_dep = dependency('xcursor')
+xdamage_dep = dependency('xdamage')
+xfixes_dep = dependency('xfixes')
+xcomposite_dep = dependency('xcomposite')
+glib_dep = dependency('glib-2.0', version: '>= 2.49.4')
+giounix_dep = dependency('gio-unix-2.0', required : false)
+pango_dep = dependency('pango', version: '>=1.37.3')
+pangoft_dep = dependency('pangoft2')
+cairo_dep = dependency('cairo')
pangocairo_dep = dependency('pangocairo')
-cairogobj_dep = dependency('cairo-gobject')
-pixbuf_dep = dependency('gdk-pixbuf-2.0')
-epoxy_dep = dependency('epoxy')
-atk_dep = dependency('atk')
-atkbridge_dep = dependency('atk-bridge-2.0')
-gmodule_dep = dependency('gmodule-2.0')
-mlib = cc.find_library('m')
-shmlib = cc.find_library('rt')
+cairogobj_dep = dependency('cairo-gobject')
+pixbuf_dep = dependency('gdk-pixbuf-2.0', version: '>= 2.30.0')
+epoxy_dep = dependency('epoxy')
+atk_dep = dependency('atk', version: '>= 2.15.1')
+atkbridge_dep = dependency('atk-bridge-2.0')
+gmodule_dep = dependency('gmodule-2.0')
+mlib = cc.find_library('m')
+shmlib = cc.find_library('rt')
fontconfig_dep = dependency('fontconfig')
-xkbdep = dependency('xkbcommon')
-wlclientdep = dependency('wayland-client')
-wlprotocolsdep = dependency('wayland-protocols')
-wlcursordep = dependency('wayland-cursor')
-wlegldep = dependency('wayland-egl')
+xkbdep = dependency('xkbcommon')
+wlclientdep = dependency('wayland-client')
+wlprotocolsdep = dependency('wayland-protocols', version: '>= 1.7')
+wlcursordep = dependency('wayland-cursor')
+wlegldep = dependency('wayland-egl')
if giounix_dep.found()
cdata.set('HAVE_GIO_UNIX', 1)
endif
-configure_file(input: 'config.h.meson', output: 'config.h', configuration: cdata)
+configure_file(
+ input : 'config.h.meson',
+ output: 'config.h',
+ configuration: cdata
+)
subdir('gdk')
subdir('gtk')
subdir('demos')
-subdir('tests')
-subdir('testsuite')
+# subdir('tests')
+# subdir('testsuite')
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]