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

Side by Side Diff: chrome/browser/extensions/convert_user_script.cc

Issue 8890086: Issue 71980: Extensions code should use UTF-16 for user-visible Unicode strings (Closed) Base URL: http://src.chromium.org/svn/trunk/src/
Patch Set: '' Created 9 years 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
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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 "chrome/browser/extensions/convert_user_script.h" 5 #include "chrome/browser/extensions/convert_user_script.h"
6 6
7 #include <string> 7 #include <string>
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/base64.h" 10 #include "base/base64.h"
11 #include "base/file_path.h" 11 #include "base/file_path.h"
12 #include "base/file_util.h" 12 #include "base/file_util.h"
13 #include "base/json/json_value_serializer.h" 13 #include "base/json/json_value_serializer.h"
14 #include "base/path_service.h" 14 #include "base/path_service.h"
15 #include "base/scoped_temp_dir.h" 15 #include "base/scoped_temp_dir.h"
16 #include "base/string_util.h" 16 #include "base/string_util.h"
17 #include "base/utf_string_conversions.h"
17 #include "chrome/browser/extensions/user_script_master.h" 18 #include "chrome/browser/extensions/user_script_master.h"
18 #include "chrome/common/chrome_paths.h" 19 #include "chrome/common/chrome_paths.h"
19 #include "chrome/common/extensions/extension.h" 20 #include "chrome/common/extensions/extension.h"
20 #include "chrome/common/extensions/extension_constants.h" 21 #include "chrome/common/extensions/extension_constants.h"
21 #include "chrome/common/extensions/extension_file_util.h" 22 #include "chrome/common/extensions/extension_file_util.h"
22 #include "chrome/common/extensions/user_script.h" 23 #include "chrome/common/extensions/user_script.h"
23 #include "crypto/sha2.h" 24 #include "crypto/sha2.h"
24 #include "googleurl/src/gurl.h" 25 #include "googleurl/src/gurl.h"
25 26
26 namespace keys = extension_manifest_keys; 27 namespace keys = extension_manifest_keys;
27 namespace values = extension_manifest_values; 28 namespace values = extension_manifest_values;
28 29
29 scoped_refptr<Extension> ConvertUserScriptToExtension( 30 scoped_refptr<Extension> ConvertUserScriptToExtension(
30 const FilePath& user_script_path, const GURL& original_url, 31 const FilePath& user_script_path, const GURL& original_url,
31 std::string* error) { 32 string16* error) {
32 std::string content; 33 std::string content;
33 if (!file_util::ReadFileToString(user_script_path, &content)) { 34 if (!file_util::ReadFileToString(user_script_path, &content)) {
34 *error = "Could not read source file."; 35 *error = ASCIIToUTF16("Could not read source file.");
35 return NULL; 36 return NULL;
36 } 37 }
37 38
38 if (!IsStringUTF8(content)) { 39 if (!IsStringUTF8(content)) {
39 *error = "User script must be UTF8 encoded."; 40 *error = ASCIIToUTF16("User script must be UTF8 encoded.");
40 return NULL; 41 return NULL;
41 } 42 }
42 43
43 UserScript script; 44 UserScript script;
44 if (!UserScriptMaster::ScriptReloader::ParseMetadataHeader(content, 45 if (!UserScriptMaster::ScriptReloader::ParseMetadataHeader(content,
45 &script)) { 46 &script)) {
46 *error = "Invalid script header."; 47 *error = ASCIIToUTF16("Invalid script header.");
47 return NULL; 48 return NULL;
48 } 49 }
49 50
50 FilePath user_data_temp_dir = extension_file_util::GetUserDataTempDir(); 51 FilePath user_data_temp_dir = extension_file_util::GetUserDataTempDir();
51 if (user_data_temp_dir.empty()) { 52 if (user_data_temp_dir.empty()) {
52 *error = "Could not get path to profile temporary directory."; 53 *error = ASCIIToUTF16("Could not get path to profile temporary directory.");
53 return NULL; 54 return NULL;
54 } 55 }
55 56
56 ScopedTempDir temp_dir; 57 ScopedTempDir temp_dir;
57 if (!temp_dir.CreateUniqueTempDirUnderPath(user_data_temp_dir)) { 58 if (!temp_dir.CreateUniqueTempDirUnderPath(user_data_temp_dir)) {
58 *error = "Could not create temporary directory."; 59 *error = ASCIIToUTF16("Could not create temporary directory.");
59 return NULL; 60 return NULL;
60 } 61 }
61 62
62 // Create the manifest 63 // Create the manifest
63 scoped_ptr<DictionaryValue> root(new DictionaryValue); 64 scoped_ptr<DictionaryValue> root(new DictionaryValue);
64 std::string script_name; 65 std::string script_name;
65 if (!script.name().empty() && !script.name_space().empty()) 66 if (!script.name().empty() && !script.name_space().empty())
66 script_name = script.name_space() + "/" + script.name(); 67 script_name = script.name_space() + "/" + script.name();
67 else 68 else
68 script_name = original_url.spec(); 69 script_name = original_url.spec();
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after
137 138
138 ListValue* content_scripts = new ListValue(); 139 ListValue* content_scripts = new ListValue();
139 content_scripts->Append(content_script); 140 content_scripts->Append(content_script);
140 141
141 root->Set(keys::kContentScripts, content_scripts); 142 root->Set(keys::kContentScripts, content_scripts);
142 143
143 FilePath manifest_path = temp_dir.path().Append( 144 FilePath manifest_path = temp_dir.path().Append(
144 Extension::kManifestFilename); 145 Extension::kManifestFilename);
145 JSONFileValueSerializer serializer(manifest_path); 146 JSONFileValueSerializer serializer(manifest_path);
146 if (!serializer.Serialize(*root)) { 147 if (!serializer.Serialize(*root)) {
147 *error = "Could not write JSON."; 148 *error = ASCIIToUTF16("Could not write JSON.");
148 return NULL; 149 return NULL;
149 } 150 }
150 151
151 // Write the script file. 152 // Write the script file.
152 if (!file_util::CopyFile(user_script_path, 153 if (!file_util::CopyFile(user_script_path,
153 temp_dir.path().AppendASCII("script.js"))) { 154 temp_dir.path().AppendASCII("script.js"))) {
154 *error = "Could not copy script file."; 155 *error = ASCIIToUTF16("Could not copy script file.");
155 return NULL; 156 return NULL;
156 } 157 }
157 158
159 // TODO(rdevlin.cronin): Continue removing std::string errors and replacing
160 // with string16
161 std::string utf8_error;
158 scoped_refptr<Extension> extension = Extension::Create( 162 scoped_refptr<Extension> extension = Extension::Create(
159 temp_dir.path(), 163 temp_dir.path(),
160 Extension::INTERNAL, 164 Extension::INTERNAL,
161 *root, 165 *root,
162 Extension::NO_FLAGS, 166 Extension::NO_FLAGS,
163 error); 167 &utf8_error);
168 *error = UTF8ToUTF16(utf8_error);
164 if (!extension) { 169 if (!extension) {
165 NOTREACHED() << "Could not init extension " << *error; 170 NOTREACHED() << "Could not init extension " << *error;
166 return NULL; 171 return NULL;
167 } 172 }
168 173
169 temp_dir.Take(); // The caller takes ownership of the directory. 174 temp_dir.Take(); // The caller takes ownership of the directory.
170 return extension; 175 return extension;
171 } 176 }
OLDNEW
« no previous file with comments | « chrome/browser/extensions/convert_user_script.h ('k') | chrome/browser/extensions/convert_user_script_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698