--- client/map.c | 56 ++++++++++++++++++++++++++++++++++++++++++++++++++++ doc/client-api.txt | 5 +++- 2 files changed, 60 insertions(+), 1 deletions(-) diff --git a/client/map.c b/client/map.c index bee49c5..51a7711 100644 --- a/client/map.c +++ b/client/map.c @@ -49,7 +49,63 @@ 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; + guint8 err_code = g_obex_packet_get_operation(rsp, NULL); + + if (err != NULL) + reply = g_dbus_create_error(map->msg, + "org.openobex.Error.Failed", + "%s", err->message); + else if (err_code != G_OBEX_RSP_SUCCESS) + reply = g_dbus_create_error(map->msg, + "org.openobex.Error.Failed", + "%s (0x%02x)", + g_obex_strerror(err_code), + err_code); + 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, + "org.openobex.Error.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, + "org.openobex.Error.Failed", + "%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