changeset 8506:887c0259b47b

[gaim-migrate @ 9242] " 6: Using CTRL+Up to get back a previous line breaks the formatting on any new text entered on that line. Text, while being entered appears extremely small, and when it's sent, the formatting is slightly smaller and may lose other elements of formatting. the problem was that in the key_press_cb in gtkconv.c was using gtk_text_buffer_get_text(gtkconv->entry_buffer, ...); this was not giving us the html tags. So I changed it to gtk_imthml_get_markup(GTK_IMHTML(gtkconv->entry)); Then I added a signal so that the toolbar gets update when gtk_imhtml_append_text_with_images is called so that the toolbar can be updated as well. I also rename the format_functions_update to format_buttons_update since it, to me atleast, makes more sense and because I couldn't think of a better name than format_function_update, which would have been very confusing. theres one issue that I was not able to fix in this. I'm planning on looking into it later, but after ctrl-up/down the closing tag gets added and ends at the last character from the buffer. Which means formatting returns to normal (ie plain text) if you type after you've used ctrl-up/down." --Gary Kramlich committer: Tailor Script <tailor@pidgin.im>
author Luke Schierer <lschiere@pidgin.im>
date Fri, 26 Mar 2004 14:14:16 +0000
parents 112f5762a41a
children e993ed303477
files src/gtkconv.c src/gtkimhtml.c src/gtkimhtml.h src/gtkimhtmltoolbar.c
diffstat 4 files changed, 46 insertions(+), 6 deletions(-) [+]
line wrap: on
line diff
--- a/src/gtkconv.c	Fri Mar 26 05:05:08 2004 +0000
+++ b/src/gtkconv.c	Fri Mar 26 14:14:16 2004 +0000
@@ -1274,10 +1274,9 @@
 					gtk_text_buffer_get_end_iter(gtkconv->entry_buffer, &end);
 
 					conv->send_history->data =
-						gtk_text_buffer_get_text(gtkconv->entry_buffer,
-												 &start, &end, FALSE);
+						gtk_imhtml_get_markup(GTK_IMHTML(gtkconv->entry));
 				}
-
+				
 				if (conv->send_history->next &&
 					conv->send_history->next->data) {
 
--- a/src/gtkimhtml.c	Fri Mar 26 05:05:08 2004 +0000
+++ b/src/gtkimhtml.c	Fri Mar 26 14:14:16 2004 +0000
@@ -90,6 +90,7 @@
 	BUTTONS_UPDATE,
 	TOGGLE_FORMAT,
 	CLEAR_FORMAT,
+	UPDATE_FORMAT,
 	LAST_SIGNAL
 };
 static guint signals [LAST_SIGNAL] = { 0 };
@@ -625,7 +626,7 @@
 						g_cclosure_marshal_VOID__POINTER,
 						G_TYPE_NONE, 1,
 						G_TYPE_POINTER);
-	signals[BUTTONS_UPDATE] = g_signal_new("format_functions_update",
+	signals[BUTTONS_UPDATE] = g_signal_new("format_buttons_update",
 					       G_TYPE_FROM_CLASS(gobject_class),
 					       G_SIGNAL_RUN_FIRST,
 					       G_STRUCT_OFFSET(GtkIMHtmlClass, buttons_update),
@@ -651,6 +652,14 @@
 					      0,
 						  g_cclosure_marshal_VOID__VOID,
 						  G_TYPE_NONE, 0);
+	signals[UPDATE_FORMAT] = g_signal_new("format_function_update",
+							G_TYPE_FROM_CLASS(gobject_class),
+							G_SIGNAL_RUN_FIRST,
+							G_STRUCT_OFFSET(GtkIMHtmlClass, update_format),
+							NULL,
+							0,
+							g_cclosure_marshal_VOID__VOID,
+							G_TYPE_NONE, 0);
 	gobject_class->finalize = gtk_imhtml_finalize;
 }
 
@@ -1415,6 +1424,7 @@
 		pre = 0;
 
 	GSList *fonts = NULL;
+	GObject *object;
 	GtkIMHtmlScalable *scalable = NULL;
 	int y, height;
 
@@ -2042,7 +2052,12 @@
 	g_free (ws);
 	if(bg)
 		g_free(bg);
