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

Side by Side Diff: net/base/escape.cc

Issue 543077: The search terms are escaped using + or %20 for space depending on whether re... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 10 years, 11 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
« no previous file with comments | « net/base/escape.h ('k') | net/base/escape_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 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 #include <algorithm> 5 #include <algorithm>
6 6
7 #include "net/base/escape.h" 7 #include "net/base/escape.h"
8 8
9 #include "base/i18n/icu_string_conversions.h" 9 #include "base/i18n/icu_string_conversions.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
(...skipping 172 matching lines...) Expand 10 before | Expand all | Expand 10 after
183 // Everything except alphanumerics and !'()*-._~ 183 // Everything except alphanumerics and !'()*-._~
184 // See RFC 2396 for the list of reserved characters. 184 // See RFC 2396 for the list of reserved characters.
185 static const Charmap kQueryCharmap( 185 static const Charmap kQueryCharmap(
186 0xffffffffL, 0xfc00987dL, 0x78000001L, 0xb8000001L, 186 0xffffffffL, 0xfc00987dL, 0x78000001L, 0xb8000001L,
187 0xffffffffL, 0xffffffffL, 0xffffffffL, 0xffffffffL); 187 0xffffffffL, 0xffffffffL, 0xffffffffL, 0xffffffffL);
188 188
189 std::string EscapeQueryParamValue(const std::string& text, bool use_plus) { 189 std::string EscapeQueryParamValue(const std::string& text, bool use_plus) {
190 return Escape(text, kQueryCharmap, use_plus); 190 return Escape(text, kQueryCharmap, use_plus);
191 } 191 }
192 192
193 std::string EscapeQueryParamValue(const std::string& text) {
194 return Escape(text, kQueryCharmap, true);
195 }
196
197 // Convert the string to a sequence of bytes and then % escape anything 193 // Convert the string to a sequence of bytes and then % escape anything
198 // except alphanumerics and !'()*-._~ 194 // except alphanumerics and !'()*-._~
199 std::wstring EscapeQueryParamValueUTF8(const std::wstring& text) { 195 std::wstring EscapeQueryParamValueUTF8(const std::wstring& text,
200 return UTF8ToWide(Escape(WideToUTF8(text), kQueryCharmap, true)); 196 bool use_plus) {
197 return UTF8ToWide(Escape(WideToUTF8(text), kQueryCharmap, use_plus));
201 } 198 }
202 199
203 // non-printable, non-7bit, and (including space) "#%:<>?[\]^`{|} 200 // non-printable, non-7bit, and (including space) "#%:<>?[\]^`{|}
204 static const Charmap kPathCharmap( 201 static const Charmap kPathCharmap(
205 0xffffffffL, 0xd400002dL, 0x78000000L, 0xb8000001L, 202 0xffffffffL, 0xd400002dL, 0x78000000L, 0xb8000001L,
206 0xffffffffL, 0xffffffffL, 0xffffffffL, 0xffffffffL); 203 0xffffffffL, 0xffffffffL, 0xffffffffL, 0xffffffffL);
207 204
208 std::string EscapePath(const std::string& path) { 205 std::string EscapePath(const std::string& path) {
209 return Escape(path, kPathCharmap, false); 206 return Escape(path, kPathCharmap, false);
210 } 207 }
(...skipping 21 matching lines...) Expand all
232 // !'()*-._~% 229 // !'()*-._~%
233 static const Charmap kExternalHandlerCharmap( 230 static const Charmap kExternalHandlerCharmap(
234 0xffffffffL, 0x5000080dL, 0x68000000L, 0xb8000001L, 231 0xffffffffL, 0x5000080dL, 0x68000000L, 0xb8000001L,
235 0xffffffffL, 0xffffffffL, 0xffffffffL, 0xffffffffL); 232 0xffffffffL, 0xffffffffL, 0xffffffffL, 0xffffffffL);
236 233
237 std::string EscapeExternalHandlerValue(const std::string& text) { 234 std::string EscapeExternalHandlerValue(const std::string& text) {
238 return Escape(text, kExternalHandlerCharmap, false); 235 return Escape(text, kExternalHandlerCharmap, false);
239 } 236 }
240 237
241 bool EscapeQueryParamValue(const string16& text, const char* codepage, 238 bool EscapeQueryParamValue(const string16& text, const char* codepage,
242 string16* escaped) { 239 bool use_plus, string16* escaped) {
243 // TODO(brettw) bug 1201094: this function should be removed, this "SKIP" 240 // TODO(brettw) bug 1201094: this function should be removed, this "SKIP"
244 // behavior is wrong when the character can't be encoded properly. 241 // behavior is wrong when the character can't be encoded properly.
245 std::string encoded; 242 std::string encoded;
246 if (!base::UTF16ToCodepage(text, codepage, 243 if (!base::UTF16ToCodepage(text, codepage,
247 base::OnStringConversionError::SKIP, &encoded)) 244 base::OnStringConversionError::SKIP, &encoded))
248 return false; 245 return false;
249 246
250 escaped->assign(UTF8ToUTF16(Escape(encoded, kQueryCharmap, true))); 247 escaped->assign(UTF8ToUTF16(Escape(encoded, kQueryCharmap, use_plus)));
251 return true; 248 return true;
252 } 249 }
253 250
254 string16 UnescapeAndDecodeUTF8URLComponent(const std::string& text, 251 string16 UnescapeAndDecodeUTF8URLComponent(const std::string& text,
255 UnescapeRule::Type rules, 252 UnescapeRule::Type rules,
256 size_t* offset_for_adjustment) { 253 size_t* offset_for_adjustment) {
257 std::wstring result; 254 std::wstring result;
258 size_t original_offset = offset_for_adjustment ? *offset_for_adjustment : 0; 255 size_t original_offset = offset_for_adjustment ? *offset_for_adjustment : 0;
259 std::string unescaped_url( 256 std::string unescaped_url(
260 UnescapeURLImpl(text, rules, offset_for_adjustment)); 257 UnescapeURLImpl(text, rules, offset_for_adjustment));
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after
319 return result; 316 return result;
320 } 317 }
321 318
322 std::string EscapeForHTML(const std::string& input) { 319 std::string EscapeForHTML(const std::string& input) {
323 return EscapeForHTMLImpl(input); 320 return EscapeForHTMLImpl(input);
324 } 321 }
325 322
326 string16 EscapeForHTML(const string16& input) { 323 string16 EscapeForHTML(const string16& input) {
327 return EscapeForHTMLImpl(input); 324 return EscapeForHTMLImpl(input);
328 } 325 }
OLDNEW
« no previous file with comments | « net/base/escape.h ('k') | net/base/escape_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698