summaryrefslogtreecommitdiff
path: root/client/session.c
diff options
context:
space:
mode:
authorLuiz Augusto von Dentz <luiz.von.dentz@intel.com>2012-02-08 11:44:01 +0200
committerJohan Hedberg <johan.hedberg@intel.com>2012-02-08 12:41:24 +0200
commitd143ae8fdf0ec3138fb9423d6b2554134bff7edc (patch)
treef2f6314efa4bfff34727734c84f695c19522d7d1 /client/session.c
parentc2fd4a32d44a4b33472d8d6cd9f6e252d3869851 (diff)
downloadobexd-d143ae8fdf0ec3138fb9423d6b2554134bff7edc.tar.gz
client: introduce obc_session_mkdir
Diffstat (limited to 'client/session.c')
-rw-r--r--client/session.c64
1 files changed, 64 insertions, 0 deletions
diff --git a/client/session.c b/client/session.c
index e946cfd..2467e85 100644
--- a/client/session.c
+++ b/client/session.c
@@ -1241,3 +1241,67 @@ fail:
pending_request_free(p);
return 0;
}
+
+static void async_cb(GObex *obex, GError *err, GObexPacket *rsp,
+ gpointer user_data)
+{
+ struct pending_request *p = user_data;
+ struct obc_session *session = p->session;
+ GError *gerr = NULL;
+ uint8_t code;
+
+ p->req_id = 0;
+
+ if (err != NULL) {
+ if (p->func)
+ p->func(p->session, err, p->data);
+ goto done;
+ }
+
+ code = g_obex_packet_get_operation(rsp, NULL);
+ if (code != G_OBEX_RSP_SUCCESS)
+ g_set_error(&gerr, OBEX_IO_ERROR, code, "%s",
+ g_obex_strerror(code));
+
+ if (p->func)
+ p->func(p->session, gerr, p->data);
+
+ if (gerr != NULL)
+ g_clear_error(&gerr);
+
+done:
+ pending_request_free(p);
+ session->p = NULL;
+
+ session_process_queue(session);
+}
+
+guint obc_session_mkdir(struct obc_session *session, const char *folder,
+ session_callback_t func, void *user_data,
+ GError **err)
+{
+ struct pending_request *p;
+
+ if (session->obex == NULL) {
+ g_set_error(err, OBEX_IO_ERROR, OBEX_IO_DISCONNECTED,
+ "Session disconnected");
+ return 0;
+ }
+
+ if (session->p != NULL) {
+ g_set_error(err, OBEX_IO_ERROR, OBEX_IO_BUSY, "Session busy");
+ return 0;
+ }
+
+
+ p = pending_request_new(session, NULL, NULL, func, user_data);
+
+ p->req_id = g_obex_mkdir(session->obex, folder, async_cb, p, err);
+ if (*err != NULL) {
+ pending_request_free(p);
+ return 0;
+ }
+
+ session->p = p;
+ return p->id;
+}