Diff between fe22983f433d927768c6e343640881ae211573e6 and cb61428a7304eb1de81e0b0c72aeaa2e49623a32

Changed Files

File Additions Deletions Status
tools/obexctl.c +77 -8 modified

Full Patch

diff --git a/tools/obexctl.c b/tools/obexctl.c
index bab9ad8..9adf6b8 100644
--- a/tools/obexctl.c
+++ b/tools/obexctl.c
@@ -657,6 +657,33 @@ static void change_folder_setup(DBusMessageIter *iter, void *user_data)
 	dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING, &folder);
 }
 
+static void select_reply(DBusMessage *message, void *user_data)
+{
+	DBusMessageIter iter;
+	DBusError error;
+
+	dbus_error_init(&error);
+
+	if (dbus_set_error_from_message(&error, message) == TRUE) {
+		rl_printf("Failed to Select: %s\n", error.name);
+		dbus_error_free(&error);
+		return;
+	}
+
+	dbus_message_iter_init(message, &iter);
+
+	rl_printf("Select successful\n");
+}
+
+static void select_setup(DBusMessageIter *iter, void *user_data)
+{
+	const char *folder = user_data;
+	const char *location = "int";
+
+	dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING, &location);
+	dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING, &folder);
+}
+
 static GDBusProxy *find_ftp(const char *path)
 {
 	GSList *l;
@@ -671,19 +698,22 @@ static GDBusProxy *find_ftp(const char *path)
 	return NULL;
 }
 
-static void cmd_cd(int argc, char *argv[])
+static GDBusProxy *find_pbap(const char *path)
 {
-	GDBusProxy *proxy;
+	GSList *l;
 
-	if (!check_default_session())
-		return;
+	for (l = pbaps; l; l = g_slist_next(l)) {
+		GDBusProxy *proxy = l->data;
 
-	proxy = find_ftp(g_dbus_proxy_get_path(default_session));
-	if (proxy == NULL) {
-		rl_printf("Command not supported\n");
-		return;
+		if (strcmp(path, g_dbus_proxy_get_path(proxy)) == 0)
+			return proxy;
 	}
 
+	return NULL;
+}
+
+static void ftp_cd(GDBusProxy *proxy, int argc, char *argv[])
+{
 	if (argc < 2) {
 		rl_printf("Missing path argument\n");
 		return;
@@ -699,6 +729,45 @@ static void cmd_cd(int argc, char *argv[])
 	rl_printf("Attempting to ChangeFolder to %s\n", argv[1]);
 }
 
+static void pbap_cd(GDBusProxy *proxy, int argc, char *argv[])
+{
+	if (argc < 2) {
+		rl_printf("Missing path argument\n");
+		return;
+	}
+
+	if (g_dbus_proxy_method_call(proxy, "Select", select_setup,
+					select_reply, g_strdup(argv[1]),
+					g_free) == FALSE) {
+		rl_printf("Failed to Select\n");
+		return;
+	}
+
+	rl_printf("Attempting to Select to %s\n", argv[1]);
+}
+
+static void cmd_cd(int argc, char *argv[])
+{
+	GDBusProxy *proxy;
+
+	if (!check_default_session())
+		return;
+
+	proxy = find_ftp(g_dbus_proxy_get_path(default_session));
+	if (proxy) {
+		ftp_cd(proxy, argc, argv);
+		return;
+	}
+
+	proxy = find_pbap(g_dbus_proxy_get_path(default_session));
+	if (proxy) {
+		pbap_cd(proxy, argc, argv);
+		return;
+	}
+
+	rl_printf("Command not supported\n");
+}
+
 static void list_folder_reply(DBusMessage *message, void *user_data)
 {
 	DBusMessageIter iter, array;