diff options
author | Mikhail Pozdnyakov <mikhail.pozdnyakov@mapbox.com> | 2019-10-10 11:43:17 +0300 |
---|---|---|
committer | Mikhail Pozdnyakov <mikhail.pozdnyakov@mapbox.com> | 2019-10-10 15:39:34 +0300 |
commit | 2f973e9646b49f80c7af6851d38cf1029a31a232 (patch) | |
tree | 9858bf0bf9b600a2b14f03d7134f0823a3ec1405 /src/mbgl/renderer/image_manager.cpp | |
parent | 76346944f3f6809bed7dd7ce4ef82343fc069423 (diff) | |
download | qtlocation-mapboxgl-2f973e9646b49f80c7af6851d38cf1029a31a232.tar.gz |
[core] Introduce Scheduler::bindOnce() and use it in ImageManager
Diffstat (limited to 'src/mbgl/renderer/image_manager.cpp')
-rw-r--r-- | src/mbgl/renderer/image_manager.cpp | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/src/mbgl/renderer/image_manager.cpp b/src/mbgl/renderer/image_manager.cpp index 65defc54c8..0920f5a659 100644 --- a/src/mbgl/renderer/image_manager.cpp +++ b/src/mbgl/renderer/image_manager.cpp @@ -204,6 +204,7 @@ void ImageManager::checkMissingAndNotify(ImageRequestor& requestor, const ImageR } requestedImages[missingImage].emplace(requestorPtr); requestor.addPendingRequest(missingImage); + auto removePendingRequests = [this, missingImage] { auto existingRequest = requestedImages.find(missingImage); if (existingRequest == requestedImages.end()) { @@ -214,11 +215,8 @@ void ImageManager::checkMissingAndNotify(ImageRequestor& requestor, const ImageR req->removePendingRequest(missingImage); } }; - - Scheduler& scheduler = *Scheduler::GetCurrent(); - auto callback = [&scheduler, removePendingRequests]() { scheduler.schedule(removePendingRequests); }; - - observer->onStyleImageMissing(missingImage, std::move(callback)); + observer->onStyleImageMissing(missingImage, + Scheduler::GetCurrent()->bindOnce(std::move(removePendingRequests))); } } else { // Associate requestor with an image that was provided by the client. |