diff options
author | Alexander Shalamov <alexander.shalamov@mapbox.com> | 2020-03-19 23:15:46 +0200 |
---|---|---|
committer | kevin <kevin.li@mapbox.com> | 2020-03-24 10:39:43 +0800 |
commit | b817e0f58d6b62a6d8fc445be0e1bfaf1ef29d03 (patch) | |
tree | 414cd8bf861bdc8235b5c7b6b9adb02bbfb726e0 /platform/android/src/snapshotter/map_snapshotter.hpp | |
parent | bdbac2d78bfea8970c4d26ce72be91092b3407e9 (diff) | |
download | qtlocation-mapboxgl-b817e0f58d6b62a6d8fc445be0e1bfaf1ef29d03.tar.gz |
Use custom deleter for snapshotter
Diffstat (limited to 'platform/android/src/snapshotter/map_snapshotter.hpp')
-rw-r--r-- | platform/android/src/snapshotter/map_snapshotter.hpp | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/platform/android/src/snapshotter/map_snapshotter.hpp b/platform/android/src/snapshotter/map_snapshotter.hpp index 1da4f8275b..e6f543649f 100644 --- a/platform/android/src/snapshotter/map_snapshotter.hpp +++ b/platform/android/src/snapshotter/map_snapshotter.hpp @@ -3,9 +3,7 @@ #include <jni/jni.hpp> #include <mbgl/map/map_snapshotter.hpp> #include <mbgl/util/util.hpp> - #include <memory> -#include <mapbox/weak.hpp> #include "../file_source.hpp" #include "../geometry/lat_lng_bounds.hpp" @@ -65,6 +63,15 @@ public: void onStyleImageMissing(const std::string&) override; private: + struct DeleteOnThread { + DeleteOnThread(); + explicit DeleteOnThread(mapbox::base::WeakPtr<mbgl::Scheduler>); + void operator()(mbgl::MapSnapshotter* p) const; + private: + mapbox::base::WeakPtr<mbgl::Scheduler> weakScheduler; + }; + +private: MBGL_STORE_THREAD(tid); JavaVM *vm = nullptr; @@ -77,8 +84,7 @@ private: void activateFilesource(JNIEnv&); void deactivateFilesource(JNIEnv&); bool activatedFilesource = false; - std::unique_ptr<mbgl::MapSnapshotter> snapshotter; - mapbox::base::WeakPtr<mbgl::Scheduler> weakScheduler; + std::unique_ptr<mbgl::MapSnapshotter, DeleteOnThread> snapshotter; }; } // namespace android |