dart
Uri.hpp
1 /*
2  * Copyright (c) 2011-2021, The DART development contributors
3  * All rights reserved.
4  *
5  * The list of contributors can be found at:
6  * https://github.com/dartsim/dart/blob/master/LICENSE
7  *
8  * This file is provided under the following "BSD-style" License:
9  * Redistribution and use in source and binary forms, with or
10  * without modification, are permitted provided that the following
11  * conditions are met:
12  * * Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  * * Redistributions in binary form must reproduce the above
15  * copyright notice, this list of conditions and the following
16  * disclaimer in the documentation and/or other materials provided
17  * with the distribution.
18  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
19  * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
20  * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
23  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
26  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
27  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30  * POSSIBILITY OF SUCH DAMAGE.
31  */
32 
33 #ifndef DART_COMMON_URI_HPP_
34 #define DART_COMMON_URI_HPP_
35 
36 #include <string>
37 
38 namespace dart {
39 namespace common {
40 
41 class UriComponent final
42 {
43 public:
44  using value_type = std::string;
45  using reference_type = value_type&;
46  using reference_const_type = const value_type&;
47  using pointer_type = value_type*;
48  using pointer_const_type = const value_type*;
49 
50  UriComponent();
51  UriComponent(reference_const_type _value);
52 
53  operator bool() const;
54 
55  bool operator!() const;
56 
57  UriComponent& operator=(reference_const_type _value);
58 
59  reference_type operator*();
60  reference_const_type operator*() const;
61 
62  pointer_type operator->();
63  pointer_const_type operator->() const;
64 
65  void assign(reference_const_type _value);
66  void reset();
67 
68  reference_type get();
69  reference_const_type get() const;
70 
71  reference_type get_value_or(reference_type _default);
72  reference_const_type get_value_or(reference_const_type _default) const;
73 
74 private:
75  bool mExists;
76  std::string mValue;
77 };
78 
86 struct Uri final
87 {
90 
93 
96 
99 
102 
104  Uri() = default;
105 
112  Uri(const std::string& _input);
113 
116  Uri(const char* _input);
117 
119  void clear();
120 
123  bool fromString(const std::string& _input);
124 
128  bool fromPath(const std::string& _path);
129 
133  bool fromStringOrPath(const std::string& _input);
134 
137  bool fromRelativeUri(
138  const std::string& _base,
139  const std::string& _relative,
140  bool _strict = false);
141 
144  bool fromRelativeUri(
145  const char* _base, const char* _relative, bool _strict = false);
146 
149  bool fromRelativeUri(
150  const Uri& _base, const std::string& _relative, bool _strict = false);
151 
154  bool fromRelativeUri(
155  const Uri& _base, const char* _relative, bool _strict = false);
156 
159  bool fromRelativeUri(
160  const Uri& _base, const Uri& _relative, bool _strict = false);
161 
163  std::string toString() const;
164 
166  static Uri createFromString(const std::string& _input);
167 
169  static Uri createFromPath(const std::string& _path);
170 
173  static Uri createFromStringOrPath(const std::string& _input);
174 
177  static Uri createFromRelativeUri(
178  const std::string& _base,
179  const std::string& _relative,
180  bool _strict = false);
181 
184  static Uri createFromRelativeUri(
185  const Uri& _base, const std::string& _relative, bool _strict = false);
186 
189  static Uri createFromRelativeUri(
190  const Uri& _base, const Uri& _relative, bool _strict = false);
191 
193  static std::string getUri(const std::string& _input);
194 
196  static std::string getRelativeUri(
197  const std::string& _base,
198  const std::string& _relative,
199  bool _strict = false);
200 
202  static std::string getRelativeUri(
203  const Uri& _base, const std::string& _relative, bool _strict = false);
204 
206  static std::string getRelativeUri(
207  const Uri& _base, const Uri& _relative, bool _strict = false);
208 
210  std::string getPath() const;
211 
216  std::string getFilesystemPath() const;
217 
218 private:
220  static std::string mergePaths(const Uri& _base, const Uri& _relative);
221 
223  static std::string removeDotSegments(const std::string& _path);
224 };
225 
226 } // namespace common
227 } // namespace dart
228 
229 #endif // ifndef DART_COMMON_URI_HPP_
UriComponent mFragment
Fragment, e.g. the part of the URI after the #.
Definition: Uri.hpp:101
UriComponent mPath
Path, e.g. &#39;/index.html&#39;, &#39;/foo/bar.txt&#39;.
Definition: Uri.hpp:95
Definition: Aspect.cpp:40
UriComponent mQuery
Query string, i.e. the part of the URI after the ?
Definition: Uri.hpp:98
UriComponent mAuthority
Authority, e.g. &#39;google.com&#39;, &#39;en.wikipedia.org&#39;.
Definition: Uri.hpp:92
UriComponent mScheme
Scheme, e.g. &#39;http&#39;, &#39;file&#39;, &#39;package&#39;.
Definition: Uri.hpp:89
The Uri struct provides URI parsing and merging functionality based on RFC 3986.
Definition: Uri.hpp:86
Definition: Uri.hpp:41