diff options
author | kho <kho@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-01-19 14:27:45 +0000 |
---|---|---|
committer | kho <kho@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-01-19 14:27:45 +0000 |
commit | fea51eac929c4bc60b4e75a13ca674deec587952 (patch) | |
tree | 34def173eca9b0823df6cf9bb1777b1bb4131cfc /libjava/jni | |
parent | 4910bd8d8f04c3e09cf872c0b50f3fa34c8a503b (diff) | |
download | gcc-fea51eac929c4bc60b4e75a13ca674deec587952.tar.gz |
2004-01-19 Kim Ho <kho@redhat.com>
* gnu/java/awt/peer/gtk/GtkFramePeer.java (getMenuBarHeight): Added
MenuBarPeer parameter.
(removeMenuBarPeer): New native method.
(setMenuBar): Call remove if menu bar is null. Adjust insets
appropriately.
(postSizeAllocateEvent): New method. Called when menu bar size is
allocated. Adjust insets and redo layout.
(GtkFramePeer): Set menu bar during frame creation.
(postConfigureEvent): Adjust position and size to accomodate
menu bar.
* java/awt/Frame.java (setMenuBar): addNotify to create menu bar.
* java/awt/Menu.java (addSeparator): Use peer's addSeparator.
(addNotify): Create the peer if it doesn't exist and call addNotify
for the menu's items.
* java/awt/MenuBar.java (addNotify): Create this menu bar's menus.
* java/awt/MenuItem.java (addNotify): Create the peer if it
doesn't exist.
* jni/gtk-peer/gnu_java_awt_peer_gtk_GtkWindowPeer.c
(removeMenuBarPeer): New method. Remove menu bar on the current
frame.
(setMenuBarPeer): Add the menu bar to the current frame and the
callback for size-allocate events on the menu bar.
(getMenuBarHeight): Add menu bar parameter.
(menubar_resize_cb): New callback method for postSizeAllocate events.
Also: Fix indentation on last ChangeLog entry.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@76149 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libjava/jni')
-rw-r--r-- | libjava/jni/gtk-peer/gnu_java_awt_peer_gtk_GtkWindowPeer.c | 86 |
1 files changed, 63 insertions, 23 deletions
diff --git a/libjava/jni/gtk-peer/gnu_java_awt_peer_gtk_GtkWindowPeer.c b/libjava/jni/gtk-peer/gnu_java_awt_peer_gtk_GtkWindowPeer.c index 677f1532a12..8ad7a2cdcec 100644 --- a/libjava/jni/gtk-peer/gnu_java_awt_peer_gtk_GtkWindowPeer.c +++ b/libjava/jni/gtk-peer/gnu_java_awt_peer_gtk_GtkWindowPeer.c @@ -1,5 +1,5 @@ /* gtkwindowpeer.c -- Native implementation of GtkWindowPeer - Copyright (C) 1998, 1999, 2002, 2004 Free Software Foundation, Inc. + Copyright (C) 1998, 1999, 2002 Free Software Foundation, Inc. This file is part of GNU Classpath. @@ -72,6 +72,8 @@ static jint window_get_new_state (GtkWidget *widget); static gboolean window_property_changed_cb (GtkWidget *widget, GdkEventProperty *event, jobject peer); +static void menubar_resize_cb (GtkWidget *widget, GtkAllocation *alloc, + jobject peer); /* * Make a new window. @@ -358,45 +360,61 @@ Java_gnu_java_awt_peer_gtk_GtkWindowPeer_nativeSetBounds } JNIEXPORT void JNICALL -Java_gnu_java_awt_peer_gtk_GtkFramePeer_setMenuBarPeer +Java_gnu_java_awt_peer_gtk_GtkFramePeer_removeMenuBarPeer (JNIEnv *env, jobject obj, jobject menubar) { - void *wptr, *mptr; - GtkBox *box; + void *wptr; + GtkWidget *box; + GtkWidget *mptr; - if (!menubar) return; + wptr = NSA_GET_PTR (env, obj); + mptr = NSA_GET_PTR (env, menubar); + + gdk_threads_enter (); + box = GTK_BIN (wptr)->child; + gtk_container_remove (GTK_CONTAINER (box), GTK_WIDGET (mptr)); + + gdk_threads_leave(); +} + +JNIEXPORT void JNICALL +Java_gnu_java_awt_peer_gtk_GtkFramePeer_setMenuBarPeer + (JNIEnv *env, jobject obj, jobject menubar) +{ + void *wptr; + GtkWidget *mptr; + GtkWidget *box; + jobject *gref = NSA_GET_GLOBAL_REF (env, obj); + wptr = NSA_GET_PTR (env, obj); mptr = NSA_GET_PTR (env, menubar); + + gdk_threads_enter (); - if (!mptr) return; /* this case should remove a menu */ + g_signal_connect (G_OBJECT (mptr), "size-allocate", + G_CALLBACK (menubar_resize_cb), *gref); + box = GTK_BIN (wptr)->child; + gtk_box_pack_start (GTK_BOX (box), mptr, 0, 0, 0); + + gtk_widget_show (mptr); - gdk_threads_enter (); - box = GTK_BOX (GTK_BIN (wptr)->child); - gtk_box_pack_start (box, GTK_WIDGET (mptr), 0, 0, 0); + gdk_threads_leave (); } JNIEXPORT jint JNICALL Java_gnu_java_awt_peer_gtk_GtkFramePeer_getMenuBarHeight - (JNIEnv *env, jobject obj) + (JNIEnv *env, jobject obj, jobject menubar) { - void *ptr; - GList *children; - jint height = 0; - - ptr = NSA_GET_PTR (env, obj); + GtkWidget *ptr; + jint height; + + ptr = NSA_GET_PTR (env, menubar); gdk_threads_enter (); - children = gtk_container_children (GTK_CONTAINER (GTK_BIN (ptr)->child)); - if (g_list_length (children) == 2) - { - GtkWidget *menubar = GTK_WIDGET (children->data); - height = menubar->allocation.height; - - } + height = ptr->allocation.height; gdk_threads_leave (); - return height; } @@ -698,3 +716,25 @@ window_property_changed_cb (GtkWidget *widget __attribute__((unused)), return FALSE; } + +static void menubar_resize_cb (GtkWidget *widget, GtkAllocation *alloc, + jobject peer) +{ + static int id_set = 0; + static jmethodID postSizeAllocateEventID; + + if (!id_set) + { + jclass gtkframepeer = (*gdk_env)->FindClass (gdk_env, + "gnu/java/awt/peer/gtk/GtkFramePeer"); + postSizeAllocateEventID = (*gdk_env)->GetMethodID (gdk_env, + gtkframepeer, + "postSizeAllocateEvent", + "()V"); + id_set = 1; + } + gdk_threads_leave(); + (*gdk_env)->CallVoidMethod (gdk_env, peer, + postSizeAllocateEventID); + gdk_threads_enter(); +} |