summaryrefslogtreecommitdiff
path: root/platform
diff options
context:
space:
mode:
authorKonstantin Käfer <mail@kkaefer.com>2015-02-16 18:30:19 -0800
committerKonstantin Käfer <mail@kkaefer.com>2015-02-16 18:30:19 -0800
commitfe0baffe0dfbf369f422e175c0fcf3dda9055118 (patch)
treed404bd67ec2b338f37e4de958c74c44c841a77b5 /platform
parent8d3c2b3d303adaf2c9caa91356183d9b40cdfeab (diff)
downloadqtlocation-mapboxgl-fe0baffe0dfbf369f422e175c0fcf3dda9055118.tar.gz
update uv_zip and add tests
Diffstat (limited to 'platform')
-rw-r--r--platform/default/asset_request_fs.cpp3
-rw-r--r--platform/default/asset_request_zip.cpp51
-rw-r--r--platform/default/uv_zip.c13
3 files changed, 45 insertions, 22 deletions
diff --git a/platform/default/asset_request_fs.cpp b/platform/default/asset_request_fs.cpp
index 24856e520b..1e32ee3135 100644
--- a/platform/default/asset_request_fs.cpp
+++ b/platform/default/asset_request_fs.cpp
@@ -3,7 +3,6 @@
#include <mbgl/util/std.hpp>
#include <mbgl/util/util.hpp>
#include <mbgl/util/uv.hpp>
-#include <mbgl/platform/platform.hpp>
#include <uv.h>
@@ -63,7 +62,7 @@ AssetRequestImpl::AssetRequestImpl(AssetRequest *request_, uv_loop_t *loop) : re
path = url.substr(8);
} else {
// This is a relative path. Prefix with the application root.
- path = platform::assetRoot() + "/" + url.substr(8);
+ path = request->source->getAssetRoot() + "/" + url.substr(8);
}
uv_fs_open(loop, &req, path.c_str(), O_RDONLY, S_IRUSR, fileOpened);
diff --git a/platform/default/asset_request_zip.cpp b/platform/default/asset_request_zip.cpp
index 9a5f598bb6..fd27c4b959 100644
--- a/platform/default/asset_request_zip.cpp
+++ b/platform/default/asset_request_zip.cpp
@@ -2,8 +2,8 @@
#include <mbgl/storage/default/thread_context.hpp>
#include <mbgl/android/jni.hpp>
#include <mbgl/storage/response.hpp>
+#include <mbgl/platform/log.hpp>
#include <mbgl/util/std.hpp>
-#include <mbgl/platform/platform.hpp>
#include "uv_zip.h"
@@ -26,12 +26,12 @@ public:
AssetZipContext(uv_loop_t *loop);
~AssetZipContext();
- uv_zip_t *getHandle();
- void returnHandle(uv_zip_t *zip);
+ uv_zip_t *getHandle(const std::string &path);
+ void returnHandle(const std::string &path, uv_zip_t *zip);
private:
// A list of resuable uv_zip handles to avoid creating and destroying them all the time.
- std::forward_list<uv_zip_t *> handles;
+ std::map<std::string, std::forward_list<uv_zip_t *>> handles;
};
// -------------------------------------------------------------------------------------------------
@@ -42,28 +42,30 @@ template<> pthread_once_t ThreadContext<AssetZipContext>::once = PTHREAD_ONCE_IN
AssetZipContext::AssetZipContext(uv_loop_t *loop_) : ThreadContext(loop_) {
}
-uv_zip_t *AssetZipContext::getHandle() {
- if (!handles.empty()) {
- auto zip = handles.front();
- handles.pop_front();
+uv_zip_t *AssetZipContext::getHandle(const std::string &path) {
+ auto &list = handles[path];
+ if (!list.empty()) {
+ auto zip = list.front();
+ list.pop_front();
return zip;
} else {
return nullptr;
}
}
-void AssetZipContext::returnHandle(uv_zip_t *zip) {
- uv_zip_cleanup(zip);
- handles.push_front(zip);
+void AssetZipContext::returnHandle(const std::string &path, uv_zip_t *zip) {
+ handles[path].push_front(zip);
}
AssetZipContext::~AssetZipContext() {
// Close all zip handles
- for (auto zip : handles) {
- uv_zip_discard(loop, zip, [](uv_zip_t *zip_) {
- uv_zip_cleanup(zip_);
- delete zip_;
- });
+ for (auto &list : handles) {
+ for (auto zip : list.second) {
+ uv_zip_discard(loop, zip, [](uv_zip_t *zip_) {
+ uv_zip_cleanup(zip_);
+ delete zip_;
+ });
+ }
}
handles.clear();
}
@@ -82,6 +84,7 @@ public:
private:
AssetZipContext &context;
AssetRequest *request = nullptr;
+ const std::string root;
const std::string path;
std::unique_ptr<Response> response;
uv_buf_t buffer;
@@ -111,8 +114,9 @@ AssetRequestImpl::~AssetRequestImpl() {
AssetRequestImpl::AssetRequestImpl(AssetRequest *request_, uv_loop_t *loop)
: context(*AssetZipContext::Get(loop)),
request(request_),
- path(request->resource.url.substr(8)) {
- auto zip = context.getHandle();
+ root(request->source->assetRoot),
+ path(std::string { "assets/" } + request->resource.url.substr(8)) {
+ auto zip = context.getHandle(root);
if (zip) {
archiveOpened(zip);
} else {
@@ -124,9 +128,12 @@ void AssetRequestImpl::openZipArchive() {
uv_fs_t *req = new uv_fs_t();
req->data = this;
+ assert(request);
+ assert(request->source);
+
// We're using uv_fs_open first to obtain a file descriptor. Then, uv_zip_fdopen will operate
// on a read-only file.
- uv_fs_open(context.loop, req, platform::assetRoot().c_str(), O_RDONLY, S_IRUSR, [](uv_fs_t *fsReq) {
+ uv_fs_open(context.loop, req, root.c_str(), O_RDONLY, S_IRUSR, [](uv_fs_t *fsReq) {
if (fsReq->result < 0) {
auto impl = reinterpret_cast<AssetRequestImpl *>(fsReq->data);
impl->notifyError(uv::getFileRequestError(fsReq));
@@ -191,6 +198,10 @@ void AssetRequestImpl::fileStated(uv_zip_t *zip) {
response->modified = zip->stat->mtime;
}
+ if (zip->stat->valid & ZIP_STAT_INDEX) {
+ response->etag = std::to_string(zip->stat->index);
+ }
+
uv_zip_fopen(context.loop, zip, path.c_str(), 0, INVOKE_MEMBER(fileOpened));
}
}
@@ -239,7 +250,7 @@ void AssetRequestImpl::fileClosed(uv_zip_t *zip) {
void AssetRequestImpl::cleanup(uv_zip_t *zip) {
MBGL_VERIFY_THREAD(tid);
- context.returnHandle(zip);
+ context.returnHandle(root, zip);
delete this;
}
diff --git a/platform/default/uv_zip.c b/platform/default/uv_zip.c
index 7cb3c516d6..51bd15e8e2 100644
--- a/platform/default/uv_zip.c
+++ b/platform/default/uv_zip.c
@@ -172,6 +172,7 @@ int uv_zip_open(uv_loop_t* loop, uv_zip_t *zip, const char *path, zip_flags_t fl
assert(zip);
assert(path);
assert(strlen(path));
+ zip->result = 0;
zip->path = path;
zip->flags = flags;
zip->cb = cb;
@@ -182,6 +183,7 @@ int uv_zip_fdopen(uv_loop_t* loop, uv_zip_t *zip, uv_file fd, int flags, uv_zip_
assert(loop);
assert(zip);
assert(fd);
+ zip->result = 0;
zip->path = malloc(sizeof(uv_file));
*(uv_file *)zip->path = fd;
zip->flags = flags;
@@ -194,6 +196,8 @@ int uv_zip_stat(uv_loop_t* loop, uv_zip_t *zip, const char *fname, zip_flags_t f
assert(zip);
assert(fname);
assert(strlen(fname));
+ assert(zip->archive);
+ zip->result = 0;
zip->path = fname;
zip->flags = flags;
zip->cb = cb;
@@ -205,8 +209,11 @@ int uv_zip_fopen(uv_loop_t* loop, uv_zip_t *zip, const char *fname, zip_flags_t
assert(zip);
assert(fname);
assert(strlen(fname));
+ assert(zip->archive);
+ zip->result = 0;
zip->path = fname;
zip->flags = flags;
+ zip->file = NULL;
zip->cb = cb;
return uv_queue_work(loop, &zip->work, uv__zip_work_fopen, uv__zip_after_work);
}
@@ -215,6 +222,8 @@ int uv_zip_fclose(uv_loop_t* loop, uv_zip_t *zip, struct zip_file *file, uv_zip_
assert(loop);
assert(zip);
assert(file);
+ assert(zip->archive);
+ zip->result = 0;
zip->file = file;
zip->cb = cb;
return uv_queue_work(loop, &zip->work, uv__zip_work_fclose, uv__zip_after_work);
@@ -225,6 +234,8 @@ int uv_zip_fread(uv_loop_t* loop, uv_zip_t *zip, struct zip_file *file, uv_buf_t
assert(zip);
assert(file);
assert(buf);
+ assert(zip->archive);
+ zip->result = 0;
zip->file = file;
zip->buf = buf;
zip->cb = cb;
@@ -234,6 +245,8 @@ int uv_zip_fread(uv_loop_t* loop, uv_zip_t *zip, struct zip_file *file, uv_buf_t
int uv_zip_discard(uv_loop_t* loop, uv_zip_t *zip, uv_zip_cb cb) {
assert(loop);
assert(zip);
+ assert(!zip->file);
+ zip->result = 0;
zip->cb = cb;
return uv_queue_work(loop, &zip->work, uv__zip_work_discard, uv__zip_after_work);
}