diff options
Diffstat (limited to 'rox-base/pager/files')
-rw-r--r-- | rox-base/pager/files/01_all_libwnck-2-fix.patch | 505 | ||||
-rw-r--r-- | rox-base/pager/files/digest-pager-1.0.1 | 1 |
2 files changed, 506 insertions, 0 deletions
diff --git a/rox-base/pager/files/01_all_libwnck-2-fix.patch b/rox-base/pager/files/01_all_libwnck-2-fix.patch new file mode 100644 index 000000000000..e5152e7930cb --- /dev/null +++ b/rox-base/pager/files/01_all_libwnck-2-fix.patch @@ -0,0 +1,505 @@ +Only in src/: Makefile +diff -Pua src/Makefile.in fixed/Makefile.in +--- src/Makefile.in 2004-07-15 07:10:54.000000000 -0400 ++++ fixed/Makefile.in 2005-09-18 08:19:39.000000000 -0400 +@@ -17,9 +17,9 @@ + + PROG = Pager + +-SRCS = choices.c gui_support.c main.c options.c rox_gettext.c ++SRCS = choices.c gui_support.c main.c options.c rox_gettext.c window-menu.c + +-OBJECTS = choices.o gui_support.o main.o options.o rox_gettext.o ++OBJECTS = choices.o gui_support.o main.o options.o rox_gettext.o window-menu.o + + ############ Things to keep the same + +Only in src/: choices.c +Only in src/: choices.h +diff -Pua src/config.h.in fixed/config.h.in +--- src/config.h.in 2004-07-15 07:10:54.000000000 -0400 ++++ fixed/config.h.in 2005-09-18 08:19:52.000000000 -0400 +@@ -2,6 +2,8 @@ + + #define PROJECT "Pager" + ++#undef HAVE_WNCK_CREATE_WINDOW_MENU ++ + #include "rox_gettext.h" + #define _(String) rox_gettext(String) + /* Short for gettext_noop() - marks a string as translatable without +Only in src/: configure +diff -Pua src/configure.in fixed/configure.in +--- src/configure.in 2003-07-16 06:38:38.000000000 -0400 ++++ fixed/configure.in 2005-09-18 08:20:05.000000000 -0400 +@@ -82,6 +82,12 @@ + AC_C_CONST + AC_TYPE_SIZE_T + ++dnl does libwnck have wnck_create_window_menu() ? ++ac_LIBS="$LIBS" ++LIBS="$LIBS `pkg-config --libs libwnck-1.0`" ++AC_CHECK_FUNCS(wnck_create_window_menu) ++LIBS="$ac_LIBS" ++ + dnl Extract version info from AppInfo.xml + AC_MSG_CHECKING(extracting version information) + [ +Only in src/: global.h +Only in src/: gui_support.c +Only in src/: gui_support.h +diff -Pua src/main.c fixed/main.c +--- src/main.c 2004-08-15 13:19:39.000000000 -0400 ++++ fixed/main.c 2005-09-18 08:19:24.000000000 -0400 +@@ -18,6 +18,8 @@ + #include "options.h" + #include "choices.h" + ++#include "window-menu.h" ++ + char *app_dir = NULL; + + static GdkWindow *socket = NULL; /* NULL => Not an applet */ +@@ -28,6 +30,13 @@ + + static Option n_rows; + ++static int ++workspace_at_point (WnckPager *pager, ++ int x, ++ int y, ++ int *viewport_x, ++ int *viewport_y); ++ + /* Read the contents of this property. g_free() the result. */ + static char *read_property(GdkWindow *window, GdkAtom prop, + GdkAtom type, gint *out_length) +@@ -169,14 +178,47 @@ + return window_list; + } + ++/* Returns a list of the windows on the active workspace */ ++static GList *get_workspace_window_list(WnckWorkspace *work_space, ++ GList *wins) ++{ ++ GList *window_list = NULL; ++ while (wins) ++ { ++ WnckWindow *window = WNCK_WINDOW(wins->data); ++ if (wnck_window_is_on_workspace(window,work_space)) ++ window_list = g_list_append(window_list,wins->data); ++ wins = wins->next; ++ } ++ wins = g_list_first(wins); ++ return window_list; ++} ++ ++/* Returns the selected workspace from the pager widget */ ++static WnckWorkspace *get_selected_workspace(GdkEventButton *event) ++{ ++ int space_number; ++ ++ space_number = workspace_at_point(WNCK_PAGER(pager), ++ event->x, event->y, ++ NULL, NULL); ++ if (space_number == -1) ++ return wnck_screen_get_active_workspace(screen); ++ ++ return wnck_screen_get_workspace(screen, space_number); ++} ++ + static gboolean button_event(GtkWidget *widget, + GdkEventButton *event, + gpointer user_data) + { + if (event->button == 3) + { ++ WnckWorkspace *work_space; ++ GtkWidget *menu_all; + GtkWidget *menu; + GtkWidget *item; ++ GList *wins_all; + GList *wins; + gchar *pos = NULL; + +@@ -186,12 +228,28 @@ + gdk_atom_intern("_ROX_PANEL_MENU_POS", + FALSE)); + } +- + +- wins = get_window_list(); ++ wins_all = get_window_list(); ++#ifdef HAVE_WNCK_CREATE_WINDOW_MENU ++ menu_all = wnck_create_window_menu(wins_all); ++#else ++ menu_all = our_create_window_menu(wins_all); ++#endif ++ ++ work_space = get_selected_workspace(event); ++ wins = get_workspace_window_list(work_space,wins_all); ++#ifdef HAVE_WNCK_CREATE_WINDOW_MENU + menu = wnck_create_window_menu(wins); ++#else ++ menu = our_create_window_menu(wins); ++#endif + + item = gtk_menu_item_new(); ++ ++ item = gtk_menu_item_new_with_label(_("All windows")); ++ gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), menu_all); ++ gtk_widget_show(item); ++ + gtk_menu_append(GTK_MENU(menu), item); + gtk_widget_show(item); + +@@ -260,8 +318,7 @@ + { + double aspect; + Orient orient = panel_get_orient(); +- int n_screens = wnck_screen_get_workspace_count( +- wnck_screen_get_default()); ++ int n_screens = wnck_screen_get_workspace_count(screen); + + *width = alloc_width; + *height = alloc_height; +@@ -467,3 +524,175 @@ + + return 0; + } ++ ++/* Taken from libwnck/pager.c */ ++#define POINT_IN_RECT(xcoord, ycoord, rect) \ ++ ((xcoord) >= (rect).x && \ ++ (xcoord) < ((rect).x + (rect).width) && \ ++ (ycoord) >= (rect).y && \ ++ (ycoord) < ((rect).y + (rect).height)) ++ ++#define N_SCREEN_CONNECTIONS 11 ++ ++static void ++get_workspace_rect (WnckPager *pager, ++ int space, ++ GdkRectangle *rect) ++{ ++ int hsize, vsize; ++ int n_spaces; ++ int spaces_per_row; ++ GtkWidget *widget; ++ int col, row; ++ int focus_width; ++ int nrows = n_rows.int_value; ++ ++ gtk_widget_style_get (GTK_WIDGET (pager), ++ "focus-line-width", &focus_width, ++ NULL); ++ ++ widget = GTK_WIDGET (pager); ++ ++ hsize = widget->allocation.width - 2 * focus_width; ++ vsize = widget->allocation.height - 2 * focus_width; ++ ++ /* if (pager->priv->shadow_type != GTK_SHADOW_NONE) */ ++ { ++ hsize -= 2 * widget->style->xthickness; ++ vsize -= 2 * widget->style->ythickness; ++ } ++ ++ n_spaces = wnck_screen_get_workspace_count (wnck_screen_get_default ()); ++ ++ g_return_if_fail(nrows > 0); ++ spaces_per_row = (n_spaces + nrows - 1) / nrows; ++ ++ if (panel_get_orient() == ORIENT_VERT) ++ { ++ rect->width = (hsize - (nrows - 1)) / nrows; ++ rect->height = (vsize - (spaces_per_row - 1)) / spaces_per_row; ++ ++ col = space / spaces_per_row; ++ row = space % spaces_per_row; ++ rect->x = (rect->width + 1) * col; ++ rect->y = (rect->height + 1) * row; ++ ++ if (col == nrows - 1) ++ rect->width = hsize - rect->x; ++ ++ if (row == spaces_per_row - 1) ++ rect->height = vsize - rect->y; ++ } ++ else ++ { ++ rect->width = (hsize - (spaces_per_row - 1)) / spaces_per_row; ++ rect->height = (vsize - (nrows - 1)) / nrows; ++ ++ col = space % spaces_per_row; ++ row = space / spaces_per_row; ++ rect->x = (rect->width + 1) * col; ++ rect->y = (rect->height + 1) * row; ++ ++ if (col == spaces_per_row - 1) ++ rect->width = hsize - rect->x; ++ ++ if (row == nrows - 1) ++ rect->height = vsize - rect->y; ++ } ++ ++ rect->x += focus_width; ++ rect->y += focus_width; ++ ++ /* if (pager->priv->shadow_type != GTK_SHADOW_NONE) */ ++ { ++ rect->x += widget->style->xthickness; ++ rect->y += widget->style->ythickness; ++ } ++} ++ ++static int ++workspace_at_point (WnckPager *pager, ++ int x, ++ int y, ++ int *viewport_x, ++ int *viewport_y) ++{ ++ GtkWidget *widget; ++ int i; ++ int n_spaces; ++ int focus_width; ++ int xthickness; ++ int ythickness; ++ ++ widget = GTK_WIDGET (pager); ++ ++ gtk_widget_style_get (GTK_WIDGET (pager), ++ "focus-line-width", &focus_width, ++ NULL); ++ ++ xthickness = focus_width + widget->style->xthickness; ++ ythickness = focus_width + widget->style->ythickness; ++ ++ n_spaces = wnck_screen_get_workspace_count (screen); ++ ++ i = 0; ++ while (i < n_spaces) ++ { ++ GdkRectangle rect; ++ ++ get_workspace_rect (pager, i, &rect); ++ ++ /* if (pager->priv->shadow_type != GTK_SHADOW_NONE) */ ++ { ++ /* If workspace is on the edge, pretend points on the frame ++ * belong to the workspace. ++ */ ++ ++ GtkWidget *widget = GTK_WIDGET (pager); ++ ++ if (rect.x == xthickness) ++ { ++ rect.x = 0; ++ rect.width += xthickness; ++ } ++ if (rect.y == ythickness) ++ { ++ rect.y = 0; ++ rect.height += ythickness; ++ } ++ if (rect.y + rect.height == widget->allocation.height - ythickness) ++ { ++ rect.height += ythickness; ++ } ++ if (rect.x + rect.width == widget->allocation.width - xthickness) ++ { ++ rect.width += xthickness; ++ } ++ } ++ ++ if (POINT_IN_RECT (x, y, rect)) ++ { ++ double width_ratio, height_ratio; ++ WnckWorkspace *space; ++ ++ space = wnck_screen_get_workspace (screen, i); ++ g_assert (space != NULL); ++ ++ /* Scale x, y mouse coords to corresponding screenwide viewport coords */ ++ ++ width_ratio = (double) wnck_workspace_get_width (space) / (double) rect.width; ++ height_ratio = (double) wnck_workspace_get_height (space) / (double) rect.height; ++ ++ if (viewport_x) ++ *viewport_x = width_ratio * (x - rect.x); ++ if (viewport_y) ++ *viewport_y = height_ratio * (y - rect.y); ++ ++ return i; ++ } ++ ++ ++i; ++ } ++ ++ return -1; ++} +Only in src/: options.c +Only in src/: options.h +Only in src/: po +Only in src/: rox_gettext.c +Only in src/: rox_gettext.h +diff -Pua src/window-menu.c fixed/window-menu.c +--- src/window-menu.c 1969-12-31 19:00:00.000000000 -0500 ++++ fixed/window-menu.c 2005-09-18 08:20:16.000000000 -0400 +@@ -0,0 +1,137 @@ ++/* window menu */ ++ ++/* ++ * Copyright (C) 2001 Havoc Pennington ++ * ++ * This library is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU Library 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 ++ * Library General Public License for more details. ++ * ++ * You should have received a copy of the GNU Library General Public ++ * License along with this library; if not, write to the ++ * Free Software Foundation, Inc., 59 Temple Place - Suite 330, ++ * Boston, MA 02111-1307, USA. ++ */ ++ ++/* Modified by Lucas Hazel and Stephen Watson for use in the Pager ++ * application because it was removed from later libwnck versions ++ */ ++ ++#include "config.h" ++#ifndef HAVE_WNCK_CREATE_WINDOW_MENU ++ ++#include "window-menu.h" ++ ++static void object_weak_notify (gpointer data, ++ GObject *obj); ++static void window_weak_notify (gpointer data, ++ GObject *window); ++ ++static void ++window_weak_notify (gpointer data, ++ GObject *window) ++{ ++ g_object_set_data (G_OBJECT (data), "wnck-window-data", NULL); ++ g_object_weak_unref (G_OBJECT (data), ++ object_weak_notify, ++ window); ++} ++ ++static void ++set_window (GObject *obj, ++ WnckWindow *win) ++{ ++ g_object_set_data (obj, "wnck-window-data", win); ++ if (win) ++ { ++ g_object_weak_ref (G_OBJECT (win), window_weak_notify, obj); ++ g_object_weak_ref (obj, object_weak_notify, win); ++ } ++} ++ ++static void ++object_weak_notify (gpointer data, ++ GObject *obj) ++{ ++ g_object_weak_unref (G_OBJECT (data), ++ window_weak_notify, ++ obj); ++} ++ ++static WnckWindow* ++get_window (GObject *obj) ++{ ++ return g_object_get_data (obj, "wnck-window-data"); ++} ++ ++static void ++item_activated_callback (GtkWidget *menu_item, ++ gpointer data) ++{ ++ WnckWindow *win; ++ ++ win = get_window (G_OBJECT (menu_item)); ++ ++ if (win == NULL) ++ return; ++ ++ wnck_window_activate (win, 0); ++} ++ ++GtkWidget* ++our_create_window_menu (GList *windows) ++{ ++ GList *tmp; ++ GtkWidget *menu; ++ ++ menu = gtk_menu_new (); ++ ++ tmp = windows; ++ ++ while (tmp != NULL) ++ { ++ WnckWindow *win = WNCK_WINDOW (tmp->data); ++ GdkPixbuf *icon; ++ const char *title; ++ GtkWidget *mi; ++ ++ icon = wnck_window_get_icon (win); ++ title = wnck_window_get_icon_name (win); ++ ++ if (icon) ++ { ++ GtkWidget *image; ++ ++ image = gtk_image_new_from_pixbuf (icon); ++ ++ mi = gtk_image_menu_item_new_with_label (title); ++ gtk_image_menu_item_set_image (GTK_IMAGE_MENU_ITEM (mi), ++ image); ++ } ++ else ++ { ++ mi = gtk_menu_item_new_with_label (title); ++ } ++ ++ g_signal_connect (G_OBJECT (mi), "activate", ++ G_CALLBACK (item_activated_callback), NULL); ++ ++ set_window (G_OBJECT (mi), win); ++ ++ gtk_widget_show (mi); ++ ++ gtk_menu_shell_append (GTK_MENU_SHELL (menu), mi); ++ ++ tmp = tmp->next; ++ } ++ ++ return menu; ++} ++ ++#endif /* HAVE_WNCK_CREATE_WINDOW_MENU */ +diff -Pua src/window-menu.h fixed/window-menu.h +--- src/window-menu.h 1969-12-31 19:00:00.000000000 -0500 ++++ fixed/window-menu.h 2005-09-18 08:20:27.000000000 -0400 +@@ -0,0 +1,14 @@ ++#ifndef HAVE_WNCK_CREATE_WINDOW_MENU ++ ++#ifndef WINDOW_MENU_H ++#define WINDOW_MENU_H ++ ++#define WNCK_I_KNOW_THIS_IS_UNSTABLE ++ ++#include <libwnck/libwnck.h> ++ ++extern GtkWidget* our_create_window_menu (GList *windows); ++ ++#endif /* WINDOW_MENU_H */ ++ ++#endif /* HAVE_WNCK_CREATE_WINDOW_MENU */ diff --git a/rox-base/pager/files/digest-pager-1.0.1 b/rox-base/pager/files/digest-pager-1.0.1 new file mode 100644 index 000000000000..1d1a7fa61e67 --- /dev/null +++ b/rox-base/pager/files/digest-pager-1.0.1 @@ -0,0 +1 @@ +MD5 78e00f3d0d827edfe182bf4db906272a pager-1.0.1.tgz 46081 |