--- client/map.c | 50 ++++++++++++++++++++++++++++++++++++++++++++++++++ doc/client-api.txt | 5 ++++- 2 files changed, 54 insertions(+), 1 deletions(-) diff --git a/client/map.c b/client/map.c index bee49c5..e5ebecb 100644 --- a/client/map.c +++ b/client/map.c @@ -40,6 +40,9 @@ #define OBEX_MAS_UUID_LEN 16 #define MAP_INTERFACE "org.openobex.MessageAccess" +#define ERROR_INF MAP_INTERFACE ".Error" +#define ERROR_FAILED_PATH "org.openobex.Error.Failed" + #define MAS_UUID "00001132-0000-1000-8000-00805f9b34fb" struct map_data { @@ -49,7 +52,54 @@ struct map_data { static DBusConnection *conn = NULL; +static void simple_cb(GObex *obex, GError *err, GObexPacket *rsp, + gpointer user_data) +{ + DBusMessage *reply; + struct map_data *map = user_data; + + if (err != NULL) + reply = g_dbus_create_error(map->msg, ERROR_FAILED_PATH, + "%s", err->message); + else + reply = dbus_message_new_method_return(map->msg); + + g_dbus_send_message(conn, reply); + dbus_message_unref(map->msg); +} + +static DBusMessage *map_setpath(DBusConnection *connection, + DBusMessage *message, void *user_data) +{ + struct map_data *map = user_data; + const char *folder; + GObex *obex; + GError *err = NULL; + + if (dbus_message_get_args(message, NULL, DBUS_TYPE_STRING, &folder, + DBUS_TYPE_INVALID) == FALSE) + return g_dbus_create_error(message, + ERROR_INF ".InvalidArguments", NULL); + + obex = obc_session_get_obex(map->session); + + g_obex_setpath(obex, folder, simple_cb, map, &err); + if (err != NULL) { + DBusMessage *reply; + reply = g_dbus_create_error(message, + ERROR_FAILED_PATH, + "%s", err->message); + g_error_free(err); + return reply; + } + + map->msg = dbus_message_ref(message); + + return NULL; +} + static GDBusMethodTable map_methods[] = { + { "SetFolder", "s", "", map_setpath, G_DBUS_METHOD_FLAG_ASYNC }, { } }; diff --git a/doc/client-api.txt b/doc/client-api.txt index ee8951f..fb5a8b2 100644 --- a/doc/client-api.txt +++ b/doc/client-api.txt @@ -258,7 +258,10 @@ Service org.openobex.client Interface org.openobex.MessageAccess Object path [variable prefix]/{session0,session1,...} -Methods +Methods void SetFolder(string name) + + Set working directory for current session, *name* may + be the directory name or '..[/dir]'. Transfer hierarchy ================== -- 1.7.4.1 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html