Add toggle comment and toggle comment block actions w/ keybindings (#290)
This commit is contained in:
parent
992ca7a3ec
commit
4044529191
|
@ -11,3 +11,14 @@
|
|||
min-height: 0;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
/*remove a keybinding so that we can use it for toggling comments*/
|
||||
@binding-set xed-view-bindings
|
||||
{
|
||||
unbind "<Control>slash";
|
||||
}
|
||||
|
||||
textview
|
||||
{
|
||||
-gtk-key-bindings: xed-view-bindings;
|
||||
}
|
||||
|
|
|
@ -327,6 +327,20 @@
|
|||
<property name="title" translatable="yes">Decrement number at cursor</property>
|
||||
</object>
|
||||
</child>
|
||||
<child>
|
||||
<object class="GtkShortcutsShortcut">
|
||||
<property name="visible">1</property>
|
||||
<property name="accelerator"><ctrl><shift>slash</property>
|
||||
<property name="title" translatable="yes">Toggle comment block</property>
|
||||
</object>
|
||||
</child>
|
||||
<child>
|
||||
<object class="GtkShortcutsShortcut">
|
||||
<property name="visible">1</property>
|
||||
<property name="accelerator"><ctrl>slash</property>
|
||||
<property name="title" translatable="yes">Toggle comment</property>
|
||||
</object>
|
||||
</child>
|
||||
</object>
|
||||
</child>
|
||||
</object>
|
||||
|
|
|
@ -38,6 +38,9 @@
|
|||
<menuitem name="EditSelectAllMenu" action="EditSelectAll"/>
|
||||
<placeholder name="EditOps_3" />
|
||||
<separator/>
|
||||
<menuitem name="EditToggleCommentMenu" action="EditToggleComment"/>
|
||||
<menuitem name="EditToggleCommentBlockMenu" action="EditToggleCommentBlock"/>
|
||||
<separator/>
|
||||
<placeholder name="EditOps_4" />
|
||||
<separator/>
|
||||
<placeholder name="EditOps_5" />
|
||||
|
|
|
@ -169,3 +169,156 @@ _xed_cmd_edit_preferences (GtkAction *action,
|
|||
|
||||
xed_show_preferences_dialog (window);
|
||||
}
|
||||
|
||||
void
|
||||
_xed_cmd_edit_toggle_comment (GtkAction *action,
|
||||
XedWindow *window)
|
||||
{
|
||||
XedView *active_view;
|
||||
GtkSourceBuffer *active_document;
|
||||
GtkSourceLanguage *language;
|
||||
const gchar *comment_text;
|
||||
gint start_line;
|
||||
gint end_line;
|
||||
gint i;
|
||||
gboolean is_comment = FALSE;
|
||||
GtkTextIter start_iter;
|
||||
GtkTextIter end_iter;
|
||||
|
||||
xed_debug (DEBUG_COMMANDS);
|
||||
|
||||
active_view = xed_window_get_active_view (window);
|
||||
|
||||
if (active_view == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
active_document = GTK_SOURCE_BUFFER (gtk_text_view_get_buffer (GTK_TEXT_VIEW (active_view)));
|
||||
language = gtk_source_buffer_get_language (active_document);
|
||||
|
||||
if (language == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
comment_text = gtk_source_language_get_metadata (language, "line-comment-start");
|
||||
|
||||
if (comment_text == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
gtk_text_buffer_get_selection_bounds (GTK_TEXT_BUFFER (active_document), &start_iter, &end_iter);
|
||||
start_line = gtk_text_iter_get_line (&start_iter);
|
||||
end_line = gtk_text_iter_get_line (&end_iter);
|
||||
|
||||
gtk_text_buffer_begin_user_action (GTK_TEXT_BUFFER (active_document)); // begin
|
||||
|
||||
// if some lines are already commented, consider the whole block commented and uncomment them
|
||||
for (i = start_line; i <= end_line; i++)
|
||||
{
|
||||
GtkTextIter start_line_iter;
|
||||
GtkTextIter end_line_iter;
|
||||
const gchar *line_text;
|
||||
|
||||
gtk_text_buffer_get_iter_at_line (GTK_TEXT_BUFFER (active_document), &start_line_iter, i);
|
||||
end_line_iter = start_line_iter;
|
||||
gtk_text_iter_forward_to_line_end (&end_line_iter);
|
||||
|
||||
line_text = gtk_text_buffer_get_slice (GTK_TEXT_BUFFER (active_document), &start_line_iter, &end_line_iter, TRUE);
|
||||
if (g_str_has_prefix (line_text, comment_text))
|
||||
{
|
||||
is_comment = TRUE;
|
||||
end_line_iter = start_line_iter;
|
||||
gtk_text_iter_forward_chars (&end_line_iter, strlen(comment_text));
|
||||
gtk_text_buffer_delete (GTK_TEXT_BUFFER (active_document), &start_line_iter, &end_line_iter);
|
||||
}
|
||||
}
|
||||
|
||||
// only comment if nothing was commented to begin with
|
||||
if (!is_comment)
|
||||
{
|
||||
for (i = start_line; i <= end_line; i++)
|
||||
{
|
||||
GtkTextIter insert_iter;
|
||||
|
||||
gtk_text_buffer_get_iter_at_line (GTK_TEXT_BUFFER (active_document), &insert_iter, i);
|
||||
gtk_text_buffer_insert (GTK_TEXT_BUFFER (active_document), &insert_iter, comment_text, -1);
|
||||
}
|
||||
}
|
||||
|
||||
gtk_text_buffer_end_user_action (GTK_TEXT_BUFFER (active_document)); // end
|
||||
}
|
||||
|
||||
void
|
||||
_xed_cmd_edit_toggle_comment_block (GtkAction *action,
|
||||
XedWindow *window)
|
||||
{
|
||||
XedView *active_view;
|
||||
GtkSourceBuffer *active_document;
|
||||
GtkSourceLanguage *language;
|
||||
const gchar *start_text;
|
||||
const gchar *end_text;
|
||||
GtkTextIter start_iter;
|
||||
GtkTextIter end_iter;
|
||||
gchar *selected_text;
|
||||
gchar *insert_text;
|
||||
|
||||
xed_debug (DEBUG_COMMANDS);
|
||||
|
||||
active_view = xed_window_get_active_view (window);
|
||||
|
||||
if (active_view == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
active_document = GTK_SOURCE_BUFFER (gtk_text_view_get_buffer (GTK_TEXT_VIEW (active_view)));
|
||||
language = gtk_source_buffer_get_language (active_document);
|
||||
|
||||
if (language == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
start_text = gtk_source_language_get_metadata (language, "block-comment-start");
|
||||
end_text = gtk_source_language_get_metadata (language, "block-comment-end");
|
||||
|
||||
if (start_text == NULL || end_text == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
gtk_text_buffer_get_selection_bounds (GTK_TEXT_BUFFER (active_document), &start_iter, &end_iter);
|
||||
|
||||
selected_text = gtk_text_buffer_get_slice (GTK_TEXT_BUFFER (active_document), &start_iter, &end_iter, TRUE);
|
||||
|
||||
if (g_str_has_prefix (selected_text, start_text) && g_str_has_suffix (selected_text, end_text))
|
||||
{
|
||||
gint start = strlen (start_text);
|
||||
gint end = strlen (end_text);
|
||||
const gchar *tmp = selected_text + start;
|
||||
insert_text = g_strndup (tmp , strlen(selected_text) - start - end);
|
||||
}
|
||||
else
|
||||
{
|
||||
insert_text = g_strconcat (start_text, selected_text, end_text, NULL);
|
||||
}
|
||||
|
||||
gtk_text_buffer_begin_user_action (GTK_TEXT_BUFFER (active_document)); // begin
|
||||
|
||||
// replace the selected text with the commented/uncommented version
|
||||
gtk_text_buffer_delete (GTK_TEXT_BUFFER (active_document), &start_iter, &end_iter);
|
||||
gtk_text_buffer_insert (GTK_TEXT_BUFFER (active_document), &end_iter, insert_text, -1);
|
||||
|
||||
// move selection back where it was
|
||||
gtk_text_buffer_get_iter_at_offset (GTK_TEXT_BUFFER (active_document), &start_iter,
|
||||
gtk_text_iter_get_offset (&end_iter) - strlen (insert_text));
|
||||
gtk_text_buffer_select_range (GTK_TEXT_BUFFER (active_document), &start_iter, &end_iter);
|
||||
|
||||
gtk_text_buffer_end_user_action (GTK_TEXT_BUFFER (active_document)); // end
|
||||
|
||||
g_free (selected_text);
|
||||
g_free (insert_text);
|
||||
}
|
||||
|
|
|
@ -42,6 +42,8 @@ void _xed_cmd_edit_paste (GtkAction *action, XedWindow *window);
|
|||
void _xed_cmd_edit_delete (GtkAction *action, XedWindow *window);
|
||||
void _xed_cmd_edit_select_all (GtkAction *action, XedWindow *window);
|
||||
void _xed_cmd_edit_preferences (GtkAction *action, XedWindow *window);
|
||||
void _xed_cmd_edit_toggle_comment (GtkAction *action, XedWindow *window);
|
||||
void _xed_cmd_edit_toggle_comment_block (GtkAction *action, XedWindow *window);
|
||||
|
||||
void _xed_cmd_view_show_toolbar (GtkAction *action, XedWindow *window);
|
||||
void _xed_cmd_view_show_statusbar (GtkAction *action, XedWindow *window);
|
||||
|
|
|
@ -102,6 +102,10 @@ static const GtkActionEntry xed_menu_entries[] =
|
|||
N_("Delete the selected text"), G_CALLBACK (_xed_cmd_edit_delete) },
|
||||
{ "EditSelectAll", "edit-select-all-symbolic", N_("Select _All"), "<control>A",
|
||||
N_("Select the entire document"), G_CALLBACK (_xed_cmd_edit_select_all) },
|
||||
{ "EditToggleComment", NULL, N_("_Toggle Comment"), "<control>slash",
|
||||
N_("Comment"), G_CALLBACK (_xed_cmd_edit_toggle_comment) },
|
||||
{ "EditToggleCommentBlock", NULL, N_("Toggle Comment _Block"), "<shift><control>question",
|
||||
N_("Comment Block"), G_CALLBACK (_xed_cmd_edit_toggle_comment_block) },
|
||||
|
||||
/* View menu */
|
||||
{ "ViewHighlightMode", NULL, N_("_Highlight Mode"), "<shift><control>H",
|
||||
|
|
Loading…
Reference in New Issue