summaryrefslogtreecommitdiff
path: root/plugins
diff options
context:
space:
mode:
authorSlawomir Bochenski <lkslawek@gmail.com>2012-03-14 14:29:50 +0100
committerJohan Hedberg <johan.hedberg@intel.com>2012-03-14 15:57:53 +0200
commitf9b52473ac91f6c97327b37d013cf93c7c10d99c (patch)
treed0c3bd4cacb8c9c56361ca42b1f2a0bcfe007e90 /plugins
parentbcbfcaa3b5c29d5f016346102516e919bbdb60eb (diff)
downloadobexd-f9b52473ac91f6c97327b37d013cf93c7c10d99c.tar.gz
MAP/dummy: Code for returning folder listing
Diffstat (limited to 'plugins')
-rw-r--r--plugins/messages-dummy.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/plugins/messages-dummy.c b/plugins/messages-dummy.c
index cfb24e2..6b06e58 100644
--- a/plugins/messages-dummy.c
+++ b/plugins/messages-dummy.c
@@ -119,6 +119,28 @@ static ssize_t get_subdirs(struct folder_listing_data *fld, GSList **list)
static void return_folder_listing(struct folder_listing_data *fld, GSList *list)
{
struct session *session = fld->session;
+ GSList *cur;
+ uint16_t num = 0;
+ uint16_t offs = 0;
+
+ /* XXX: This isn't really documented for MAP. I need to take a look how
+ * other implementations choose to deal with parent folder.
+ */
+ if (session->cwd[0] != 0 && fld->offset == 0) {
+ num++;
+ fld->callback(session, -EAGAIN, 0, "..", fld->user_data);
+ } else {
+ offs++;
+ }
+
+ for (cur = list; offs < fld->offset; offs++) {
+ cur = cur->next;
+ if (cur == NULL)
+ break;
+ }
+
+ for (; cur != NULL && num < fld->max; cur = cur->next, num++)
+ fld->callback(session, -EAGAIN, 0, cur->data, fld->user_data);
fld->callback(session, 0, 0, NULL, fld->user_data);
}