[pan2/testing: 8/279] Add wrap selected to post editor.
- From: Heinrich MÃller <henmull src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [pan2/testing: 8/279] Add wrap selected to post editor.
- Date: Sat, 3 Dec 2011 22:26:13 +0000 (UTC)
commit 7941fef08db80a1eb24eb812a8fd2b3993ee338b
Author: K. Haley <haleykd users sf net>
Date: Thu Aug 5 17:31:48 2010 -0600
Add wrap selected to post editor.
When creating a reply the wrap mode now determines if the original
message is wrapped before being placed into the edit window. Also
a new edit entry has been added, 'Wrap selected', which uses pans
wrapping method on the selected text so it also works on quoted
text.
pan/gui/post-ui.cc | 31 +++++++++++++++++++++++++------
pan/gui/post-ui.h | 1 +
pan/gui/post.ui.h | 1 +
3 files changed, 27 insertions(+), 6 deletions(-)
---
diff --git a/pan/gui/post-ui.cc b/pan/gui/post-ui.cc
index 2b3940f..2428280 100644
--- a/pan/gui/post-ui.cc
+++ b/pan/gui/post-ui.cc
@@ -197,6 +197,7 @@ namespace
void do_close (GtkAction*, gpointer p) { static_cast<PostUI*>(p)->close_window (); }
void do_wrap (GtkToggleAction * w, gpointer p) { static_cast<PostUI*>(p)->set_wrap_mode (gtk_toggle_action_get_active (w)); }
void do_edit2 (GtkToggleAction * w, gpointer p) { static_cast<PostUI*>(p)->set_always_run_editor (gtk_toggle_action_get_active (w)); }
+ void do_wrap_selected(GtkAction*, gpointer p) { static_cast<PostUI*>(p)->wrap_selection(); }
GtkActionEntry entries[] =
{
@@ -215,7 +216,8 @@ namespace
{ "paste", GTK_STOCK_PASTE, 0, 0, 0, G_CALLBACK(do_paste) },
{ "rot13", GTK_STOCK_REFRESH, N_("_Rot13"), 0, N_("Rot13 Selected Text"), G_CALLBACK(do_rot13) },
{ "run-editor", GTK_STOCK_JUMP_TO, N_("Run _Editor"), "<control>e", N_("Run Editor"), G_CALLBACK(do_edit) },
- { "manage-profiles", GTK_STOCK_EDIT, N_("Edit P_osting Profiles"), 0, 0, G_CALLBACK(do_profiles) }
+ { "manage-profiles", GTK_STOCK_EDIT, N_("Edit P_osting Profiles"), 0, 0, G_CALLBACK(do_profiles) },
+ { "wrapselected", 0, N_("Wrap Selected"), 0, 0, G_CALLBACK(do_wrap_selected) }
};
GtkToggleActionEntry toggle_entries[] =
@@ -319,6 +321,21 @@ PostUI :: rot13_selection ()
}
}
+void
+PostUI :: wrap_selection ()
+{
+ GtkTextIter start, end;
+ if (gtk_text_buffer_get_selection_bounds (_body_buf, &start, &end))
+ {
+ char * str (gtk_text_buffer_get_text (_body_buf, &start, &end, false));
+ std::string s(str);
+ s = _tm.fill(s);
+ gtk_text_buffer_delete (_body_buf, &start, &end);
+ gtk_text_buffer_insert (_body_buf, &start, s.c_str(), s.length() );
+ g_free (str);
+ }
+}
+
namespace
{
gboolean delete_event_cb (GtkWidget*, GdkEvent*, gpointer user_data)
@@ -1565,7 +1582,7 @@ PostUI :: set_message (GMimeMessage * message)
SetMessageForeachHeaderData data;
const char *name, *value;
GMimeHeaderIter iter;
-
+
if (message->mime_part && g_mime_header_list_get_stream (message->mime_part->headers)) {
if (g_mime_header_list_get_iter (message->mime_part->headers, &iter)) {
do {
@@ -1575,7 +1592,7 @@ PostUI :: set_message (GMimeMessage * message)
} while (g_mime_header_iter_next (&iter));
}
}
-
+
if (g_mime_header_list_get_iter (GMIME_OBJECT (message)->headers, &iter)) {
do {
value = g_mime_header_iter_get_value (&iter);
@@ -1583,7 +1600,7 @@ PostUI :: set_message (GMimeMessage * message)
set_message_foreach_header_func (name, value, &data);
} while (g_mime_header_iter_next (&iter));
}
-
+
s = utf8ize (data.visible_headers);
gtk_text_buffer_set_text (_headers_buf, s.c_str(), -1);
_hidden_headers = data.hidden_headers;
@@ -1594,8 +1611,10 @@ PostUI :: set_message (GMimeMessage * message)
s = utf8ize (tmp);
g_free (tmp);
if (!s.empty()) {
- s = TextMassager().fill (s);
- s += "\n\n";
+ if (_prefs.get_flag ("compose-wrap-enabled", true)) {
+ s = TextMassager().fill (s);
+ s += "\n\n";
+ }
gtk_text_buffer_set_text (_body_buf, s.c_str(), s.size());
}
diff --git a/pan/gui/post-ui.h b/pan/gui/post-ui.h
index f879d14..29d1f7b 100644
--- a/pan/gui/post-ui.h
+++ b/pan/gui/post-ui.h
@@ -51,6 +51,7 @@ namespace pan
public:
GtkWidget * root() { return _root; }
void rot13_selection ();
+ void wrap_selection ();
void wrap_body ();
void spawn_editor ();
void manage_profiles ();
diff --git a/pan/gui/post.ui.h b/pan/gui/post.ui.h
index 95a76d1..055b296 100644
--- a/pan/gui/post.ui.h
+++ b/pan/gui/post.ui.h
@@ -22,6 +22,7 @@ const char * fallback_post_ui =
" <menuitem action='always-run-editor' />\n"
" <separator />\n"
" <menuitem action='wrap' />\n"
+" <menuitem action='wrapselected' />\n"
" <menuitem action='spellcheck' />\n"
" <separator />\n"
" <menuitem action='manage-profiles' />\n"
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]