diff options
author | Luiz Augusto von Dentz <luiz.von.dentz@intel.com> | 2012-02-08 11:44:01 +0200 |
---|---|---|
committer | Johan Hedberg <johan.hedberg@intel.com> | 2012-02-08 12:41:24 +0200 |
commit | d143ae8fdf0ec3138fb9423d6b2554134bff7edc (patch) | |
tree | f2f6314efa4bfff34727734c84f695c19522d7d1 /client/session.c | |
parent | c2fd4a32d44a4b33472d8d6cd9f6e252d3869851 (diff) | |
download | obexd-d143ae8fdf0ec3138fb9423d6b2554134bff7edc.tar.gz |
client: introduce obc_session_mkdir
Diffstat (limited to 'client/session.c')
-rw-r--r-- | client/session.c | 64 |
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; +} |