1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 // Functions for canonicalizing "mailto:" URLs.
7 #include "url/url_canon.h"
8 #include "url/url_canon_internal.h"
9 #include "url/url_file.h"
10 #include "url/url_parse_internal.h"
17 template<typename CHAR
, typename UCHAR
>
18 bool DoCanonicalizeMailtoURL(const URLComponentSource
<CHAR
>& source
,
19 const url_parse::Parsed
& parsed
,
21 url_parse::Parsed
* new_parsed
) {
23 // mailto: only uses {scheme, path, query} -- clear the rest.
24 new_parsed
->username
= url_parse::Component();
25 new_parsed
->password
= url_parse::Component();
26 new_parsed
->host
= url_parse::Component();
27 new_parsed
->port
= url_parse::Component();
28 new_parsed
->ref
= url_parse::Component();
30 // Scheme (known, so we don't bother running it through the more
31 // complicated scheme canonicalizer).
32 new_parsed
->scheme
.begin
= output
->length();
33 output
->Append("mailto:", 7);
34 new_parsed
->scheme
.len
= 6;
39 if (parsed
.path
.is_valid()) {
40 new_parsed
->path
.begin
= output
->length();
42 // Copy the path using path URL's more lax escaping rules.
43 // We convert to UTF-8 and escape non-ASCII, but leave all
44 // ASCII characters alone.
45 int end
= parsed
.path
.end();
46 for (int i
= parsed
.path
.begin
; i
< end
; ++i
) {
47 UCHAR uch
= static_cast<UCHAR
>(source
.path
[i
]);
48 if (uch
< 0x20 || uch
>= 0x80)
49 success
&= AppendUTF8EscapedChar(source
.path
, &i
, end
, output
);
51 output
->push_back(static_cast<char>(uch
));
54 new_parsed
->path
.len
= output
->length() - new_parsed
->path
.begin
;
57 new_parsed
->path
.reset();
60 // Query -- always use the default utf8 charset converter.
61 CanonicalizeQuery(source
.query
, parsed
.query
, NULL
,
62 output
, &new_parsed
->query
);
69 bool CanonicalizeMailtoURL(const char* spec
,
71 const url_parse::Parsed
& parsed
,
73 url_parse::Parsed
* new_parsed
) {
74 return DoCanonicalizeMailtoURL
<char, unsigned char>(
75 URLComponentSource
<char>(spec
), parsed
, output
, new_parsed
);
78 bool CanonicalizeMailtoURL(const base::char16
* spec
,
80 const url_parse::Parsed
& parsed
,
82 url_parse::Parsed
* new_parsed
) {
83 return DoCanonicalizeMailtoURL
<base::char16
, base::char16
>(
84 URLComponentSource
<base::char16
>(spec
), parsed
, output
, new_parsed
);
87 bool ReplaceMailtoURL(const char* base
,
88 const url_parse::Parsed
& base_parsed
,
89 const Replacements
<char>& replacements
,
91 url_parse::Parsed
* new_parsed
) {
92 URLComponentSource
<char> source(base
);
93 url_parse::Parsed
parsed(base_parsed
);
94 SetupOverrideComponents(base
, replacements
, &source
, &parsed
);
95 return DoCanonicalizeMailtoURL
<char, unsigned char>(
96 source
, parsed
, output
, new_parsed
);
99 bool ReplaceMailtoURL(const char* base
,
100 const url_parse::Parsed
& base_parsed
,
101 const Replacements
<base::char16
>& replacements
,
103 url_parse::Parsed
* new_parsed
) {
104 RawCanonOutput
<1024> utf8
;
105 URLComponentSource
<char> source(base
);
106 url_parse::Parsed
parsed(base_parsed
);
107 SetupUTF16OverrideComponents(base
, replacements
, &utf8
, &source
, &parsed
);
108 return DoCanonicalizeMailtoURL
<char, unsigned char>(
109 source
, parsed
, output
, new_parsed
);
112 } // namespace url_canon