[SyncFS] Build indexes from FileTracker entries on disk.
[chromium-blink-merge.git] / mojo / shell / mojo_url_resolver.h
blobd232a40703503105c5b32eba923f6f29ddba8600
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef MOJO_SHELL_MOJO_URL_RESOLVER_H_
6 #define MOJO_SHELL_MOJO_URL_RESOLVER_H_
8 #include <map>
9 #include <set>
11 #include "url/gurl.h"
13 namespace mojo {
14 namespace shell {
16 // This class resolves "mojo:" URLs to physical URLs (e.g., "file:" and
17 // "https:" URLs). By default, "mojo:" URLs resolve to a file location, but
18 // that resolution can be customized via the AddCustomMapping method.
19 class MojoURLResolver {
20 public:
21 MojoURLResolver();
22 ~MojoURLResolver();
24 // If specified, then unknown "mojo:" URLs will be resolved relative to this
25 // origin. That is, the portion after the colon will be appeneded to origin
26 // with platform-specific shared library prefix and suffix inserted.
27 void set_origin(const std::string& origin) { origin_ = origin; }
29 // Add a custom mapping for a particular "mojo:" URL.
30 void AddCustomMapping(const GURL& mojo_url, const GURL& resolved_url);
32 // Add a local file mapping for a particular "mojo:" URL. This causes the
33 // "mojo:" URL to be resolved to an base::DIR_EXE-relative shared library.
34 void AddLocalFileMapping(const GURL& mojo_url);
36 // Resolve the given "mojo:" URL to the URL that should be used to fetch the
37 // code for the corresponding Mojo App.
38 GURL Resolve(const GURL& mojo_url) const;
40 private:
41 std::map<GURL, GURL> url_map_;
42 std::set<GURL> local_file_set_;
43 std::string origin_;
46 } // namespace shell
47 } // namespace mojo
49 #endif // MOJO_SHELL_MOJO_URL_RESOLVER_H_