Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2009 Google Inc. All rights reserved. | 2 * Copyright (C) 2009 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 29 */ | 29 */ |
| 30 | 30 |
| 31 #ifndef WebURL_h | 31 #ifndef WebURL_h |
| 32 #define WebURL_h | 32 #define WebURL_h |
| 33 | 33 |
| 34 #include "WebCString.h" | 34 #include "WebCString.h" |
| 35 #include "WebString.h" | |
| 35 #include <url/url_parse.h> | 36 #include <url/url_parse.h> |
| 36 | 37 |
| 37 #if WEBKIT_IMPLEMENTATION | 38 #if WEBKIT_IMPLEMENTATION |
| 38 namespace WebCore { class KURL; } | 39 namespace WebCore { class KURL; } |
| 39 #else | 40 #else |
| 40 #include <url/gurl.h> | 41 #include <url/gurl.h> |
| 41 #endif | 42 #endif |
| 42 | 43 |
| 43 namespace WebKit { | 44 namespace WebKit { |
| 44 | 45 |
| 45 class WebURL { | 46 class WebURL { |
| 46 public: | 47 public: |
| 47 ~WebURL() | 48 ~WebURL() |
| 48 { | 49 { |
| 49 } | 50 } |
| 50 | 51 |
| 51 WebURL() : m_isValid(false) | 52 WebURL() |
| 53 : m_isValid(false) | |
| 52 { | 54 { |
| 53 } | 55 } |
| 54 | 56 |
| 55 WebURL(const WebCString& spec, const url_parse::Parsed& parsed, bool isValid ) | 57 WebURL(const WebURL& url) |
| 56 : m_spec(spec) | 58 : m_string(url.m_string) |
| 57 , m_parsed(parsed) | 59 , m_parsed(url.m_parsed) |
| 58 , m_isValid(isValid) | 60 , m_isValid(url.m_isValid) |
| 59 { | 61 { |
| 60 } | 62 } |
| 61 | 63 |
| 62 WebURL(const WebURL& s) | 64 WebURL& operator=(const WebURL& url) |
| 63 : m_spec(s.m_spec) | |
| 64 , m_parsed(s.m_parsed) | |
| 65 , m_isValid(s.m_isValid) | |
| 66 { | 65 { |
| 67 } | 66 m_string = url.m_string; |
| 68 | 67 m_parsed = url.m_parsed; |
| 69 WebURL& operator=(const WebURL& s) | 68 m_isValid = url.m_isValid; |
| 70 { | |
| 71 m_spec = s.m_spec; | |
| 72 m_parsed = s.m_parsed; | |
| 73 m_isValid = s.m_isValid; | |
| 74 return *this; | 69 return *this; |
| 75 } | 70 } |
| 76 | 71 |
| 77 void assign(const WebCString& spec, const url_parse::Parsed& parsed, bool is Valid) | 72 WebCString spec() const |
| 78 { | 73 { |
| 79 m_spec = spec; | 74 return m_string.utf8(); |
| 80 m_parsed = parsed; | |
| 81 m_isValid = isValid; | |
| 82 } | 75 } |
| 83 | 76 |
| 84 const WebCString& spec() const | 77 const WebString& string() const |
| 85 { | 78 { |
| 86 return m_spec; | 79 return m_string; |
| 87 } | 80 } |
| 88 | 81 |
| 89 const url_parse::Parsed& parsed() const | 82 const url_parse::Parsed& parsed() const |
| 90 { | 83 { |
| 91 return m_parsed; | 84 return m_parsed; |
| 92 } | 85 } |
| 93 | 86 |
| 94 bool isValid() const | 87 bool isValid() const |
| 95 { | 88 { |
| 96 return m_isValid; | 89 return m_isValid; |
| 97 } | 90 } |
| 98 | 91 |
| 99 bool isEmpty() const | 92 bool isEmpty() const |
| 100 { | 93 { |
| 101 return m_spec.isEmpty(); | 94 return m_string.isEmpty(); |
| 102 } | 95 } |
| 103 | 96 |
| 104 bool isNull() const | 97 bool isNull() const |
| 105 { | 98 { |
| 106 return m_spec.isEmpty(); | 99 return m_string.isEmpty(); |
| 107 } | 100 } |
| 108 | 101 |
| 109 #if WEBKIT_IMPLEMENTATION | 102 #if WEBKIT_IMPLEMENTATION |
| 110 WebURL(const WebCore::KURL&); | 103 WebURL(const WebCore::KURL&); |
| 111 WebURL& operator=(const WebCore::KURL&); | 104 WebURL& operator=(const WebCore::KURL&); |
| 112 operator WebCore::KURL() const; | 105 operator WebCore::KURL() const; |
| 113 #else | 106 #else |
| 114 WebURL(const GURL& g) | 107 WebURL(const GURL& url) |
| 115 : m_spec(g.possibly_invalid_spec()) | 108 : m_string(WebString::fromUTF8(url.possibly_invalid_spec())) |
| 116 , m_parsed(g.parsed_for_possibly_invalid_spec()) | 109 , m_parsed(url.parsed_for_possibly_invalid_spec()) |
| 117 , m_isValid(g.is_valid()) | 110 , m_isValid(url.is_valid()) |
| 118 { | 111 { |
| 119 } | 112 } |
| 120 | 113 |
| 121 WebURL& operator=(const GURL& g) | 114 WebURL& operator=(const GURL& url) |
| 122 { | 115 { |
| 123 m_spec = g.possibly_invalid_spec(); | 116 m_string = WebString::fromUTF8(url.possibly_invalid_spec()); |
| 124 m_parsed = g.parsed_for_possibly_invalid_spec(); | 117 m_parsed = url.parsed_for_possibly_invalid_spec(); |
| 125 m_isValid = g.is_valid(); | 118 m_isValid = url.is_valid(); |
| 126 return *this; | 119 return *this; |
| 127 } | 120 } |
| 128 | 121 |
| 129 operator GURL() const | 122 operator GURL() const |
| 130 { | 123 { |
| 131 return isNull() ? GURL() : GURL(m_spec.data(), m_spec.length(), m_parsed , m_isValid); | 124 return isNull() ? GURL() : GURL(m_string.toUTF8String(), m_parsed, m_isV alid); |
|
Jeffrey Yasskin
2013/07/24 21:23:51
In order to avoid a copy here, you need to use a G
abarth-chromium
2013/07/24 21:57:34
Sorry for not cross-linking the CLs. The CL that
| |
| 132 } | 125 } |
| 133 #endif | 126 #endif |
| 134 | 127 |
| 135 private: | 128 private: |
| 136 WebCString m_spec; // UTF-8 encoded | 129 WebString m_string; |
| 137 url_parse::Parsed m_parsed; | 130 url_parse::Parsed m_parsed; |
| 138 bool m_isValid; | 131 bool m_isValid; |
| 139 }; | 132 }; |
| 140 | 133 |
| 141 inline bool operator<(const WebURL& a, const WebURL& b) | 134 inline bool operator<(const WebURL& a, const WebURL& b) |
| 142 { | 135 { |
| 143 return a.spec() < b.spec(); | 136 return a.string() < b.string(); |
| 144 } | 137 } |
| 145 | 138 |
| 146 inline bool operator==(const WebURL& a, const WebURL& b) | 139 inline bool operator==(const WebURL& a, const WebURL& b) |
| 147 { | 140 { |
| 148 return !a.spec().compare(b.spec()); | 141 return !a.string().equals(b.string()); |
|
Jeffrey Yasskin
2013/07/24 21:23:51
s/!//, right?
abarth-chromium
2013/07/24 21:57:34
Yes! :)
| |
| 149 } | 142 } |
| 150 | 143 |
| 151 inline bool operator!=(const WebURL& a, const WebURL& b) | 144 inline bool operator!=(const WebURL& a, const WebURL& b) |
| 152 { | 145 { |
| 153 return !(a == b); | 146 return !(a == b); |
| 154 } | 147 } |
| 155 | 148 |
| 156 } // namespace WebKit | 149 } // namespace WebKit |
| 157 | 150 |
| 158 #endif | 151 #endif |
| OLD | NEW |