summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSébastien Wilmet <swilmet@informatique-libre.be>2023-03-21 16:00:00 +0100
committerSébastien Wilmet <swilmet@informatique-libre.be>2023-03-21 16:00:00 +0100
commitbc5d8516c84cbad9dd423541c3e1a354b558c29d (patch)
tree4fc5c2ddeb11e0b3f1aff8ddf3da5c28b04fe005
parent8b348bc053a64035a66a1c106557acb2741a000b (diff)
downloadgedit-bc5d8516c84cbad9dd423541c3e1a354b558c29d.tar.gz
Window: simplify code of create_tab_from_location/stream()
First create tab with gedit_window_create_tab() and then load content. This shouldn't change anything because the content is loaded asynchronously.
-rw-r--r--gedit/gedit-window.c40
1 files changed, 12 insertions, 28 deletions
diff --git a/gedit/gedit-window.c b/gedit/gedit-window.c
index b17dad9ab..e4f0da593 100644
--- a/gedit/gedit-window.c
+++ b/gedit/gedit-window.c
@@ -2913,27 +2913,6 @@ _gedit_window_get_notebook (GeditWindow *window)
return GTK_WIDGET (gedit_multi_notebook_get_active_notebook (window->priv->multi_notebook));
}
-static void
-process_create_tab (GeditWindow *window,
- GeditTab *tab,
- gboolean jump_to)
-{
- GeditNotebook *notebook;
-
- notebook = GEDIT_NOTEBOOK (_gedit_window_get_notebook (window));
-
- gtk_widget_show (GTK_WIDGET (tab));
- gedit_notebook_add_tab (notebook,
- tab,
- -1,
- jump_to);
-
- if (!gtk_widget_get_visible (GTK_WIDGET (window)))
- {
- gtk_window_present (GTK_WINDOW (window));
- }
-}
-
/**
* gedit_window_create_tab:
* @window: a #GeditWindow
@@ -2949,13 +2928,22 @@ gedit_window_create_tab (GeditWindow *window,
gboolean jump_to)
{
GeditTab *tab;
+ GeditNotebook *notebook;
g_return_val_if_fail (GEDIT_IS_WINDOW (window), NULL);
gedit_debug (DEBUG_WINDOW);
tab = _gedit_tab_new ();
- process_create_tab (window, tab, jump_to);
+ gtk_widget_show (GTK_WIDGET (tab));
+
+ notebook = GEDIT_NOTEBOOK (_gedit_window_get_notebook (window));
+ gedit_notebook_add_tab (notebook, tab, -1, jump_to);
+
+ if (!gtk_widget_get_visible (GTK_WIDGET (window)))
+ {
+ gtk_window_present (GTK_WINDOW (window));
+ }
return tab;
}
@@ -2995,7 +2983,7 @@ gedit_window_create_tab_from_location (GeditWindow *window,
gedit_debug (DEBUG_WINDOW);
- tab = _gedit_tab_new ();
+ tab = gedit_window_create_tab (window, jump_to);
_gedit_tab_load (tab,
location,
@@ -3004,8 +2992,6 @@ gedit_window_create_tab_from_location (GeditWindow *window,
column_pos,
create);
- process_create_tab (window, tab, jump_to);
-
return tab;
}
@@ -3035,7 +3021,7 @@ gedit_window_create_tab_from_stream (GeditWindow *window,
g_return_val_if_fail (GEDIT_IS_WINDOW (window), NULL);
g_return_val_if_fail (G_IS_INPUT_STREAM (stream), NULL);
- tab = _gedit_tab_new ();
+ tab = gedit_window_create_tab (window, jump_to);
_gedit_tab_load_stream (tab,
stream,
@@ -3043,8 +3029,6 @@ gedit_window_create_tab_from_stream (GeditWindow *window,
line_pos,
column_pos);
- process_create_tab (window, tab, jump_to);
-
return tab;
}