Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(235)

Side by Side Diff: mojo/shell/mojo_url_resolver.h

Issue 397733003: mojo: kill app_thread before unloading main app library and add tests (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: review + hack Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef MOJO_SHELL_MOJO_URL_RESOLVER_H_ 5 #ifndef MOJO_SHELL_MOJO_URL_RESOLVER_H_
6 #define MOJO_SHELL_MOJO_URL_RESOLVER_H_ 6 #define MOJO_SHELL_MOJO_URL_RESOLVER_H_
7 7
8 #include <map> 8 #include <map>
9 #include <set> 9 #include <set>
10 10
11 #include "url/gurl.h" 11 #include "url/gurl.h"
12 12
13 namespace mojo { 13 namespace mojo {
14 namespace shell { 14 namespace shell {
15 15
16 // This class resolves "mojo:" URLs to physical URLs (e.g., "file:" and 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 17 // "https:" URLs). By default, "mojo:" URLs resolve to a file location, but
18 // that resolution can be customized via the AddCustomMapping method. 18 // that resolution can be customized via the AddCustomMapping method.
19 class MojoURLResolver { 19 class MojoURLResolver {
20 public: 20 public:
21 MojoURLResolver(); 21 MojoURLResolver();
22 ~MojoURLResolver(); 22 ~MojoURLResolver();
23 23
24 // If specified, then unknown "mojo:" URLs will be resolved relative to this 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 25 // base URL. That is, the portion after the colon will be appeneded to
26 // with platform-specific shared library prefix and suffix inserted. 26 // |base_url| with platform-specific shared library prefix and suffix
27 void set_origin(const std::string& origin) { origin_ = origin; } 27 // inserted.
28 void SetBaseURL(const GURL& base_url);
28 29
29 // Add a custom mapping for a particular "mojo:" URL. 30 // Add a custom mapping for a particular "mojo:" URL.
30 void AddCustomMapping(const GURL& mojo_url, const GURL& resolved_url); 31 void AddCustomMapping(const GURL& mojo_url, const GURL& resolved_url);
31 32
32 // Add a local file mapping for a particular "mojo:" URL. This causes the 33 // 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 // "mojo:" URL to be resolved to an base::DIR_EXE-relative shared library.
34 void AddLocalFileMapping(const GURL& mojo_url); 35 void AddLocalFileMapping(const GURL& mojo_url);
35 36
36 // Resolve the given "mojo:" URL to the URL that should be used to fetch the 37 // Resolve the given "mojo:" URL to the URL that should be used to fetch the
37 // code for the corresponding Mojo App. 38 // code for the corresponding Mojo App.
38 GURL Resolve(const GURL& mojo_url) const; 39 GURL Resolve(const GURL& mojo_url) const;
39 40
40 private: 41 private:
41 std::map<GURL, GURL> url_map_; 42 std::map<GURL, GURL> url_map_;
42 std::set<GURL> local_file_set_; 43 std::set<GURL> local_file_set_;
43 std::string origin_; 44 GURL base_url_;
44 }; 45 };
45 46
46 } // namespace shell 47 } // namespace shell
47 } // namespace mojo 48 } // namespace mojo
48 49
49 #endif // MOJO_SHELL_MOJO_URL_RESOLVER_H_ 50 #endif // MOJO_SHELL_MOJO_URL_RESOLVER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698