summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarlos Soriano <csoriano@redhat.com>2018-11-19 08:55:22 +0000
committerCarlos Soriano <csoriano1618@gmail.com>2018-11-21 12:47:15 +0000
commitbac4bd595c518983571b0fb41fcf5586f27544eb (patch)
tree5c218fe2739c872d8cec164a91d16572c307d3d4
parent05a9dbcc90379df749031c209171b4ad32bdf739 (diff)
downloadnautilus-bac4bd595c518983571b0fb41fcf5586f27544eb.tar.gz
dbus: Implement rename file
So desktop icons extensions can use it. (cherry picked from commit 42c5ce657e2b24ddf19932e9e3284a045d60ff51)
-rw-r--r--data/dbus-interfaces.xml4
-rw-r--r--src/nautilus-dbus-manager.c33
2 files changed, 37 insertions, 0 deletions
diff --git a/data/dbus-interfaces.xml b/data/dbus-interfaces.xml
index 298871bc4..1827f92ab 100644
--- a/data/dbus-interfaces.xml
+++ b/data/dbus-interfaces.xml
@@ -39,6 +39,10 @@
<method name='CreateFolder'>
<arg type='s' name='URI' direction='in'/>
</method>
+ <method name='RenameFile'>
+ <arg type='s' name='URI' direction='in'/>
+ <arg type='s' name='NewName' direction='in'/>
+ </method>
<method name='Undo'>
</method>
<method name='Redo'>
diff --git a/src/nautilus-dbus-manager.c b/src/nautilus-dbus-manager.c
index 3257c4bd4..43f27e10a 100644
--- a/src/nautilus-dbus-manager.c
+++ b/src/nautilus-dbus-manager.c
@@ -27,6 +27,7 @@
#include "nautilus-file-operations.h"
#include "nautilus-file-undo-manager.h"
+#include "nautilus-file.h"
#define DEBUG_FLAG NAUTILUS_DEBUG_DBUS
#include "nautilus-debug.h"
@@ -230,6 +231,34 @@ handle_trash_files (NautilusDBusFileOperations *object,
return TRUE; /* invocation was handled */
}
+static void
+rename_file_on_finished (NautilusFile *file,
+ GFile *result_location,
+ GError *error,
+ gpointer callback_data)
+{
+ g_application_release (g_application_get_default ());
+}
+
+static gboolean
+handle_rename_file (NautilusDBusFileOperations *object,
+ GDBusMethodInvocation *invocation,
+ const gchar *uri,
+ const gchar *new_name)
+{
+ NautilusFile *file = NULL;
+
+ file = nautilus_file_get_by_uri (uri);
+
+ g_application_hold (g_application_get_default ());
+ nautilus_file_rename (file, new_name,
+ rename_file_on_finished, NULL);
+
+ nautilus_dbus_file_operations_complete_rename_file (object, invocation);
+
+ return TRUE; /* invocation was handled */
+}
+
static void
undo_manager_changed (NautilusDBusManager *self)
@@ -267,6 +296,10 @@ nautilus_dbus_manager_init (NautilusDBusManager *self)
G_CALLBACK (handle_create_folder),
self);
g_signal_connect (self->file_operations,
+ "handle-rename-file",
+ G_CALLBACK (handle_rename_file),
+ self);
+ g_signal_connect (self->file_operations,
"handle-undo",
G_CALLBACK (handle_undo),
self);