diff options
author | Slawomir Bochenski <lkslawek@gmail.com> | 2012-03-14 14:29:50 +0100 |
---|---|---|
committer | Johan Hedberg <johan.hedberg@intel.com> | 2012-03-14 15:57:53 +0200 |
commit | f9b52473ac91f6c97327b37d013cf93c7c10d99c (patch) | |
tree | d0c3bd4cacb8c9c56361ca42b1f2a0bcfe007e90 | |
parent | bcbfcaa3b5c29d5f016346102516e919bbdb60eb (diff) | |
download | obexd-f9b52473ac91f6c97327b37d013cf93c7c10d99c.tar.gz |
MAP/dummy: Code for returning folder listing
-rw-r--r-- | plugins/messages-dummy.c | 22 |
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); } |