| Index: mojo/runner/url_resolver.h
|
| diff --git a/mojo/runner/url_resolver.h b/mojo/runner/url_resolver.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..b34e854a474de93b989b164e6d2e73729ddc0e7e
|
| --- /dev/null
|
| +++ b/mojo/runner/url_resolver.h
|
| @@ -0,0 +1,81 @@
|
| +// Copyright 2014 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef MOJO_RUNNER_URL_RESOLVER_H_
|
| +#define MOJO_RUNNER_URL_RESOLVER_H_
|
| +
|
| +#include <map>
|
| +#include <set>
|
| +
|
| +#include "base/basictypes.h"
|
| +#include "base/command_line.h"
|
| +#include "base/files/file_path.h"
|
| +#include "url/gurl.h"
|
| +
|
| +namespace mojo {
|
| +namespace runner {
|
| +
|
| +// This class supports the mapping of URLs to other URLs.
|
| +// It's commonly used with mojo: URL, to provide a physical location URL
|
| +// (i.e. file: or https:) but works with any URL.
|
| +// By default, "mojo:" URLs resolve to a file location, with ".mojo" appended,
|
| +// but that resolution can be customized via the AddURLMapping and
|
| +// AddOriginMapping methods.
|
| +class URLResolver {
|
| + public:
|
| + URLResolver();
|
| + ~URLResolver();
|
| +
|
| + // Used for the return value of GetOriginMappings().
|
| + struct OriginMapping {
|
| + OriginMapping(const std::string& origin, const std::string& base_url)
|
| + : origin(origin), base_url(base_url) {}
|
| +
|
| + std::string origin;
|
| + std::string base_url;
|
| + };
|
| +
|
| + // Returns a list of origin mappings based on command line args.
|
| + // The switch --map-origin can be specified multiple times. Each occurrence
|
| + // has the format of --map-origin={origin}={base_url}
|
| + // For example:
|
| + // --map-origin=http://domokit.org=file:///source/out
|
| + static std::vector<OriginMapping> GetOriginMappings(
|
| + const base::CommandLine::StringVector& argv);
|
| +
|
| + // Add a custom mapping for a particular URL. If |mapped_url| is
|
| + // itself a mojo URL, then normal resolution rules apply.
|
| + void AddURLMapping(const GURL& url, const GURL& mapped_url);
|
| +
|
| + // Add a custom mapping for all URLs rooted at |origin|. An origin is a
|
| + // combination of URL scheme, host and port.
|
| + void AddOriginMapping(const GURL& origin, const GURL& base_url);
|
| +
|
| + // Applies all custom mappings for |url|, returning the last non-mapped url.
|
| + // For example, if 'a' maps to 'b' and 'b' maps to 'c', calling this with 'a'
|
| + // returns 'c'.
|
| + GURL ApplyMappings(const GURL& url) const;
|
| +
|
| + // If specified, then "mojo:" URLs will be resolved relative to this
|
| + // URL. That is, the portion after the colon will be appended to
|
| + // |mojo_base_url| with .mojo appended.
|
| + void SetMojoBaseURL(const GURL& mojo_base_url);
|
| +
|
| + // Resolve the given "mojo:" URL to the URL that should be used to fetch the
|
| + // code for the corresponding Mojo App.
|
| + GURL ResolveMojoURL(const GURL& mojo_url) const;
|
| +
|
| + private:
|
| + using GURLToGURLMap = std::map<GURL, GURL>;
|
| + GURLToGURLMap url_map_;
|
| + GURLToGURLMap origin_map_;
|
| + GURL mojo_base_url_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(URLResolver);
|
| +};
|
| +
|
| +} // namespace runner
|
| +} // namespace mojo
|
| +
|
| +#endif // MOJO_RUNNER_URL_RESOLVER_H_
|
|
|