diff options
Diffstat (limited to 'packages/swt/files/swt-hildon.patch')
-rw-r--r-- | packages/swt/files/swt-hildon.patch | 263 |
1 files changed, 0 insertions, 263 deletions
diff --git a/packages/swt/files/swt-hildon.patch b/packages/swt/files/swt-hildon.patch deleted file mode 100644 index 90ceb1ee0e..0000000000 --- a/packages/swt/files/swt-hildon.patch +++ /dev/null @@ -1,263 +0,0 @@ -Index: swt-source/make_linux.mak -=================================================================== ---- swt-source.orig/make_linux.mak 2007-06-20 12:01:22.000000000 +0200 -+++ swt-source/make_linux.mak 2008-10-08 01:36:56.000000000 +0200 -@@ -45,8 +45,8 @@ - CAIROLIBS = `pkg-config --libs-only-L cairo` -lcairo - - # Do not use pkg-config to get libs because it includes unnecessary dependencies (i.e. pangoxft-1.0) --GTKCFLAGS = `pkg-config --cflags gtk+-2.0` --GTKLIBS = `pkg-config --libs-only-L gtk+-2.0 gthread-2.0` -lgtk-x11-2.0 -lgthread-2.0 -L/usr/X11R6/lib $(XLIB64) -lXtst -+GTKCFLAGS = `pkg-config --cflags gtk+-2.0 hildon-1 hildon-fm-2` -+GTKLIBS = -lhildon-1 -lhildonfm `pkg-config --libs-only-L gtk+-2.0 gthread-2.0` -lgtk-x11-2.0 -lgthread-2.0 -L/usr/X11R6/lib $(XLIB64) -lXtst - - CDE_LIBS = -L$(CDE_HOME)/lib -R$(CDE_HOME)/lib -lXt -lX11 -lDtSvc - -@@ -74,8 +74,6 @@ - -Wno-non-virtual-dtor \ - -fPIC \ - -I. \ -- -I$(JAVA_HOME)/include \ -- -I$(JAVA_HOME)/include/linux \ - ${SWT_PTR_CFLAGS} - MOZILLALIBS = -shared -Wl,--version-script=mozilla_exports -Bsymbolic - MOZILLAEXCLUDES = -DNO_XPCOMGlueShutdown -DNO_XPCOMGlueStartup -@@ -96,8 +94,6 @@ - -DSWT_VERSION=$(SWT_VERSION) \ - $(NATIVE_STATS) \ - -DLINUX -DGTK \ -- -I$(JAVA_HOME)/include \ -- -I$(JAVA_HOME)/include/linux \ - -fPIC \ - ${SWT_PTR_CFLAGS} - LIBS = -shared -fPIC -Index: swt-source/os.c -=================================================================== ---- swt-source.orig/os.c 2008-06-05 13:31:52.000000000 +0200 -+++ swt-source/os.c 2008-10-08 01:36:56.000000000 +0200 -@@ -17,6 +17,9 @@ - #include "os_structs.h" - #include "os_stats.h" - -+#include <hildon/hildon-program.h> -+#include <hildon/hildon-window.h> -+ - #define OS_NATIVE(func) Java_org_eclipse_swt_internal_gtk_OS_##func - - #ifndef NO_Call -@@ -7133,9 +7136,18 @@ - JNIEXPORT void JNICALL OS_NATIVE(_1gtk_1container_1add) - (JNIEnv *env, jclass that, jint arg0, jint arg1) - { -+ GtkContainer *container = (GtkContainer *) arg0; -+ GtkWidget *widget = (GtkWidget *) arg1; - OS_NATIVE_ENTER(env, that, _1gtk_1container_1add_FUNC); -- gtk_container_add((GtkContainer *)arg0, (GtkWidget *)arg1); -- OS_NATIVE_EXIT(env, that, _1gtk_1container_1add_FUNC); -+ if (GTK_CHECK_TYPE (widget, GTK_TYPE_MENU) -+ && !strcmp(gtk_menu_get_title(GTK_MENU(widget)), "__main_menu__")) -+ { -+ hildon_window_set_menu(HILDON_WINDOW(container), GTK_MENU(widget)); -+ } -+ else -+ gtk_container_add((GtkContainer *)arg0, (GtkWidget *)arg1); -+ -+ OS_NATIVE_EXIT(env, that, _1gtk_1container_1add_FUNC); - } - #endif - -@@ -9375,9 +9387,12 @@ - JNIEXPORT jint JNICALL OS_NATIVE(_1gtk_1menu_1bar_1new) - (JNIEnv *env, jclass that) - { -+ GtkWidget *menu; - jint rc = 0; - OS_NATIVE_ENTER(env, that, _1gtk_1menu_1bar_1new_FUNC); -- rc = (jint)gtk_menu_bar_new(); -+ menu = gtk_menu_new(); -+ gtk_menu_set_title(menu, "__main_menu__"); -+ rc = (jint) menu; - OS_NATIVE_EXIT(env, that, _1gtk_1menu_1bar_1new_FUNC); - return rc; - } -@@ -15849,8 +15864,23 @@ - (JNIEnv *env, jclass that, jint arg0) - { - jint rc = 0; -+ HildonProgram *p; -+ GtkWidget *w; - OS_NATIVE_ENTER(env, that, _1gtk_1window_1new_FUNC); -- rc = (jint)gtk_window_new((GtkWindowType)arg0); -+/* -+ if (GTK_WINDOW_TOPLEVEL == (GtkWindowType) arg0) -+ { -+*/ -+ p = hildon_program_get_instance(); -+ w = hildon_window_new(); -+ hildon_program_add_window(p, HILDON_WINDOW(w)); -+/* gtk_window_fullscreen(GTK_WINDOW(w));*/ -+/* -+ } -+ else -+ w = gtk_window_new(GTK_WINDOW_POPUP); -+*/ -+ rc = (jint) w; - OS_NATIVE_EXIT(env, that, _1gtk_1window_1new_FUNC); - return rc; - } -Index: swt-source/org/eclipse/swt/widgets/Menu.java -=================================================================== ---- swt-source.orig/org/eclipse/swt/widgets/Menu.java 2008-06-05 13:31:08.000000000 +0200 -+++ swt-source/org/eclipse/swt/widgets/Menu.java 2008-10-08 01:36:56.000000000 +0200 -@@ -287,9 +287,17 @@ - if ((style & SWT.BAR) != 0) { - handle = OS.gtk_menu_bar_new (); - if (handle == 0) error (SWT.ERROR_NO_HANDLES); -+ if (parent instanceof Shell) -+ { -+ int /*long*/ shellHandle = ((Shell) parent).shellHandle; -+ OS.gtk_container_add (shellHandle, handle); -+ } -+ else -+ { - int /*long*/ vboxHandle = parent.vboxHandle; - OS.gtk_container_add (vboxHandle, handle); - OS.gtk_box_set_child_packing (vboxHandle, handle, false, true, 0, OS.GTK_PACK_START); -+ } - } else { - handle = OS.gtk_menu_new (); - if (handle == 0) error (SWT.ERROR_NO_HANDLES); -Index: swt-source/org/eclipse/swt/internal/gtk/OS.java -=================================================================== ---- swt-source.orig/org/eclipse/swt/internal/gtk/OS.java 2008-06-05 13:32:08.000000000 +0200 -+++ swt-source/org/eclipse/swt/internal/gtk/OS.java 2008-10-08 01:36:56.000000000 +0200 -@@ -473,6 +473,11 @@ - public static final byte[] window_state_event = ascii("window-state-event"); - - /** Properties */ -+ /* Maemo hildon specific - border added due to toolbar */ -+ public static final byte[] toolbar_borders = ascii("toolbar-borders"); -+ /* Maemo hildon specific - border added due to skin graphics area */ -+ public static final byte[] borders = ascii("borders"); -+ - public static final byte[] active = ascii("active"); - public static final byte[] background_gdk = ascii("background-gdk"); - public static final byte[] button_relief = ascii("button-relief"); -Index: swt-source/org/eclipse/swt/widgets/Shell.java -=================================================================== ---- swt-source.orig/org/eclipse/swt/widgets/Shell.java 2008-06-05 13:31:10.000000000 +0200 -+++ swt-source/org/eclipse/swt/widgets/Shell.java 2008-10-08 01:36:56.000000000 +0200 -@@ -1067,6 +1067,14 @@ - int /*long*/ gtk_size_allocate (int /*long*/ widget, int /*long*/ allocation) { - int width = OS.GTK_WIDGET_WIDTH (shellHandle); - int height = OS.GTK_WIDGET_HEIGHT (shellHandle); -+ -+ if (!fullScreen) -+ { -+ GtkBorder b = getMaemoBorder(false); -+ width -= (b.left + b.right); -+ height -= (b.top + b.bottom); -+ } -+ - if (!resized || oldWidth != width || oldHeight != height) { - oldWidth = width; - oldHeight = height; -@@ -1472,14 +1480,53 @@ - if ((state & FOREIGN_HANDLE) != 0) return; - Monitor monitor = getMonitor (); - Rectangle rect = monitor.getClientArea (); -+/* - int width = rect.width * 5 / 8; - int height = rect.height * 5 / 8; -+*/ -+ -+ int width = rect.width; -+ int height = rect.height; -+ -+ // Instead of some arbitrary defaults we can use the complete "application -+ // area" on the maemo platform. -+ if (!fullScreen) -+ { -+ GtkBorder b = getMaemoBorder(false); -+ width -= (b.left + b.right); -+ height -= (b.top + b.bottom); -+ } -+ - if ((style & SWT.RESIZE) != 0) { - OS.gtk_window_resize (shellHandle, width, height); - } - resizeBounds (width, height, false); - } - -+/** -+ * Retrieves the "borders" or "toolbar-borders" property -+ * from the Shell. -+ * -+ * That is neccessary to calculate correct Shell sizes on -+ * the Maemo platform. -+ * -+ */ -+private GtkBorder getMaemoBorder(boolean wantToolbarBorder) -+{ -+ GtkBorder b = new GtkBorder(); -+ -+ int /*long*/ [] result = new int /*long*/[1]; -+ OS.gtk_widget_style_get(shellHandle, -+ (wantToolbarBorder ? OS.toolbar_borders -+ : OS.borders), -+ result, 0); -+ -+ if (result[0] != 0) -+ OS.memmove(b, result[0], GtkBorder.sizeof); -+ -+ return b; -+} -+ - public void setMaximized (boolean maximized) { - checkWidget(); - super.setMaximized (maximized); -Index: swt-source/os_custom.c -=================================================================== ---- swt-source.orig/os_custom.c 2008-06-05 13:31:50.000000000 +0200 -+++ swt-source/os_custom.c 2008-10-08 01:36:56.000000000 +0200 -@@ -13,6 +13,8 @@ - * IBM Corporation - initial API and implementation - *******************************************************************************/ - -+#include <hildon/hildon-file-chooser-dialog.h> -+ - #include "swt.h" - #include "os_structs.h" - #include "os_stats.h" -@@ -41,11 +43,22 @@ - { - jbyte *lparg0=NULL; - SWT_PTR rc = 0; -+ GtkWidget *widget = NULL; - OS_NATIVE_ENTER(env, that, _1gtk_1file_1chooser_1dialog_1new_FUNC); - if (arg0) if ((lparg0 = (*env)->GetByteArrayElements(env, arg0, NULL)) == NULL) goto fail; - /* - rc = (SWT_PTR)gtk_file_chooser_dialog_new(lparg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7); - */ -+ /* Remaining arguments are thrown away as they cannot be used for the -+ * HildonFileChooserDialog anyways. -+ */ -+ widget = (SWT_PTR) hildon_file_chooser_dialog_new(arg1, (GtkFileChooserAction) arg2); -+ gtk_window_set_title(GTK_WINDOW(widget), (const gchar *) lparg0); -+ -+ rc = (SWT_PTR) widget; -+#if 0 -+// The code is not supposed to run on AMD64. -+ - { - static int initialized = 0; - static void *handle = NULL; -@@ -70,6 +83,8 @@ - rc = (SWT_PTR)(*fptr)(lparg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7); - } - } -+#endif -+ - fail: - if (arg0 && lparg0) (*env)->ReleaseByteArrayElements(env, arg0, lparg0, 0); - OS_NATIVE_EXIT(env, that, _1gtk_1file_1chooser_1dialog_1new_FUNC); |