summaryrefslogtreecommitdiffstats
path: root/webkit/tools
diff options
context:
space:
mode:
authorevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-04 20:46:59 +0000
committerevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-04 20:46:59 +0000
commit0d89635f0c83a050662d1d60cb88fe3255a20985 (patch)
tree2c116b5b03093f7fcfbdbdc65ce463fb12471998 /webkit/tools
parent2815fd215021595d12782cd15bb69d7d03c39618 (diff)
downloadchromium_src-0d89635f0c83a050662d1d60cb88fe3255a20985.zip
chromium_src-0d89635f0c83a050662d1d60cb88fe3255a20985.tar.gz
chromium_src-0d89635f0c83a050662d1d60cb88fe3255a20985.tar.bz2
linux: SizeTo() must synchronously size the content area.
The old code was wrong and racy and the new message loop really exposed the bug. Review URL: http://codereview.chromium.org/119197 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@17663 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/tools')
-rw-r--r--webkit/tools/test_shell/test_shell.h5
-rw-r--r--webkit/tools/test_shell/test_shell_gtk.cc45
2 files changed, 38 insertions, 12 deletions
diff --git a/webkit/tools/test_shell/test_shell.h b/webkit/tools/test_shell/test_shell.h
index d6ac049..1de2a9f 100644
--- a/webkit/tools/test_shell/test_shell.h
+++ b/webkit/tools/test_shell/test_shell.h
@@ -344,11 +344,6 @@ private:
// Dump the stats table counters on exit.
bool dump_stats_table_on_exit_;
-
-#if defined(OS_LINUX)
- // The height of the non-rendering area of the main window, in pixels.
- int top_chrome_height_;
-#endif
};
#endif // WEBKIT_TOOLS_TEST_SHELL_TEST_SHELL_H_
diff --git a/webkit/tools/test_shell/test_shell_gtk.cc b/webkit/tools/test_shell/test_shell_gtk.cc
index 6971a57..8543664 100644
--- a/webkit/tools/test_shell/test_shell_gtk.cc
+++ b/webkit/tools/test_shell/test_shell_gtk.cc
@@ -314,7 +314,6 @@ GtkWidget* CreateMenuBar(TestShell* shell) {
bool TestShell::Initialize(const std::wstring& startingURL) {
m_mainWnd = GTK_WINDOW(gtk_window_new(GTK_WINDOW_TOPLEVEL));
gtk_window_set_title(m_mainWnd, "Test Shell");
- gtk_window_set_default_size(m_mainWnd, 640, 480);
g_signal_connect(G_OBJECT(m_mainWnd), "destroy",
G_CALLBACK(MainWindowDestroyed), this);
g_signal_connect(G_OBJECT(m_mainWnd), "focus-out-event",
@@ -370,11 +369,9 @@ bool TestShell::Initialize(const std::wstring& startingURL) {
gtk_container_add(GTK_CONTAINER(m_mainWnd), vbox);
gtk_widget_show_all(GTK_WIDGET(m_mainWnd));
- top_chrome_height_ = toolbar->allocation.height +
- menu_bar->allocation.height + 2 * gtk_box_get_spacing(GTK_BOX(vbox));
- // LoadURL will do a resize (which uses top_chrome_height_), so make
- // sure we don't call LoadURL until we've completed all of our GTK setup.
+ // LoadURL will do a resize, so make sure we don't call LoadURL
+ // until we've completed all of our GTK setup.
if (!startingURL.empty())
LoadURL(startingURL.c_str());
@@ -399,9 +396,43 @@ void TestShell::TestFinished() {
MessageLoop::current()->Quit();
}
+// Quit the current message loop. Used as a callback below.
+static void QuitMessageLoop() {
+ MessageLoop::current()->Quit();
+}
+
void TestShell::SizeTo(int width, int height) {
- gtk_window_resize(GTK_WINDOW(m_mainWnd), width,
- height + top_chrome_height_);
+ // We've been asked to size the content area to a particular size.
+ // GTK works asynchronously: you request a size and then it eventually
+ // becomes that size. But for this request we need to be sure the resize
+ // has completed by the time SizeTo() returns.
+ //
+ // The fix is to attach to the actual sizing event, resize the widget,
+ // then block the message loop until that event comes through.
+
+ GtkWidget* widget = m_webViewHost->view_handle();
+ if (widget->allocation.width == width &&
+ widget->allocation.height == height) {
+ // Nothing to do.
+ return;
+ }
+
+ gulong handler =
+ g_signal_connect(G_OBJECT(widget), "size-allocate",
+ G_CALLBACK(QuitMessageLoop), NULL);
+ gtk_widget_set_size_request(m_webViewHost->view_handle(), width, height);
+
+ if (widget->allocation.width > width ||
+ widget->allocation.height > height) {
+ // We've been sized smaller. Shrink the window so it snaps back to the
+ // appropriate size.
+ gtk_window_resize(GTK_WINDOW(m_mainWnd), 1, 1);
+ }
+
+ MessageLoop::current()->Run();
+
+ // Clean up our handler.
+ g_signal_handler_disconnect(G_OBJECT(m_webViewHost->view_handle()), handler);
}
static void AlarmHandler(int signatl) {