--- a/pidgin/gtkwebview.c Tue Jun 05 06:17:48 2012 +0000
+++ b/pidgin/gtkwebview.c Tue Jun 05 07:14:40 2012 +0000
@@ -303,6 +303,14 @@
+emit_format_signal(GtkWebView *webview, GtkWebViewButtons buttons) + g_signal_emit(webview, signals[TOGGLE_FORMAT], 0, buttons); + g_object_unref(webview); do_formatting(GtkWebView *webview, const char *name, const char *value)
GtkWebViewPriv *priv = GTK_WEBVIEW_GET_PRIVATE(webview);
@@ -332,6 +340,34 @@
+webview_font_shrink(GtkWebView *webview) + fontsize = gtk_webview_get_current_fontsize(webview); + fontsize = MAX(fontsize - 1, 1); + tmp = g_strdup_printf("%d", fontsize); + do_formatting(webview, "fontSize", tmp); +webview_font_grow(GtkWebView *webview) + fontsize = gtk_webview_get_current_fontsize(webview); + fontsize = MIN(fontsize + 1, MAX_FONT_SIZE); + tmp = g_strdup_printf("%d", fontsize); + do_formatting(webview, "fontSize", tmp); webview_clear_formatting(GtkWebView *webview)
if (!webkit_web_view_get_editable(WEBKIT_WEB_VIEW(webview)))
@@ -349,22 +385,22 @@
- gtk_webview_toggle_bold(webview);
+ do_formatting(webview, "bold", ""); - gtk_webview_toggle_italic(webview);
+ do_formatting(webview, "italic", ""); case GTK_WEBVIEW_UNDERLINE:
- gtk_webview_toggle_underline(webview);
+ do_formatting(webview, "underline", ""); - gtk_webview_toggle_strike(webview);
+ do_formatting(webview, "strikethrough", ""); - gtk_webview_font_shrink(webview);
+ webview_font_shrink(webview); - gtk_webview_font_grow(webview);
+ webview_font_grow(webview); @@ -933,40 +969,40 @@
object = g_object_ref(G_OBJECT(webview));
g_signal_emit(object, signals[CLEAR_FORMAT], 0);
+ g_object_unref(object); gtk_widget_grab_focus(GTK_WIDGET(webview));
- g_object_unref(object);
gtk_webview_toggle_bold(GtkWebView *webview)
- do_formatting(webview, "bold", "");
+ emit_format_signal(webview, GTK_WEBVIEW_BOLD); gtk_webview_toggle_italic(GtkWebView *webview)
- do_formatting(webview, "italic", "");
+ emit_format_signal(webview, GTK_WEBVIEW_ITALIC); gtk_webview_toggle_underline(GtkWebView *webview)
- do_formatting(webview, "underline", "");
+ emit_format_signal(webview, GTK_WEBVIEW_UNDERLINE); gtk_webview_toggle_strike(GtkWebView *webview)
- do_formatting(webview, "strikethrough", "");
+ emit_format_signal(webview, GTK_WEBVIEW_STRIKE); gtk_webview_toggle_forecolor(GtkWebView *webview, const char *color)
do_formatting(webview, "foreColor", color);
+ emit_format_signal(webview, GTK_WEBVIEW_FORECOLOR); @@ -975,6 +1011,7 @@
gtk_webview_toggle_backcolor(GtkWebView *webview, const char *color)
do_formatting(webview, "backColor", color);
+ emit_format_signal(webview, GTK_WEBVIEW_BACKCOLOR); @@ -983,6 +1020,7 @@
gtk_webview_toggle_fontface(GtkWebView *webview, const char *face)
do_formatting(webview, "fontName", face);
+ emit_format_signal(webview, GTK_WEBVIEW_FACE); @@ -992,35 +1030,20 @@
char *tmp = g_strdup_printf("%d", size);
do_formatting(webview, "fontSize", tmp);
+ emit_format_signal(webview, GTK_WEBVIEW_SHRINK|GTK_WEBVIEW_GROW); gtk_webview_font_shrink(GtkWebView *webview)
- fontsize = gtk_webview_get_current_fontsize(webview);
- fontsize = MAX(fontsize - 1, 1);
- tmp = g_strdup_printf("%d", fontsize);
- do_formatting(webview, "fontSize", tmp);
+ emit_format_signal(webview, GTK_WEBVIEW_SHRINK); gtk_webview_font_grow(GtkWebView *webview)
- fontsize = gtk_webview_get_current_fontsize(webview);
- fontsize = MIN(fontsize + 1, MAX_FONT_SIZE);
- tmp = g_strdup_printf("%d", fontsize);
- do_formatting(webview, "fontSize", tmp);
+ emit_format_signal(webview, GTK_WEBVIEW_GROW);