mirror of
https://github.com/gryf/gryf-overlay.git
synced 2026-03-24 13:43:33 +01:00
Added fix for pasting PRIMARY selection on GTK2
This commit is contained in:
6
x11-libs/gtk+/Manifest
Normal file
6
x11-libs/gtk+/Manifest
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
AUX gtk+-2.24.24-out-of-source.patch 1487 SHA256 3492f3c22df40f7e0696098eb689b949ce0b6152293aba0a54adb8a859ec5250 SHA512 794903f8254a49f7d0e24f9730658dc69184969bb450419bd34bc2a9e7065d99931df4ae5ecd93abc0a18bff546aeb6816aae47531e8a79dc5aef5beaf9b6aa2 WHIRLPOOL abc0a7572bd27afc3d4b0d0dbae78e93ebfec8c8bbc6787c632de80401d4f0b9f6621ccb0fbae867a70cea8767f97542b7c42c9f532598676d89563677cd79d3
|
||||||
|
AUX gtk+-2.24.31-fix-gtkentry-beep.patch 1331 SHA256 d12ab8774f248cdec0eee97763735365c9804fce2bdcc022611f93f32e776afa SHA512 a5fe1474a044299dd2a6e3d238cb1afedc363db095c752cbc9d0435794a6a8f9f6260b7eb96eb3a64ae7fe46b9ca275168c6c39358dca28f7f42203f929c935c WHIRLPOOL 9f7300bcfcfb6855b43f53b6d84cb90247b1bb84c41dbcd50d31c8f43c687ac40824c010cd5d83f08cb2cec3ba22353aa148c2abbb721fa72da996ddd75a46c9
|
||||||
|
AUX gtk+-2.24.31-update-icon-cache.patch 2504 SHA256 aff2bc60ebed09103d3f5d69a095986afeb5fd2c311f82df6c8fd18478258d4f SHA512 c2a55a410019502b0af3fa5152fc372ce8a555bd63b5cf7f9574ebe5058f3b95e21dc5f14b5b8867d52105e4f6ebca3336a59935c3a7269bfd41aa91edadab48 WHIRLPOOL a77b23f47308e06524418eff422545062f67ba9a1cfe5038c1e4bb67c08b2eeabbf22049301c6beef909542a5adb4c3c6fd312402ae25c41eaadbeb25d755a24
|
||||||
|
AUX gtk+-2.24.31_enable_paste_selection.patch 7677 SHA256 5f2ecda06f95d217c2d895f62d4a8c3f1d59f4b380b0d34c135cea91cd5e402d SHA512 4de343c43ad2d217ff9817410abd563a62a76c3da358859ada6d2b5b61af7ce9442543530f715f35bca969906b6742e5ace8bceea5686488938cae53623f5e00 WHIRLPOOL 230d79e7b857d4e59bdd082ec8076c6fb2144d80e0567dbc3decaac72ffd5d541e4cbc4f347810194fe5bbe3b27a051dcead88724cd1da39b615d1363bd5fc25
|
||||||
|
DIST gtk+-2.24.31.tar.xz 12805344 SHA256 68c1922732c7efc08df4656a5366dcc3afdc8791513400dac276009b40954658 SHA512 75b846661308d94b5236e7e1c367deabf57753792ca87e92f9769822dd5ec90e00cd8d5574adcc12162e3702e1ae6dc152278a1d218f9bd9e4d1c8dc1dd520c1 WHIRLPOOL 6f59d444b28910b0f4cd7d0d0bf04f8e442acd945205679c19e5adf7ca3f8e7406d4095e9ff9ca597882eb937a7551e19af63b6597e7b57c0babe5b061f9110e
|
||||||
|
EBUILD gtk+-2.24.31-r99.ebuild 10243 SHA256 05c7a76af6d84f4975fc140fd84df9abdc85c707e1eee8c12aa2f58e3a5843a9 SHA512 87ea95a5789c4a588ee2d4920e446b3f2fca6c32d52f21526d66a01ac94ba9a8bce9059963285c97d21a0ccc4fae0d2b1aaffd2f7f62590da8d7b1705e5ed673 WHIRLPOOL 29e463d7b61c9e6b1817b0eec32c5899d2d2e72080079fa6910d2db33b8674a5632af08e73ac3382ad5275e75dd24eb9d004bafc20a75ad390dfcae74a048bde
|
||||||
33
x11-libs/gtk+/files/gtk+-2.24.24-out-of-source.patch
Normal file
33
x11-libs/gtk+/files/gtk+-2.24.24-out-of-source.patch
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
From 9e0f33144aff8d792ab105927cf686eda0afd25e Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Micha=C5=82=20G=C3=B3rny?= <mgorny@gentoo.org>
|
||||||
|
Date: Sun, 18 May 2014 10:50:05 +0200
|
||||||
|
Subject: [PATCH] aliasfilecheck: check for sources both in builddir & srcdir.
|
||||||
|
|
||||||
|
The $gtk_all_c_sources variable contains both supplied and generated
|
||||||
|
sources. The former reside in $srcdir, the latter in the build directory
|
||||||
|
(cwd).
|
||||||
|
|
||||||
|
In order to handle both kinds properly, first try to find each source
|
||||||
|
file in cwd, and then fallback to $srcdir. This makes it possible to use
|
||||||
|
out-of-source builds, and guarantees that fresh-built source files will
|
||||||
|
be used rather than pre-generated copies included in the distribution
|
||||||
|
tarball.
|
||||||
|
---
|
||||||
|
gtk/aliasfilescheck.sh | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/gtk/aliasfilescheck.sh b/gtk/aliasfilescheck.sh
|
||||||
|
index 31b49d4..3636a82 100755
|
||||||
|
--- a/gtk/aliasfilescheck.sh
|
||||||
|
+++ b/gtk/aliasfilescheck.sh
|
||||||
|
@@ -6,6 +6,6 @@ if test "x$gtk_all_c_sources" = x; then
|
||||||
|
fi
|
||||||
|
|
||||||
|
grep 'IN_FILE' ${srcdir-.}/gtk.symbols | sed 's/.*(//;s/).*//' | grep __ | sort -u > expected-files
|
||||||
|
-{ cd ${srcdir-.}; grep '^ *# *define __' $gtk_all_c_sources; } | sed 's/.*define //;s/ *$//' | sort > actual-files
|
||||||
|
+{ for f in $gtk_all_c_sources; do if test -f ${f}; then grep '^ *# *define __' ${f}; else grep '^ *# *define __' "${srcdir-.}"/${f}; fi; done } | sed 's/.*define //;s/ *$//' | sort > actual-files
|
||||||
|
|
||||||
|
diff expected-files actual-files && rm -f expected-files actual-files
|
||||||
|
--
|
||||||
|
1.9.3
|
||||||
|
|
||||||
42
x11-libs/gtk+/files/gtk+-2.24.31-fix-gtkentry-beep.patch
Normal file
42
x11-libs/gtk+/files/gtk+-2.24.31-fix-gtkentry-beep.patch
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
From debba4d14155a9e5736de069c2b693ab6f6e21aa Mon Sep 17 00:00:00 2001
|
||||||
|
From: Matthias Clasen <mclasen@redhat.com>
|
||||||
|
Date: Wed, 5 Oct 2016 12:20:14 -0400
|
||||||
|
Subject: [PATCH] entry: Fix a corner case of overwrite mode
|
||||||
|
|
||||||
|
We currently beep when a character is appended at the end in
|
||||||
|
overwrite mode. That is obviously not right. Patch based on
|
||||||
|
a patch by Ian MacDonald.
|
||||||
|
|
||||||
|
https://bugzilla.gnome.org/show_bug.cgi?id=772389
|
||||||
|
---
|
||||||
|
gtk/gtkentry.c | 7 ++++++-
|
||||||
|
1 file changed, 6 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/gtk/gtkentry.c b/gtk/gtkentry.c
|
||||||
|
index b522039..bc33754 100644
|
||||||
|
--- a/gtk/gtkentry.c
|
||||||
|
+++ b/gtk/gtkentry.c
|
||||||
|
@@ -5224,6 +5224,7 @@ gtk_entry_enter_text (GtkEntry *entry,
|
||||||
|
GtkEditable *editable = GTK_EDITABLE (entry);
|
||||||
|
gint tmp_pos;
|
||||||
|
gboolean old_need_im_reset;
|
||||||
|
+ guint text_length;
|
||||||
|
|
||||||
|
old_need_im_reset = entry->need_im_reset;
|
||||||
|
entry->need_im_reset = FALSE;
|
||||||
|
@@ -5233,7 +5234,11 @@ gtk_entry_enter_text (GtkEntry *entry,
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (entry->overwrite_mode)
|
||||||
|
- gtk_entry_delete_from_cursor (entry, GTK_DELETE_CHARS, 1);
|
||||||
|
+ {
|
||||||
|
+ text_length = gtk_entry_buffer_get_length (get_buffer (entry));
|
||||||
|
+ if (entry->current_pos < text_length)
|
||||||
|
+ gtk_entry_delete_from_cursor (entry, GTK_DELETE_CHARS, 1);
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
|
||||||
|
tmp_pos = entry->current_pos;
|
||||||
|
--
|
||||||
|
2.10.0
|
||||||
|
|
||||||
78
x11-libs/gtk+/files/gtk+-2.24.31-update-icon-cache.patch
Normal file
78
x11-libs/gtk+/files/gtk+-2.24.31-update-icon-cache.patch
Normal file
@@ -0,0 +1,78 @@
|
|||||||
|
From 260f94f3914ba18a256e6f1c222f643a57854e80 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Gilles Dartiguelongue <eva@gentoo.org>
|
||||||
|
Date: Sat, 9 May 2015 23:30:58 +0200
|
||||||
|
Subject: [PATCH] Always use external gtk-update-icon-cache
|
||||||
|
|
||||||
|
---
|
||||||
|
configure.ac | 8 +++-----
|
||||||
|
docs/reference/gtk/Makefile.am | 2 +-
|
||||||
|
gtk/Makefile.am | 13 ++-----------
|
||||||
|
3 files changed, 6 insertions(+), 17 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index 4e11b40..7ef8cb6 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -913,11 +913,9 @@ dnl Look for a host system's gdk-pixbuf-csource if we are cross-compiling
|
||||||
|
|
||||||
|
AM_CONDITIONAL(CROSS_COMPILING, test $cross_compiling = yes)
|
||||||
|
|
||||||
|
-if test $cross_compiling = yes; then
|
||||||
|
- AC_PATH_PROG(GTK_UPDATE_ICON_CACHE, gtk-update-icon-cache, no)
|
||||||
|
- if test x$GTK_UPDATE_ICON_CACHE = xno; then
|
||||||
|
- REBUILD_PNGS=#
|
||||||
|
- fi
|
||||||
|
+AC_PATH_PROG(GTK_UPDATE_ICON_CACHE, gtk-update-icon-cache, no)
|
||||||
|
+if test x$GTK_UPDATE_ICON_CACHE = xno; then
|
||||||
|
+ REBUILD_PNGS=#
|
||||||
|
fi
|
||||||
|
|
||||||
|
AC_PATH_PROG(GDK_PIXBUF_CSOURCE, gdk-pixbuf-csource, no)
|
||||||
|
diff --git a/docs/reference/gtk/Makefile.am b/docs/reference/gtk/Makefile.am
|
||||||
|
index c239445..60b5265 100644
|
||||||
|
--- a/docs/reference/gtk/Makefile.am
|
||||||
|
+++ b/docs/reference/gtk/Makefile.am
|
||||||
|
@@ -368,7 +368,7 @@ EXTRA_DIST += version.xml.in
|
||||||
|
|
||||||
|
if ENABLE_MAN
|
||||||
|
|
||||||
|
-man_MANS = gtk-query-immodules-2.0.1 gtk-update-icon-cache.1 gtk-builder-convert.1
|
||||||
|
+man_MANS = gtk-query-immodules-2.0.1 gtk-builder-convert.1
|
||||||
|
|
||||||
|
%.1 : %.xml
|
||||||
|
@XSLTPROC@ -nonet http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl $<
|
||||||
|
diff --git a/gtk/Makefile.am b/gtk/Makefile.am
|
||||||
|
index 8cc4536..a7afbf3 100644
|
||||||
|
--- a/gtk/Makefile.am
|
||||||
|
+++ b/gtk/Makefile.am
|
||||||
|
@@ -1087,8 +1087,7 @@ endif
|
||||||
|
# Installed tools
|
||||||
|
#
|
||||||
|
bin_PROGRAMS = \
|
||||||
|
- gtk-query-immodules-2.0 \
|
||||||
|
- gtk-update-icon-cache
|
||||||
|
+ gtk-query-immodules-2.0
|
||||||
|
|
||||||
|
bin_SCRIPTS = gtk-builder-convert
|
||||||
|
|
||||||
|
@@ -1438,16 +1437,8 @@ stamp-icons: $(STOCK_ICONS)
|
||||||
|
) done \
|
||||||
|
&& touch stamp-icons
|
||||||
|
|
||||||
|
-if CROSS_COMPILING
|
||||||
|
-gtk_update_icon_cache_program = $(GTK_UPDATE_ICON_CACHE)
|
||||||
|
-else
|
||||||
|
-gtk_update_icon_cache_program = \
|
||||||
|
- ./gtk-update-icon-cache
|
||||||
|
-endif
|
||||||
|
-
|
||||||
|
gtkbuiltincache.h: @REBUILD@ stamp-icons
|
||||||
|
- $(MAKE) $(AM_MAKEFLAGS) gtk-update-icon-cache$(EXEEXT)
|
||||||
|
- $(gtk_update_icon_cache_program) --force --ignore-theme-index \
|
||||||
|
+ $(GTK_UPDATE_ICON_CACHE) --force --ignore-theme-index \
|
||||||
|
--include-image-data \
|
||||||
|
--source builtin_icons stock-icons > gtkbuiltincache.h.tmp && \
|
||||||
|
mv gtkbuiltincache.h.tmp gtkbuiltincache.h
|
||||||
|
--
|
||||||
|
2.10.0
|
||||||
|
|
||||||
208
x11-libs/gtk+/files/gtk+-2.24.31_enable_paste_selection.patch
Normal file
208
x11-libs/gtk+/files/gtk+-2.24.31_enable_paste_selection.patch
Normal file
@@ -0,0 +1,208 @@
|
|||||||
|
diff -ur gtk+-2.24.31/gtk/gtkentry.c gtk+-2.24.31_patched/gtk/gtkentry.c
|
||||||
|
--- gtk+-2.24.31/gtk/gtkentry.c 2016-07-03 20:01:01.000000000 +0200
|
||||||
|
+++ gtk+-2.24.31_patched/gtk/gtkentry.c 2016-10-06 20:19:41.504175144 +0200
|
||||||
|
@@ -168,6 +168,7 @@
|
||||||
|
CUT_CLIPBOARD,
|
||||||
|
COPY_CLIPBOARD,
|
||||||
|
PASTE_CLIPBOARD,
|
||||||
|
+ PASTE_SELECTION,
|
||||||
|
TOGGLE_OVERWRITE,
|
||||||
|
ICON_PRESS,
|
||||||
|
ICON_RELEASE,
|
||||||
|
@@ -382,6 +383,8 @@
|
||||||
|
static void gtk_entry_cut_clipboard (GtkEntry *entry);
|
||||||
|
static void gtk_entry_copy_clipboard (GtkEntry *entry);
|
||||||
|
static void gtk_entry_paste_clipboard (GtkEntry *entry);
|
||||||
|
+static void gtk_entry_paste_selection (GtkEntry *entry,
|
||||||
|
+ const gchar *which);
|
||||||
|
static void gtk_entry_toggle_overwrite (GtkEntry *entry);
|
||||||
|
static void gtk_entry_select_all (GtkEntry *entry);
|
||||||
|
static void gtk_entry_real_activate (GtkEntry *entry);
|
||||||
|
@@ -612,6 +615,7 @@
|
||||||
|
class->cut_clipboard = gtk_entry_cut_clipboard;
|
||||||
|
class->copy_clipboard = gtk_entry_copy_clipboard;
|
||||||
|
class->paste_clipboard = gtk_entry_paste_clipboard;
|
||||||
|
+ class->paste_selection = gtk_entry_paste_selection;
|
||||||
|
class->toggle_overwrite = gtk_entry_toggle_overwrite;
|
||||||
|
class->activate = gtk_entry_real_activate;
|
||||||
|
class->get_text_area_size = gtk_entry_get_text_area_size;
|
||||||
|
@@ -1485,6 +1489,26 @@
|
||||||
|
_gtk_marshal_VOID__VOID,
|
||||||
|
G_TYPE_NONE, 0);
|
||||||
|
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * GtkEntry::paste-selection:
|
||||||
|
+ * @entry: the object which received the signal
|
||||||
|
+ *
|
||||||
|
+ * The ::paste-selection signal is a
|
||||||
|
+ * <link linkend="keybinding-signals">keybinding signal</link>
|
||||||
|
+ * which gets emitted to paste the contents of the given selection
|
||||||
|
+ * into the entry.
|
||||||
|
+ */
|
||||||
|
+ signals[PASTE_SELECTION] =
|
||||||
|
+ g_signal_new (I_("paste-selection"),
|
||||||
|
+ G_OBJECT_CLASS_TYPE (gobject_class),
|
||||||
|
+ G_SIGNAL_RUN_LAST | G_SIGNAL_ACTION,
|
||||||
|
+ G_STRUCT_OFFSET (GtkEntryClass, paste_selection),
|
||||||
|
+ NULL, NULL,
|
||||||
|
+ _gtk_marshal_VOID__STRING,
|
||||||
|
+ G_TYPE_NONE, 1,
|
||||||
|
+ G_TYPE_STRING);
|
||||||
|
+
|
||||||
|
/**
|
||||||
|
* GtkEntry::toggle-overwrite:
|
||||||
|
* @entry: the object which received the signal
|
||||||
|
@@ -5091,6 +5115,23 @@
|
||||||
|
gtk_widget_error_bell (GTK_WIDGET (entry));
|
||||||
|
}
|
||||||
|
|
||||||
|
+gtk_entry_paste_selection (GtkEntry *entry, const gchar *which)
|
||||||
|
+{
|
||||||
|
+ if (entry->editable)
|
||||||
|
+ {
|
||||||
|
+ if (g_str_equal(which, "primary"))
|
||||||
|
+ gtk_entry_paste (entry, GDK_SELECTION_PRIMARY);
|
||||||
|
+ else if (g_str_equal(which, "secondary"))
|
||||||
|
+ gtk_entry_paste (entry, GDK_SELECTION_PRIMARY);
|
||||||
|
+ else if (g_str_equal(which, "clipboard"))
|
||||||
|
+ gtk_entry_paste (entry, GDK_SELECTION_CLIPBOARD);
|
||||||
|
+ else
|
||||||
|
+ gtk_widget_error_bell (GTK_WIDGET (entry));
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ gtk_widget_error_bell (GTK_WIDGET (entry));
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static void
|
||||||
|
gtk_entry_delete_cb (GtkEntry *entry)
|
||||||
|
{
|
||||||
|
diff -ur gtk+-2.24.31/gtk/gtkentry.h gtk+-2.24.31_patched/gtk/gtkentry.h
|
||||||
|
--- gtk+-2.24.31/gtk/gtkentry.h 2015-12-28 16:42:28.000000000 +0100
|
||||||
|
+++ gtk+-2.24.31_patched/gtk/gtkentry.h 2016-10-06 19:59:44.000000000 +0200
|
||||||
|
@@ -149,6 +149,8 @@
|
||||||
|
void (* cut_clipboard) (GtkEntry *entry);
|
||||||
|
void (* copy_clipboard) (GtkEntry *entry);
|
||||||
|
void (* paste_clipboard) (GtkEntry *entry);
|
||||||
|
+ void (* paste_selection) (GtkEntry *entry,
|
||||||
|
+ const gchar *which);
|
||||||
|
void (* toggle_overwrite) (GtkEntry *entry);
|
||||||
|
|
||||||
|
/* hook to add other objects beside the entry (like in GtkSpinButton) */
|
||||||
|
@@ -160,7 +162,6 @@
|
||||||
|
|
||||||
|
/* Padding for future expansion */
|
||||||
|
void (*_gtk_reserved1) (void);
|
||||||
|
- void (*_gtk_reserved2) (void);
|
||||||
|
};
|
||||||
|
|
||||||
|
GType gtk_entry_get_type (void) G_GNUC_CONST;
|
||||||
|
diff -ur gtk+-2.24.31/gtk/gtktextview.c gtk+-2.24.31_patched/gtk/gtktextview.c
|
||||||
|
--- gtk+-2.24.31/gtk/gtktextview.c 2015-12-28 16:42:28.000000000 +0100
|
||||||
|
+++ gtk+-2.24.31_patched/gtk/gtktextview.c 2016-10-06 19:59:58.000000000 +0200
|
||||||
|
@@ -135,6 +135,7 @@
|
||||||
|
CUT_CLIPBOARD,
|
||||||
|
COPY_CLIPBOARD,
|
||||||
|
PASTE_CLIPBOARD,
|
||||||
|
+ PASTE_SELECTION,
|
||||||
|
TOGGLE_OVERWRITE,
|
||||||
|
MOVE_VIEWPORT,
|
||||||
|
SELECT_ALL,
|
||||||
|
@@ -281,6 +282,8 @@
|
||||||
|
static void gtk_text_view_cut_clipboard (GtkTextView *text_view);
|
||||||
|
static void gtk_text_view_copy_clipboard (GtkTextView *text_view);
|
||||||
|
static void gtk_text_view_paste_clipboard (GtkTextView *text_view);
|
||||||
|
+static void gtk_text_view_paste_selection (GtkTextView *text_view,
|
||||||
|
+ const gchar *which);
|
||||||
|
static void gtk_text_view_toggle_overwrite (GtkTextView *text_view);
|
||||||
|
static void gtk_text_view_toggle_cursor_visible (GtkTextView *text_view);
|
||||||
|
static void gtk_text_view_compat_move_focus(GtkTextView *text_view,
|
||||||
|
@@ -532,6 +535,7 @@
|
||||||
|
klass->cut_clipboard = gtk_text_view_cut_clipboard;
|
||||||
|
klass->copy_clipboard = gtk_text_view_copy_clipboard;
|
||||||
|
klass->paste_clipboard = gtk_text_view_paste_clipboard;
|
||||||
|
+ klass->paste_selection = gtk_text_view_paste_selection;
|
||||||
|
klass->toggle_overwrite = gtk_text_view_toggle_overwrite;
|
||||||
|
klass->move_focus = gtk_text_view_compat_move_focus;
|
||||||
|
klass->set_scroll_adjustments = gtk_text_view_set_scroll_adjustments;
|
||||||
|
@@ -925,6 +929,27 @@
|
||||||
|
_gtk_marshal_VOID__VOID,
|
||||||
|
G_TYPE_NONE, 0);
|
||||||
|
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * GtkTextView::paste-selection:
|
||||||
|
+ * @text_view: the object which received the signal
|
||||||
|
+ *
|
||||||
|
+ * The ::paste-selection signal is a
|
||||||
|
+ * <link linkend="keybinding-signals">keybinding signal</link>
|
||||||
|
+ * which gets emitted to paste the contents of the given selection
|
||||||
|
+ * into the text view.
|
||||||
|
+ */
|
||||||
|
+ signals[PASTE_SELECTION] =
|
||||||
|
+ g_signal_new (I_("paste-selection"),
|
||||||
|
+ G_OBJECT_CLASS_TYPE (gobject_class),
|
||||||
|
+ G_SIGNAL_RUN_LAST | G_SIGNAL_ACTION,
|
||||||
|
+ G_STRUCT_OFFSET (GtkTextViewClass, paste_selection),
|
||||||
|
+ NULL, NULL,
|
||||||
|
+ _gtk_marshal_VOID__STRING,
|
||||||
|
+ G_TYPE_NONE, 1,
|
||||||
|
+ G_TYPE_STRING);
|
||||||
|
+
|
||||||
|
+
|
||||||
|
/**
|
||||||
|
* GtkTextView::paste-clipboard:
|
||||||
|
* @text_view: the object which received the signal
|
||||||
|
@@ -5818,6 +5843,32 @@
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
+gtk_text_view_paste_selection (GtkTextView *text_view,
|
||||||
|
+ const gchar *which)
|
||||||
|
+{
|
||||||
|
+ GtkClipboard *clipboard = NULL;
|
||||||
|
+
|
||||||
|
+ if (g_str_equal (which, "primary"))
|
||||||
|
+ clipboard = gtk_widget_get_clipboard (GTK_WIDGET (text_view),
|
||||||
|
+ GDK_SELECTION_PRIMARY);
|
||||||
|
+ else if (g_str_equal (which, "secondary"))
|
||||||
|
+ clipboard = gtk_widget_get_clipboard (GTK_WIDGET (text_view),
|
||||||
|
+ GDK_SELECTION_SECONDARY);
|
||||||
|
+ else if (g_str_equal (which, "clipboard"))
|
||||||
|
+ clipboard = gtk_widget_get_clipboard (GTK_WIDGET (text_view),
|
||||||
|
+ GDK_SELECTION_CLIPBOARD);
|
||||||
|
+
|
||||||
|
+ if (clipboard)
|
||||||
|
+ gtk_text_buffer_paste_clipboard (get_buffer (text_view),
|
||||||
|
+ clipboard,
|
||||||
|
+ NULL,
|
||||||
|
+ text_view->editable);
|
||||||
|
+ else
|
||||||
|
+ gtk_widget_error_bell (GTK_WIDGET (text_view));
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+static void
|
||||||
|
gtk_text_view_paste_done_handler (GtkTextBuffer *buffer,
|
||||||
|
GtkClipboard *clipboard,
|
||||||
|
gpointer data)
|
||||||
|
diff -ur gtk+-2.24.31/gtk/gtktextview.h gtk+-2.24.31_patched/gtk/gtktextview.h
|
||||||
|
--- gtk+-2.24.31/gtk/gtktextview.h 2015-12-28 16:42:28.000000000 +0100
|
||||||
|
+++ gtk+-2.24.31_patched/gtk/gtktextview.h 2016-10-06 20:00:08.000000000 +0200
|
||||||
|
@@ -194,6 +194,8 @@
|
||||||
|
void (* cut_clipboard) (GtkTextView *text_view);
|
||||||
|
void (* copy_clipboard) (GtkTextView *text_view);
|
||||||
|
void (* paste_clipboard) (GtkTextView *text_view);
|
||||||
|
+ void (* paste_selection) (GtkTextView *text_view, const gchar *which);
|
||||||
|
+
|
||||||
|
/* overwrite */
|
||||||
|
void (* toggle_overwrite) (GtkTextView *text_view);
|
||||||
|
|
||||||
|
@@ -211,7 +213,6 @@
|
||||||
|
void (*_gtk_reserved4) (void);
|
||||||
|
void (*_gtk_reserved5) (void);
|
||||||
|
void (*_gtk_reserved6) (void);
|
||||||
|
- void (*_gtk_reserved7) (void);
|
||||||
|
};
|
||||||
|
|
||||||
|
GType gtk_text_view_get_type (void) G_GNUC_CONST;
|
||||||
313
x11-libs/gtk+/gtk+-2.24.31-r99.ebuild
Normal file
313
x11-libs/gtk+/gtk+-2.24.31-r99.ebuild
Normal file
@@ -0,0 +1,313 @@
|
|||||||
|
# Copyright 1999-2017 Gentoo Foundation
|
||||||
|
# Distributed under the terms of the GNU General Public License v2
|
||||||
|
|
||||||
|
EAPI=6
|
||||||
|
GNOME2_LA_PUNT="yes"
|
||||||
|
|
||||||
|
inherit autotools eutils flag-o-matic gnome2 multilib multilib-minimal readme.gentoo-r1 virtualx
|
||||||
|
|
||||||
|
DESCRIPTION="Gimp ToolKit +"
|
||||||
|
HOMEPAGE="http://www.gtk.org/"
|
||||||
|
|
||||||
|
LICENSE="LGPL-2+"
|
||||||
|
SLOT="2"
|
||||||
|
IUSE="aqua cups examples +introspection test vim-syntax xinerama"
|
||||||
|
REQUIRED_USE="
|
||||||
|
xinerama? ( !aqua )
|
||||||
|
"
|
||||||
|
|
||||||
|
KEYWORDS="alpha amd64 arm ~arm64 hppa ia64 ~mips ppc ppc64 ~s390 ~sh sparc x86 ~amd64-fbsd ~x86-fbsd ~amd64-linux ~arm-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
|
||||||
|
|
||||||
|
# Upstream wants us to do their job:
|
||||||
|
# https://bugzilla.gnome.org/show_bug.cgi?id=768663#c1
|
||||||
|
RESTRICT="test"
|
||||||
|
|
||||||
|
COMMON_DEPEND="
|
||||||
|
>=dev-libs/atk-2.10.0[introspection?,${MULTILIB_USEDEP}]
|
||||||
|
>=dev-libs/glib-2.34.3:2[${MULTILIB_USEDEP}]
|
||||||
|
>=media-libs/fontconfig-2.10.92[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/cairo-1.12.14-r4:=[aqua?,svg,${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/gdk-pixbuf-2.30.7:2[introspection?,${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/pango-1.36.3[introspection?,${MULTILIB_USEDEP}]
|
||||||
|
x11-misc/shared-mime-info
|
||||||
|
|
||||||
|
cups? ( >=net-print/cups-1.7.1-r2:=[${MULTILIB_USEDEP}] )
|
||||||
|
introspection? ( >=dev-libs/gobject-introspection-0.9.3:= )
|
||||||
|
!aqua? (
|
||||||
|
>=x11-libs/cairo-1.12.14-r4:=[aqua?,svg,X,${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/libXrender-0.9.8[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/libX11-1.6.2[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/libXi-1.7.2[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/libXext-1.3.2[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/libXrandr-1.5[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/libXcursor-1.1.14[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/libXfixes-5.0.1[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/libXcomposite-0.4.4-r1[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-libs/libXdamage-1.1.4-r1[${MULTILIB_USEDEP}]
|
||||||
|
xinerama? ( >=x11-libs/libXinerama-1.1.3[${MULTILIB_USEDEP}] )
|
||||||
|
)
|
||||||
|
"
|
||||||
|
# docbook-4.1.2 and xsl required for man pages
|
||||||
|
# docbook-4.3 required for gtk-doc
|
||||||
|
DEPEND="${COMMON_DEPEND}
|
||||||
|
app-text/docbook-xsl-stylesheets
|
||||||
|
app-text/docbook-xml-dtd:4.1.2
|
||||||
|
app-text/docbook-xml-dtd:4.3
|
||||||
|
dev-libs/libxslt
|
||||||
|
dev-libs/gobject-introspection-common
|
||||||
|
>=dev-util/gtk-doc-am-1.20
|
||||||
|
>=sys-devel/gettext-0.18.3[${MULTILIB_USEDEP}]
|
||||||
|
>=virtual/pkgconfig-0-r1[${MULTILIB_USEDEP}]
|
||||||
|
!aqua? (
|
||||||
|
>=x11-proto/xextproto-7.2.1-r1[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-proto/xproto-7.0.24[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-proto/inputproto-2.3[${MULTILIB_USEDEP}]
|
||||||
|
>=x11-proto/damageproto-1.2.1-r1[${MULTILIB_USEDEP}]
|
||||||
|
xinerama? ( >=x11-proto/xineramaproto-1.2.1-r1[${MULTILIB_USEDEP}] )
|
||||||
|
)
|
||||||
|
test? (
|
||||||
|
x11-themes/hicolor-icon-theme
|
||||||
|
media-fonts/font-misc-misc
|
||||||
|
media-fonts/font-cursor-misc )
|
||||||
|
"
|
||||||
|
|
||||||
|
# gtk+-2.24.8 breaks Alt key handling in <=x11-libs/vte-0.28.2:0
|
||||||
|
# Add blocker against old gtk-builder-convert to be sure we maintain both
|
||||||
|
# in sync.
|
||||||
|
RDEPEND="${COMMON_DEPEND}
|
||||||
|
>=dev-util/gtk-update-icon-cache-2
|
||||||
|
!<gnome-base/gail-1000
|
||||||
|
!<dev-util/gtk-builder-convert-${PV}
|
||||||
|
!<x11-libs/vte-0.28.2-r201:0
|
||||||
|
>=x11-themes/adwaita-icon-theme-3.14
|
||||||
|
x11-themes/gnome-themes-standard
|
||||||
|
"
|
||||||
|
# librsvg for svg icons (PDEPEND to avoid circular dep), bug #547710
|
||||||
|
PDEPEND="
|
||||||
|
x11-themes/gtk-engines-adwaita
|
||||||
|
gnome-base/librsvg[${MULTILIB_USEDEP}]
|
||||||
|
vim-syntax? ( app-vim/gtk-syntax )
|
||||||
|
"
|
||||||
|
|
||||||
|
DISABLE_AUTOFORMATTING="yes"
|
||||||
|
DOC_CONTENTS="To make the gtk2 file chooser use 'current directory' mode by default,
|
||||||
|
edit ~/.config/gtk-2.0/gtkfilechooser.ini to contain the following:
|
||||||
|
[Filechooser Settings]
|
||||||
|
StartupMode=cwd"
|
||||||
|
|
||||||
|
MULTILIB_CHOST_TOOLS=(
|
||||||
|
/usr/bin/gtk-query-immodules-2.0$(get_exeext)
|
||||||
|
)
|
||||||
|
|
||||||
|
strip_builddir() {
|
||||||
|
local rule=$1
|
||||||
|
shift
|
||||||
|
local directory=$1
|
||||||
|
shift
|
||||||
|
sed -e "s/^\(${rule} =.*\)${directory}\(.*\)$/\1\2/" -i $@ \
|
||||||
|
|| die "Could not strip director ${directory} from build."
|
||||||
|
}
|
||||||
|
|
||||||
|
set_gtk2_confdir() {
|
||||||
|
# An arch specific config directory is used on multilib systems
|
||||||
|
GTK2_CONFDIR="/etc/gtk-2.0/${CHOST}"
|
||||||
|
}
|
||||||
|
|
||||||
|
src_prepare() {
|
||||||
|
# marshalers code was pre-generated with glib-2.31, upstream bug #662109
|
||||||
|
rm -v gdk/gdkmarshalers.c gtk/gtkmarshal.c gtk/gtkmarshalers.c \
|
||||||
|
perf/marshalers.c || die
|
||||||
|
|
||||||
|
# Stop trying to build unmaintained docs, bug #349754, upstream bug #623150
|
||||||
|
strip_builddir SUBDIRS tutorial docs/Makefile.{am,in}
|
||||||
|
strip_builddir SUBDIRS faq docs/Makefile.{am,in}
|
||||||
|
|
||||||
|
# -O3 and company cause random crashes in applications, bug #133469
|
||||||
|
replace-flags -O3 -O2
|
||||||
|
strip-flags
|
||||||
|
|
||||||
|
if ! use test ; then
|
||||||
|
# don't waste time building tests
|
||||||
|
strip_builddir SRC_SUBDIRS tests Makefile.{am,in}
|
||||||
|
strip_builddir SUBDIRS tests gdk/Makefile.{am,in} gtk/Makefile.{am,in}
|
||||||
|
else
|
||||||
|
# Non-working test in gentoo's env
|
||||||
|
sed 's:\(g_test_add_func ("/ui-tests/keys-events.*\):/*\1*/:g' \
|
||||||
|
-i gtk/tests/testing.c || die "sed 1 failed"
|
||||||
|
|
||||||
|
# Cannot work because glib is too clever to find real user's home
|
||||||
|
# gentoo bug #285687, upstream bug #639832
|
||||||
|
# XXX: /!\ Pay extra attention to second sed when bumping /!\
|
||||||
|
sed '/TEST_PROGS.*recentmanager/d' -i gtk/tests/Makefile.am \
|
||||||
|
|| die "failed to disable recentmanager test (1)"
|
||||||
|
sed '/^TEST_PROGS =/,+3 s/recentmanager//' -i gtk/tests/Makefile.in \
|
||||||
|
|| die "failed to disable recentmanager test (2)"
|
||||||
|
sed 's:\({ "GtkFileChooserButton".*},\):/*\1*/:g' -i gtk/tests/object.c \
|
||||||
|
|| die "failed to disable recentmanager test (3)"
|
||||||
|
|
||||||
|
# https://bugzilla.gnome.org/show_bug.cgi?id=617473
|
||||||
|
sed -i -e 's:pltcheck.sh:$(NULL):g' \
|
||||||
|
gtk/Makefile.am || die
|
||||||
|
|
||||||
|
# UI tests require immodules already installed; bug #413185
|
||||||
|
if ! has_version 'x11-libs/gtk+:2'; then
|
||||||
|
ewarn "Disabling UI tests because this is the first install of"
|
||||||
|
ewarn "gtk+:2 on this machine. Please re-run the tests after $P"
|
||||||
|
ewarn "has been installed."
|
||||||
|
sed '/g_test_add_func.*ui-tests/ d' \
|
||||||
|
-i gtk/tests/testing.c || die "sed 2 failed"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! use examples; then
|
||||||
|
# don't waste time building demos
|
||||||
|
strip_builddir SRC_SUBDIRS demos Makefile.{am,in}
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Fix tests running when building out of sources, bug #510596, upstream bug #730319
|
||||||
|
eapply "${FILESDIR}"/${PN}-2.24.24-out-of-source.patch
|
||||||
|
|
||||||
|
# Rely on split gtk-update-icon-cache package, bug #528810
|
||||||
|
eapply "${FILESDIR}"/${PN}-2.24.31-update-icon-cache.patch
|
||||||
|
|
||||||
|
# Fix beep when overwriting at the end of a gtkentry, from gtk-2-24 branch
|
||||||
|
eapply "${FILESDIR}"/${PN}-2.24.31-fix-gtkentry-beep.patch
|
||||||
|
|
||||||
|
# Fix shift+insert shortcut to paste from PRIMARY selection instead of CLIPBOARD
|
||||||
|
eapply "${FILESDIR}"/${PN}-2.24.31_enable_paste_selection.patch
|
||||||
|
|
||||||
|
eautoreconf
|
||||||
|
gnome2_src_prepare
|
||||||
|
}
|
||||||
|
|
||||||
|
multilib_src_configure() {
|
||||||
|
[[ ${ABI} == ppc64 ]] && append-flags -mminimal-toc
|
||||||
|
|
||||||
|
ECONF_SOURCE=${S} \
|
||||||
|
gnome2_src_configure \
|
||||||
|
$(usex aqua --with-gdktarget=quartz --with-gdktarget=x11) \
|
||||||
|
$(usex aqua "" --with-xinput) \
|
||||||
|
$(use_enable cups cups auto) \
|
||||||
|
$(multilib_native_use_enable introspection) \
|
||||||
|
$(use_enable xinerama) \
|
||||||
|
--disable-papi \
|
||||||
|
--enable-man \
|
||||||
|
--with-xml-catalog="${EPREFIX}"/etc/xml/catalog \
|
||||||
|
CUPS_CONFIG="${EPREFIX}/usr/bin/${CHOST}-cups-config"
|
||||||
|
|
||||||
|
# work-around gtk-doc out-of-source brokedness
|
||||||
|
if multilib_is_native_abi; then
|
||||||
|
local d
|
||||||
|
for d in gdk gtk libgail-util; do
|
||||||
|
ln -s "${S}"/docs/reference/${d}/html docs/reference/${d}/html || die
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
multilib_src_test() {
|
||||||
|
virtx emake check
|
||||||
|
}
|
||||||
|
|
||||||
|
multilib_src_install() {
|
||||||
|
gnome2_src_install
|
||||||
|
}
|
||||||
|
|
||||||
|
multilib_src_install_all() {
|
||||||
|
# see bug #133241
|
||||||
|
# Also set more default variables in sync with gtk3 and other distributions
|
||||||
|
echo 'gtk-fallback-icon-theme = "gnome"' > "${T}/gtkrc"
|
||||||
|
echo 'gtk-theme-name = "Adwaita"' >> "${T}/gtkrc"
|
||||||
|
echo 'gtk-icon-theme-name = "Adwaita"' >> "${T}/gtkrc"
|
||||||
|
echo 'gtk-cursor-theme-name = "Adwaita"' >> "${T}/gtkrc"
|
||||||
|
|
||||||
|
insinto /usr/share/gtk-2.0
|
||||||
|
doins "${T}"/gtkrc
|
||||||
|
|
||||||
|
einstalldocs
|
||||||
|
|
||||||
|
# dev-util/gtk-builder-convert split off into a separate package, #402905
|
||||||
|
rm "${ED}"usr/bin/gtk-builder-convert || die
|
||||||
|
rm "${ED}"usr/share/man/man1/gtk-builder-convert.* || die
|
||||||
|
|
||||||
|
readme.gentoo_create_doc
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_preinst() {
|
||||||
|
gnome2_pkg_preinst
|
||||||
|
|
||||||
|
multilib_pkg_preinst() {
|
||||||
|
# Make immodules.cache belongs to gtk+ alone
|
||||||
|
local cache="usr/$(get_libdir)/gtk-2.0/2.10.0/immodules.cache"
|
||||||
|
|
||||||
|
if [[ -e ${EROOT}${cache} ]]; then
|
||||||
|
cp "${EROOT}"${cache} "${ED}"/${cache} || die
|
||||||
|
else
|
||||||
|
touch "${ED}"/${cache} || die
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
multilib_parallel_foreach_abi multilib_pkg_preinst
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_postinst() {
|
||||||
|
gnome2_pkg_postinst
|
||||||
|
|
||||||
|
multilib_pkg_postinst() {
|
||||||
|
gnome2_query_immodules_gtk2 \
|
||||||
|
|| die "Update immodules cache failed (for ${ABI})"
|
||||||
|
}
|
||||||
|
multilib_parallel_foreach_abi multilib_pkg_postinst
|
||||||
|
|
||||||
|
set_gtk2_confdir
|
||||||
|
|
||||||
|
if [ -e "${EROOT%/}/etc/gtk-2.0/gtk.immodules" ]; then
|
||||||
|
elog "File /etc/gtk-2.0/gtk.immodules has been moved to \$CHOST"
|
||||||
|
elog "aware location. Removing deprecated file."
|
||||||
|
rm -f ${EROOT%/}/etc/gtk-2.0/gtk.immodules
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -e "${EROOT%/}${GTK2_CONFDIR}/gtk.immodules" ]; then
|
||||||
|
elog "File /etc/gtk-2.0/gtk.immodules has been moved to"
|
||||||
|
elog "${EROOT%/}/usr/$(get_libdir)/gtk-2.0/2.10.0/immodules.cache"
|
||||||
|
elog "Removing deprecated file."
|
||||||
|
rm -f ${EROOT%/}${GTK2_CONFDIR}/gtk.immodules
|
||||||
|
fi
|
||||||
|
|
||||||
|
# pixbufs are now handled by x11-libs/gdk-pixbuf
|
||||||
|
if [ -e "${EROOT%/}${GTK2_CONFDIR}/gdk-pixbuf.loaders" ]; then
|
||||||
|
elog "File ${EROOT%/}${GTK2_CONFDIR}/gdk-pixbuf.loaders is now handled by x11-libs/gdk-pixbuf"
|
||||||
|
elog "Removing deprecated file."
|
||||||
|
rm -f ${EROOT%/}${GTK2_CONFDIR}/gdk-pixbuf.loaders
|
||||||
|
fi
|
||||||
|
|
||||||
|
# two checks needed since we dropped multilib conditional
|
||||||
|
if [ -e "${EROOT%/}/etc/gtk-2.0/gdk-pixbuf.loaders" ]; then
|
||||||
|
elog "File ${EROOT%/}/etc/gtk-2.0/gdk-pixbuf.loaders is now handled by x11-libs/gdk-pixbuf"
|
||||||
|
elog "Removing deprecated file."
|
||||||
|
rm -f ${EROOT%/}/etc/gtk-2.0/gdk-pixbuf.loaders
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -e "${EROOT%/}"/usr/lib/gtk-2.0/2.[^1]* ]; then
|
||||||
|
elog "You need to rebuild ebuilds that installed into" "${EROOT%/}"/usr/lib/gtk-2.0/2.[^1]*
|
||||||
|
elog "to do that you can use qfile from portage-utils:"
|
||||||
|
elog "emerge -va1 \$(qfile -qC ${EPREFIX}/usr/lib/gtk-2.0/2.[^1]*)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! has_version "app-text/evince"; then
|
||||||
|
elog "Please install app-text/evince for print preview functionality."
|
||||||
|
elog "Alternatively, check \"gtk-print-preview-command\" documentation and"
|
||||||
|
elog "add it to your gtkrc."
|
||||||
|
fi
|
||||||
|
|
||||||
|
readme.gentoo_print_elog
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_postrm() {
|
||||||
|
gnome2_pkg_postrm
|
||||||
|
|
||||||
|
if [[ -z ${REPLACED_BY_VERSION} ]]; then
|
||||||
|
multilib_pkg_postrm() {
|
||||||
|
rm -f "${EROOT}"usr/$(get_libdir)/gtk-2.0/2.10.0/immodules.cache
|
||||||
|
}
|
||||||
|
multilib_foreach_abi multilib_pkg_postrm
|
||||||
|
fi
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user