X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f7204798e2b7db9e5ebd94c327ed0fef72b18862..b14ba1f11722aeb4e4dcd52a686f5a50335776a1:/src/gtk1/popupwin.cpp diff --git a/src/gtk1/popupwin.cpp b/src/gtk1/popupwin.cpp index 4e9908879b..9593f43a57 100644 --- a/src/gtk1/popupwin.cpp +++ b/src/gtk1/popupwin.cpp @@ -230,8 +230,8 @@ bool wxPopupWindow::Create( wxWindow *parent, int style ) gtk_signal_connect( GTK_OBJECT(m_widget), "focus", GTK_SIGNAL_FUNC(gtk_dialog_focus_callback), (gpointer)this ); - g_signal_connect (GTK_OBJECT(m_widget), "button_press_event", - G_CALLBACK(gtk_popup_button_press), (gpointer)this ); + gtk_signal_connect (GTK_OBJECT(m_widget), "button_press_event", + GTK_SIGNAL_FUNC(gtk_popup_button_press), (gpointer)this ); return TRUE; } @@ -327,30 +327,30 @@ void wxPopupWindow::GtkOnSize( int WXUNUSED(x), int WXUNUSED(y), int width, int m_width = width; m_height = height; + /* FIXME: is this a hack? */ + /* since for some reason GTK will revert to using maximum size ever set + for this window, we have to set geometry hints maxsize to match + size given. */ int minWidth = GetMinWidth(), - minHeight = GetMinHeight(), - maxWidth = GetMaxWidth(), - maxHeight = GetMaxHeight(); + minHeight = GetMinHeight(); if ((minWidth != -1) && (m_width < minWidth)) m_width = minWidth; if ((minHeight != -1) && (m_height < minHeight)) m_height = minHeight; - if ((maxWidth != -1) && (m_width > maxWidth)) m_width = maxWidth; - if ((maxHeight != -1) && (m_height > maxHeight)) m_height = maxHeight; /* set size hints */ - gint flag = 0; // GDK_HINT_POS; + gint flag = GDK_HINT_MAX_SIZE; // GDK_HINT_POS; if ((minWidth != -1) || (minHeight != -1)) flag |= GDK_HINT_MIN_SIZE; - if ((maxWidth != -1) || (maxHeight != -1)) flag |= GDK_HINT_MAX_SIZE; GdkGeometry geom; geom.min_width = minWidth; geom.min_height = minHeight; - geom.max_width = maxWidth; - geom.max_height = maxHeight; + geom.max_width = m_width; + geom.max_height = m_height; gtk_window_set_geometry_hints( GTK_WINDOW(m_widget), (GtkWidget*) NULL, &geom, (GdkWindowHints) flag ); + m_sizeSet = TRUE; wxSizeEvent event( wxSize(m_width,m_height), GetId() );