diff --git a/obexd/plugins/messages-dummy.c b/obexd/plugins/messages-dummy.c
index 511857e..3ba333c 100644
--- a/obexd/plugins/messages-dummy.c
+++ b/obexd/plugins/messages-dummy.c
struct session {
char *cwd;
char *cwd_absolute;
+ void *request;
};
+struct folder_listing_data {
+ struct session *session;
+ const char *name;
+ uint16_t max;
+ uint16_t offset;
+ messages_folder_listing_cb callback;
+ void *user_data;
+};
+
+static gboolean get_folder_listing(void *d)
+{
+ return FALSE;
+}
+
int messages_init(void)
{
char *tmp;
return 0;
}
-int messages_get_folder_listing(void *session, const char *name, uint16_t max,
+int messages_get_folder_listing(void *s, const char *name, uint16_t max,
uint16_t offset,
messages_folder_listing_cb callback,
void *user_data)
{
- return -ENOSYS;
+ struct session *session = s;
+ struct folder_listing_data *fld;
+
+ fld = g_new0(struct folder_listing_data, 1);
+ fld->session = session;
+ fld->name = name;
+ fld->max = max;
+ fld->offset = offset;
+ fld->callback = callback;
+ fld->user_data = user_data;
+
+ session->request = fld;
+
+ g_idle_add_full(G_PRIORITY_DEFAULT_IDLE, get_folder_listing,
+ fld, g_free);
+
+ return 0;
}
int messages_get_messages_listing(void *session, const char *name,
return -ENOSYS;
}
-void messages_abort(void *session)
+void messages_abort(void *s)
{
+ struct session *session = s;
+
+ if (session->request) {
+ g_idle_remove_by_data(session->request);
+ session->request = NULL;
+ }
}