| 1 | #pragma once |
| 2 | |
| 3 | #include <mbgl/storage/response.hpp> |
| 4 | #include <mbgl/storage/resource.hpp> |
| 5 | |
| 6 | #include <mbgl/util/noncopyable.hpp> |
| 7 | #include <mbgl/util/async_request.hpp> |
| 8 | |
| 9 | #include <functional> |
| 10 | #include <memory> |
| 11 | |
| 12 | namespace mbgl { |
| 13 | |
| 14 | class FileSource : private util::noncopyable { |
| 15 | public: |
| 16 | virtual ~FileSource() = default; |
| 17 | |
| 18 | using Callback = std::function<void (Response)>; |
| 19 | |
| 20 | // Request a resource. The callback will be called asynchronously, in the same |
| 21 | // thread as the request was made. This thread must have an active RunLoop. The |
| 22 | // request may be cancelled before completion by releasing the returned AsyncRequest. |
| 23 | // If the request is cancelled before the callback is executed, the callback will |
| 24 | // not be executed. |
| 25 | virtual std::unique_ptr<AsyncRequest> request(const Resource&, Callback) = 0; |
| 26 | |
| 27 | // When a file source supports consulting a local cache only, it must return true. |
| 28 | // Cache-only requests are requests that aren't as urgent, but could be useful, e.g. |
| 29 | // to cover part of the map while loading. The FileSource should only do cheap actions to |
| 30 | // retrieve the data, e.g. load it from a cache, but not from the internet. |
| 31 | virtual bool supportsCacheOnlyRequests() const { |
| 32 | return false; |
| 33 | } |
| 34 | }; |
| 35 | |
| 36 | } // namespace mbgl |
| 37 | |