diff --git a/obexd/client/session.c b/obexd/client/session.c
index dfc912d..7e7dea6 100644
--- a/obexd/client/session.c
+++ b/obexd/client/session.c
session->p = p;
return p->id;
}
+
+guint obc_session_delete(struct obc_session *session, const char *file,
+ 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_delete(session->obex, file, async_cb, p, err);
+ if (*err != NULL) {
+ pending_request_free(p);
+ return 0;
+ }
+
+ session->p = p;
+ return p->id;
+}
diff --git a/obexd/client/session.h b/obexd/client/session.h
index 64548e9..ac5c27a 100644
--- a/obexd/client/session.h
+++ b/obexd/client/session.h
guint obc_session_move(struct obc_session *session, const char *filename,
const char *destname, session_callback_t func,
void *user_data, GError **err);
+guint obc_session_delete(struct obc_session *session, const char *file,
+ session_callback_t func, void *user_data,
+ GError **err);