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-height: 0;
|
||||||
min-width: 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>
|
<property name="title" translatable="yes">Decrement number at cursor</property>
|
||||||
</object>
|
</object>
|
||||||
</child>
|
</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>
|
</object>
|
||||||
</child>
|
</child>
|
||||||
</object>
|
</object>
|
||||||
|
|
|
@ -38,6 +38,9 @@
|
||||||
<menuitem name="EditSelectAllMenu" action="EditSelectAll"/>
|
<menuitem name="EditSelectAllMenu" action="EditSelectAll"/>
|
||||||
<placeholder name="EditOps_3" />
|
<placeholder name="EditOps_3" />
|
||||||
<separator/>
|
<separator/>
|
||||||
|
<menuitem name="EditToggleCommentMenu" action="EditToggleComment"/>
|
||||||
|
<menuitem name="EditToggleCommentBlockMenu" action="EditToggleCommentBlock"/>
|
||||||
|
<separator/>
|
||||||
<placeholder name="EditOps_4" />
|
<placeholder name="EditOps_4" />
|
||||||
<separator/>
|
<separator/>
|
||||||
<placeholder name="EditOps_5" />
|
<placeholder name="EditOps_5" />
|
||||||
|
|
|
@ -169,3 +169,156 @@ _xed_cmd_edit_preferences (GtkAction *action,
|
||||||
|
|
||||||
xed_show_preferences_dialog (window);
|
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_delete (GtkAction *action, XedWindow *window);
|
||||||
void _xed_cmd_edit_select_all (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_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_toolbar (GtkAction *action, XedWindow *window);
|
||||||
void _xed_cmd_view_show_statusbar (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) },
|
N_("Delete the selected text"), G_CALLBACK (_xed_cmd_edit_delete) },
|
||||||
{ "EditSelectAll", "edit-select-all-symbolic", N_("Select _All"), "<control>A",
|
{ "EditSelectAll", "edit-select-all-symbolic", N_("Select _All"), "<control>A",
|
||||||
N_("Select the entire document"), G_CALLBACK (_xed_cmd_edit_select_all) },
|
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 */
|
/* View menu */
|
||||||
{ "ViewHighlightMode", NULL, N_("_Highlight Mode"), "<shift><control>H",
|
{ "ViewHighlightMode", NULL, N_("_Highlight Mode"), "<shift><control>H",
|
||||||
|
|
Loading…
Reference in New Issue