Blame SOURCES/0001-Resolves-tdf-96285-restore-bodge-for-unresizable-win.patch

a9add1
From b7c0576a8e8f39171b94d08fddea868da0459597 Mon Sep 17 00:00:00 2001
a9add1
From: =?UTF-8?q?Caol=C3=A1n=20McNamara?= <caolanm@redhat.com>
a9add1
Date: Tue, 8 Dec 2015 13:09:34 +0000
a9add1
Subject: [PATCH] Resolves: tdf#96285 restore bodge for unresizable windows
a9add1
 with no min size set
a9add1
a9add1
(cherry picked from commit e1df21cfe0318bf287ae8ce29261d4759c49bd5a)
a9add1
a9add1
Change-Id: Ia1af11514f6096ac55d561f729bbcba9ee5b0b14
a9add1
---
a9add1
 vcl/inc/unx/gtk/gtkframe.hxx  |  2 ++
a9add1
 vcl/unx/gtk3/gtk3gtkframe.cxx | 21 ++++++++++++++++++++-
a9add1
 2 files changed, 22 insertions(+), 1 deletion(-)
a9add1
a9add1
diff --git a/vcl/inc/unx/gtk/gtkframe.hxx b/vcl/inc/unx/gtk/gtkframe.hxx
a9add1
index 0fb5da7..3bd5353 100644
a9add1
--- a/vcl/inc/unx/gtk/gtkframe.hxx
a9add1
+++ b/vcl/inc/unx/gtk/gtkframe.hxx
a9add1
@@ -212,6 +212,8 @@ class GtkSalFrame : public SalFrame, public X11WindowProvider
a9add1
 
a9add1
 #if GTK_CHECK_VERSION(3,0,0)
a9add1
     guint32                         m_nLastScrollEventTime;
a9add1
+    long                            m_nWidthRequest;
a9add1
+    long                            m_nHeightRequest;
a9add1
     cairo_region_t*                 m_pRegion;
a9add1
 #else
a9add1
     GdkRegion*                      m_pRegion;
a9add1
diff --git a/vcl/unx/gtk3/gtk3gtkframe.cxx b/vcl/unx/gtk3/gtk3gtkframe.cxx
a9add1
index dcfebbf..1443054 100644
a9add1
--- a/vcl/unx/gtk3/gtk3gtkframe.cxx
a9add1
+++ b/vcl/unx/gtk3/gtk3gtkframe.cxx
a9add1
@@ -885,6 +885,8 @@ void GtkSalFrame::widget_set_size_request(long nWidth, long nHeight)
a9add1
 
a9add1
 void GtkSalFrame::window_resize(long nWidth, long nHeight)
a9add1
 {
a9add1
+    m_nWidthRequest = nWidth;
a9add1
+    m_nHeightRequest = nHeight;
a9add1
     gtk_window_resize(GTK_WINDOW(m_pWindow), nWidth, nHeight);
a9add1
 }
a9add1
 
a9add1
@@ -1055,6 +1057,9 @@ void GtkSalFrame::InitCommon()
a9add1
     m_aSystemData.pAppContext   = NULL;
a9add1
     m_aSystemData.pShellWidget  = m_aSystemData.pWidget;
a9add1
 
a9add1
+    m_nWidthRequest = 0;
a9add1
+    m_nHeightRequest = 0;
a9add1
+
a9add1
     // fake an initial geometry, gets updated via configure event or SetPosSize
a9add1
     if( m_bDefaultPos || m_bDefaultSize )
a9add1
     {
a9add1
@@ -1592,6 +1597,20 @@ void GtkSalFrame::setMinMaxSize()
a9add1
                 aHints |= GDK_HINT_MAX_SIZE;
a9add1
             }
a9add1
         }
a9add1
+        else
a9add1
+        {
a9add1
+            if (!m_bFullscreen && m_nWidthRequest && m_nHeightRequest)
a9add1
+            {
a9add1
+                aGeo.min_width = m_nWidthRequest;
a9add1
+                aGeo.min_height = m_nHeightRequest;
a9add1
+                aHints |= GDK_HINT_MIN_SIZE;
a9add1
+
a9add1
+                aGeo.max_width = m_nWidthRequest;
a9add1
+                aGeo.max_height = m_nHeightRequest;
a9add1
+                aHints |= GDK_HINT_MAX_SIZE;
a9add1
+            }
a9add1
+        }
a9add1
+
a9add1
         if( m_bFullscreen && m_aMaxSize.Width() && m_aMaxSize.Height() )
a9add1
         {
a9add1
             aGeo.max_width = m_aMaxSize.Width();
a9add1
@@ -1623,7 +1642,7 @@ void GtkSalFrame::SetMinClientSize( long nWidth, long nHeight )
a9add1
         m_aMinSize = Size( nWidth, nHeight );
a9add1
         if( m_pWindow )
a9add1
         {
a9add1
-            widget_set_size_request(nWidth, nHeight );
a9add1
+            widget_set_size_request(nWidth, nHeight);
a9add1
             setMinMaxSize();
a9add1
         }
a9add1
     }
a9add1
-- 
a9add1
2.5.0
a9add1