OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 // NOTE: based loosely on mozilla's nsDataChannel.cpp | 5 // NOTE: based loosely on mozilla's nsDataChannel.cpp |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "net/base/data_url.h" | 9 #include "net/base/data_url.h" |
10 | 10 |
11 #include "base/base64.h" | 11 #include "base/base64.h" |
12 #include "base/basictypes.h" | 12 #include "base/basictypes.h" |
13 #include "base/strings/string_split.h" | 13 #include "base/strings/string_split.h" |
14 #include "base/strings/string_util.h" | 14 #include "base/strings/string_util.h" |
15 #include "net/base/escape.h" | 15 #include "net/base/escape.h" |
16 #include "net/base/mime_util.h" | 16 #include "net/base/mime_util.h" |
17 #include "url/gurl.h" | 17 #include "url/gurl.h" |
18 | 18 |
19 namespace net { | 19 namespace net { |
20 | 20 |
21 // static | 21 // static |
22 bool DataURL::Parse(const GURL& url, std::string* mime_type, | 22 bool DataURL::Parse(const GURL& url, std::string* mime_type, |
23 std::string* charset, std::string* data) { | 23 std::string* charset, std::string* data) { |
24 DCHECK(mime_type->empty()); | 24 DCHECK(mime_type->empty()); |
25 DCHECK(charset->empty()); | 25 DCHECK(charset->empty()); |
26 std::string::const_iterator begin = url.spec().begin(); | |
27 std::string::const_iterator end = url.spec().end(); | |
28 | 26 |
29 std::string::const_iterator after_colon = std::find(begin, end, ':'); | 27 if (!url.SchemeIs("data")) |
asanka
2014/06/16 17:45:48
Make this a DCHECK instead.
Erik Dahlström (inactive)
2014/06/17 13:10:21
Done.
| |
30 if (after_colon == end) | |
31 return false; | 28 return false; |
32 ++after_colon; | |
33 | 29 |
34 std::string::const_iterator comma = std::find(after_colon, end, ','); | 30 const std::string path = url.path(); |
31 std::string::const_iterator begin = path.begin(); | |
32 std::string::const_iterator end = path.end(); | |
33 | |
34 std::string::const_iterator comma = std::find(begin, end, ','); | |
35 if (comma == end) | 35 if (comma == end) |
36 return false; | 36 return false; |
37 | 37 |
38 std::vector<std::string> meta_data; | 38 std::vector<std::string> meta_data; |
39 std::string unparsed_meta_data(after_colon, comma); | 39 std::string unparsed_meta_data(begin, comma); |
40 base::SplitString(unparsed_meta_data, ';', &meta_data); | 40 base::SplitString(unparsed_meta_data, ';', &meta_data); |
41 | 41 |
42 std::vector<std::string>::iterator iter = meta_data.begin(); | 42 std::vector<std::string>::iterator iter = meta_data.begin(); |
43 if (iter != meta_data.end()) { | 43 if (iter != meta_data.end()) { |
44 mime_type->swap(*iter); | 44 mime_type->swap(*iter); |
45 StringToLowerASCII(mime_type); | 45 StringToLowerASCII(mime_type); |
46 ++iter; | 46 ++iter; |
47 } | 47 } |
48 | 48 |
49 static const char kBase64Tag[] = "base64"; | 49 static const char kBase64Tag[] = "base64"; |
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
118 temp_data.resize(length + padding_needed, '='); | 118 temp_data.resize(length + padding_needed, '='); |
119 } | 119 } |
120 return base::Base64Decode(temp_data, data); | 120 return base::Base64Decode(temp_data, data); |
121 } | 121 } |
122 | 122 |
123 temp_data.swap(*data); | 123 temp_data.swap(*data); |
124 return true; | 124 return true; |
125 } | 125 } |
126 | 126 |
127 } // namespace net | 127 } // namespace net |
OLD | NEW |