Return-Path: From: Slawomir Bochenski To: linux-bluetooth@vger.kernel.org Cc: johan.hedberg@gmail.com, Slawomir Bochenski Subject: [PATCH obexd v3 2/3] MAP/dummy: Code for returning folder listing Date: Fri, 9 Mar 2012 08:06:33 +0100 Message-Id: <1331276794-14160-2-git-send-email-lkslawek@gmail.com> In-Reply-To: <1331276794-14160-1-git-send-email-lkslawek@gmail.com> References: <1331276794-14160-1-git-send-email-lkslawek@gmail.com> Sender: linux-bluetooth-owner@vger.kernel.org List-ID: --- 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..00cca59 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 n = 0; + uint16_t o = 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) { + ++n; + fld->callback(session, -EAGAIN, 0, "..", fld->user_data); + } else { + ++o; + } + + for (cur = list; o < fld->offset; ++o) { + cur = cur->next; + if (cur == NULL) + break; + } + + for (; cur != NULL && n < fld->max; cur = cur->next, ++n) + fld->callback(session, -EAGAIN, 0, cur->data, fld->user_data); fld->callback(session, 0, 0, NULL, fld->user_data); } -- 1.7.4.1