-	gtk_imhtml_close_tags(imhtml);
+	/* this shouldn't be necessary if we want to be able to continue 
+	 * using the format if it was unclosed.  But seeing as removing this
+	 * line does not help the ctrl-up/down from enabling open tags, I'm
+	 * leaving it up to sean, or unless I find some time to look into it
+	 * more -Gary */
+	gtk_imhtml_close_tags(imhtml); 
 	if (!(options & GTK_IMHTML_NO_SCROLL))
 		gtk_text_view_scroll_to_mark (GTK_TEXT_VIEW (imhtml), mark,
 					      0, TRUE, 0.0, 1.0);
@@ -2050,6 +2065,11 @@
 	gtk_text_buffer_move_mark (imhtml->text_buffer,
 				   gtk_text_buffer_get_mark (imhtml->text_buffer, "insert"),
 				   &iter);
+
+	object = g_object_ref(G_OBJECT(imhtml));
+	g_signal_emit(object, signals[UPDATE_FORMAT], 0);
+	g_object_unref(object);
+
 	return str;
 }
 
--- a/src/gtkimhtml.h	Fri Mar 26 05:05:08 2004 +0000
+++ b/src/gtkimhtml.h	Fri Mar 26 14:14:16 2004 +0000
@@ -123,6 +123,7 @@
 	void (*buttons_update)(GtkIMHtml *, GtkIMHtmlButtons);
 	void (*toggle_format)(GtkIMHtml *, GtkIMHtmlButtons);
 	void (*clear_format)(GtkIMHtml *);
+	void (*update_format)(GtkIMHtml *);
 };
 
 struct _GtkIMHtmlFontDetail {
--- a/src/gtkimhtmltoolbar.c	Fri Mar 26 05:05:08 2004 +0000
+++ b/src/gtkimhtmltoolbar.c	Fri Mar 26 14:14:16 2004 +0000
@@ -701,6 +701,25 @@
 		toggle_button_set_active_block(GTK_TOGGLE_BUTTON(toolbar->underline),
 									   FALSE, toolbar);
 }
+static void update_format_cb(GtkIMHtml *imhtml, GtkIMHtmlToolbar *toolbar)
+{
+	gboolean bold, italic, underline;
+	
+	bold = italic = underline = FALSE;
+	gtk_imhtml_get_current_format(imhtml, -1, &bold, &italic, &underline);
+
+	if(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(toolbar->bold)) != bold)
+		toggle_button_set_active_block(GTK_TOGGLE_BUTTON(toolbar->bold), bold,
+									   toolbar);
+	
+	if(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(toolbar->italic)) != italic)
+		toggle_button_set_active_block(GTK_TOGGLE_BUTTON(toolbar->italic), italic,
+									   toolbar);
+	
+	if(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(toolbar->underline)) != underline)
+		toggle_button_set_active_block(GTK_TOGGLE_BUTTON(toolbar->underline),
+									   underline, toolbar);	
+}
 
 static void cursor_moved_cb(GtkIMHtml *imhtml, GtkMovementStep step,
 							gint change, gboolean selected,
@@ -979,9 +998,10 @@
 	g_return_if_fail(GTK_IS_IMHTML(imhtml));
 
 	toolbar->imhtml = imhtml;
-	g_signal_connect(G_OBJECT(imhtml), "format_functions_update", G_CALLBACK(update_buttons_cb), toolbar);
+	g_signal_connect(G_OBJECT(imhtml), "format_buttons_update", G_CALLBACK(update_buttons_cb), toolbar);
 	g_signal_connect(G_OBJECT(imhtml), "format_function_toggle", G_CALLBACK(toggle_button_cb), toolbar);
 	g_signal_connect(G_OBJECT(imhtml), "format_function_clear", G_CALLBACK(reset_buttons_cb), toolbar);
+	g_signal_connect(G_OBJECT(imhtml), "format_function_update", G_CALLBACK(update_format_cb), toolbar);
 	g_signal_connect_after(G_OBJECT(imhtml), "move_cursor", G_CALLBACK(cursor_moved_cb), toolbar);
 
 	bold = italic = underline = FALSE;