Return-Path: From: Luiz Augusto von Dentz To: linux-bluetooth@vger.kernel.org Subject: [PATCH obexd 07/13] client: introduce obc_session_move Date: Mon, 30 Jan 2012 07:30:30 -0800 Message-Id: <1327937436-15480-7-git-send-email-luiz.dentz@gmail.com> In-Reply-To: <1327937436-15480-1-git-send-email-luiz.dentz@gmail.com> References: <1327937436-15480-1-git-send-email-luiz.dentz@gmail.com> Sender: linux-bluetooth-owner@vger.kernel.org List-ID: From: Luiz Augusto von Dentz --- client/session.c | 30 ++++++++++++++++++++++++++++++ client/session.h | 3 +++ 2 files changed, 33 insertions(+), 0 deletions(-) diff --git a/client/session.c b/client/session.c index f664372..9f07114 100644 --- a/client/session.c +++ b/client/session.c @@ -1340,3 +1340,33 @@ guint obc_session_copy(struct obc_session *session, const char *filename, session->p = p; return p->id; } + +guint obc_session_move(struct obc_session *session, const char *filename, + const char *destname, session_callback_t func, + void *user_data, GError **err) +{ + struct pending_request *p; + + if (session->obex == NULL) { + g_set_error(err, OBEX_IO_ERROR, -ENOTCONN, + strerror(-ENOTCONN)); + return 0; + } + + if (session->p != NULL) { + g_set_error(err, OBEX_IO_ERROR, -EBUSY, strerror(-EBUSY)); + return 0; + } + + p = pending_request_new(session, NULL, NULL, func, user_data); + + p->req_id = g_obex_move(session->obex, filename, destname, async_cb, p, + err); + if (*err != NULL) { + pending_request_free(p); + return 0; + } + + session->p = p; + return p->id; +} diff --git a/client/session.h b/client/session.h index 57f3fcd..64548e9 100644 --- a/client/session.h +++ b/client/session.h @@ -83,3 +83,6 @@ guint obc_session_mkdir(struct obc_session *session, const char *folder, guint obc_session_copy(struct obc_session *session, const char *filename, const char *destname, session_callback_t func, void *user_data, GError **err); +guint obc_session_move(struct obc_session *session, const char *filename, + const char *destname, session_callback_t func, + void *user_data, GError **err); -- 1.7.7.6