diff options
-rw-r--r-- | src/tab-chrome.c | 24 | ||||
-rw-r--r-- | src/tab.c | 19 |
2 files changed, 18 insertions, 25 deletions
diff --git a/src/tab-chrome.c b/src/tab-chrome.c index 316c674..fda480f 100644 --- a/src/tab-chrome.c +++ b/src/tab-chrome.c @@ -480,21 +480,6 @@ update_tab_image(MqTabChrome *chrome) } static void -update_tab_label(MqTabChrome *chrome) -{ - gtk_label_set_text(GTK_LABEL(chrome->tab_label), - g_strdup_printf("%d. %s", chrome->tab_position + 1, - webkit_web_view_get_title(chrome->web_view))); -} - -void -mq_tab_chrome_update_tab_position(MqTabChrome *chrome, guint position) -{ - chrome->tab_position = position; - update_tab_label(chrome); -} - -static void load_changed_cb(WebKitWebView *web_view, WebKitLoadEvent load_event, MqTabChrome *chrome) { @@ -600,13 +585,6 @@ favicon_cb(WebKitWebView __attribute__((unused)) *web_view, } static void -title_cb(WebKitWebView __attribute__((unused)) *web_view, - GParamSpec __attribute__((unused)) *paramspec, MqTabChrome *chrome) -{ - update_tab_label(chrome); -} - -static void loading_cb(WebKitWebView *web_view, GParamSpec __attribute__((unused)) *paramspec, MqTabChrome *chrome) { @@ -648,8 +626,6 @@ connect_web_view(MqTabChrome *chrome) /* FIXME: Doesn't work? */ g_signal_connect(chrome->web_view, "notify::favicon", G_CALLBACK(favicon_cb), chrome); - g_signal_connect(chrome->web_view, "notify::title", - G_CALLBACK(title_cb), chrome); g_signal_connect(chrome->web_view, "notify::is-loading", G_CALLBACK(loading_cb), chrome); } @@ -27,6 +27,21 @@ #include "tab-chrome.h" #include "tab-body.h" +static void +update_tab_label(MqTab *tab) +{ + gtk_label_set_text(GTK_LABEL(tab->tab_label), + g_strdup_printf("%d. %s", tab->tab_position + 1, + webkit_web_view_get_title(tab->web_view))); +} + +static void +title_cb(WebKitWebView __attribute__((unused)) *web_view, + GParamSpec __attribute__((unused)) *paramspec, MqTab *tab) +{ + update_tab_label(tab); +} + MqTab * mq_tab_new(gchar *uri, GtkWidget *tab_image, GtkWidget *tab_label) { @@ -38,6 +53,8 @@ mq_tab_new(gchar *uri, GtkWidget *tab_image, GtkWidget *tab_label) tab->chrome = mq_tab_chrome_new(uri, tab_image, tab_label); tab->body = mq_tab_body_new(uri); tab->web_view = mq_tab_body_get_web_view(tab->body); + g_signal_connect(tab->web_view, "notify::title", G_CALLBACK(title_cb), + tab); mq_tab_chrome_set_web_view(tab->chrome, tab->web_view); tab->container = gtk_grid_new(); @@ -61,5 +78,5 @@ void mq_tab_update_position(MqTab *tab, guint position) { tab->tab_position = position; - mq_tab_chrome_update_tab_position(tab->chrome, position); + update_tab_label(tab); } |