[nautilus/wip/csoriano/destktop-split2: 31/47] f with other locations subclass
- From: Carlos Soriano Sánchez <csoriano src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [nautilus/wip/csoriano/destktop-split2: 31/47] f with other locations subclass
- Date: Wed, 30 Mar 2016 20:00:40 +0000 (UTC)
commit 43286bbb91b8bde0148b82efa47694de46d714a2
Author: Carlos Soriano <csoriano gnome org>
Date: Thu Mar 24 17:08:04 2016 +0100
f with other locations subclass
src/nautilus-window.c | 25 ++++++++++++++++---------
1 files changed, 16 insertions(+), 9 deletions(-)
---
diff --git a/src/nautilus-window.c b/src/nautilus-window.c
index 1c1ceef..a0aa346 100644
--- a/src/nautilus-window.c
+++ b/src/nautilus-window.c
@@ -592,6 +592,11 @@ nautilus_window_open_location_full (NautilusWindow *window,
gboolean new_tab_at_end;
active_slot = nautilus_window_get_active_slot (window);
+ /* The location owner can be one of the slots requesting to handle an
+ * unhandled location. But this slot can be destroyed when switching to
+ * a new slot. So keep the locaiton alive
+ */
+ g_object_ref (location);
/* Assert that we are not managing new windows */
g_assert (! (flags & NAUTILUS_WINDOW_OPEN_FLAG_NEW_WINDOW));
@@ -605,15 +610,15 @@ nautilus_window_open_location_full (NautilusWindow *window,
nautilus_window_initialize_slot (window, target_slot, flags);
}
- if (target_slot == NULL) {
- if (nautilus_window_slot_handles_location (active_slot, location)) {
- target_slot = active_slot;
- } else {
- target_slot = nautilus_window_create_slot (window, location);
- nautilus_window_initialize_slot (window, target_slot, flags);
- close_slot (window, active_slot, TRUE);
- }
- }
+ if (!target_slot)
+ target_slot = active_slot;
+
+ if (target_slot == NULL || !nautilus_window_slot_handles_location (active_slot, location)) {
+ target_slot = nautilus_window_create_slot (window, location);
+ nautilus_window_initialize_slot (window, target_slot, flags);
+ if (active_slot)
+ close_slot (window, active_slot, TRUE);
+ }
/* Make the opened location the one active if we weren't ask for the
* oposite, since it's the most usual use case */
@@ -623,6 +628,8 @@ nautilus_window_open_location_full (NautilusWindow *window,
}
nautilus_window_slot_open_location_full (target_slot, location, flags, selection);
+
+ g_object_unref (location);
}
static int
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]