diff options
author | Radoslaw Jablonski <ext-jablonski.radoslaw@nokia.com> | 2011-02-16 11:34:15 +0200 |
---|---|---|
committer | Johan Hedberg <johan.hedberg@nokia.com> | 2011-02-16 11:59:56 -0300 |
commit | 1b2a322ba64a6c536c15c1575627ec1861e3e2c4 (patch) | |
tree | b71ff27882be3fa14d2caa829f4bfc0ead1f6640 /plugins/phonebook-tracker.c | |
parent | e4cc5f737cb2031f4cca7793a8826ba118b53bbc (diff) | |
download | obexd-1b2a322ba64a6c536c15c1575627ec1861e3e2c4.tar.gz |
Add increasing query OFFSET in phonebook_pull_read
It is needed to properly move starting index in tracker
for next invocations of phonebook_pull_read - without that
pull result for bigger queries (over one part of data) will
be wrong (it will include duplicate vcard entries).
Diffstat (limited to 'plugins/phonebook-tracker.c')
-rw-r--r-- | plugins/phonebook-tracker.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/plugins/phonebook-tracker.c b/plugins/phonebook-tracker.c index eb38a46..28d5c7d 100644 --- a/plugins/phonebook-tracker.c +++ b/plugins/phonebook-tracker.c @@ -1964,6 +1964,7 @@ int phonebook_pull_read(void *request) struct phonebook_data *data = request; reply_list_foreach_t pull_cb; const char *query; + char *offset_query; int col_amount; int ret; @@ -1987,6 +1988,19 @@ int phonebook_pull_read(void *request) if (query == NULL) return -ENOENT; + if (pull_cb == pull_contacts && data->tracker_index > 0) { + /* Adding offset to pull query to download next parts of data + * from tracker (phonebook_pull_read may be called many times + * from PBAP core to fetch data partially) */ + offset_query = g_strdup_printf(QUERY_OFFSET_FORMAT, query, + data->tracker_index); + ret = query_tracker(offset_query, col_amount, pull_cb, data); + + g_free(offset_query); + + return ret; + } + ret = query_tracker(query, col_amount, pull_cb, data); return ret; |