Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "content/browser/download/save_package.h" | 5 #include "content/browser/download/save_package.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/file_path.h" | 9 #include "base/file_path.h" |
| 10 #include "base/file_util.h" | 10 #include "base/file_util.h" |
| (...skipping 353 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 364 pure_file_name->clear(); | 364 pure_file_name->clear(); |
| 365 return false; | 365 return false; |
| 366 } | 366 } |
| 367 | 367 |
| 368 // Generate name for saving resource. | 368 // Generate name for saving resource. |
| 369 bool SavePackage::GenerateFileName(const std::string& disposition, | 369 bool SavePackage::GenerateFileName(const std::string& disposition, |
| 370 const GURL& url, | 370 const GURL& url, |
| 371 bool need_html_ext, | 371 bool need_html_ext, |
| 372 FilePath::StringType* generated_name) { | 372 FilePath::StringType* generated_name) { |
| 373 // TODO(jungshik): Figure out the referrer charset when having one | 373 // TODO(jungshik): Figure out the referrer charset when having one |
| 374 // makes sense and pass it to GetSuggestedFilename. | 374 // makes sense and pass it to GenerateFileName. |
| 375 string16 suggested_name = | 375 FilePath file_path = net::GenerateFileName(url, disposition, "", "", "", |
| 376 net::GetSuggestedFilename(url, disposition, "", "", | 376 ASCIIToUTF16(kDefaultSaveName)); |
| 377 ASCIIToUTF16(kDefaultSaveName)); | |
| 378 | |
| 379 // TODO(evan): this code is totally wrong -- we should just generate | |
| 380 // Unicode filenames and do all this encoding switching at the end. | |
| 381 // However, I'm just shuffling wrong code around, at least not adding | |
| 382 // to it. | |
| 383 #if defined(OS_WIN) | |
| 384 FilePath file_path = FilePath(suggested_name); | |
| 385 #else | |
| 386 FilePath file_path = FilePath( | |
| 387 base::SysWideToNativeMB(UTF16ToWide(suggested_name))); | |
| 388 #endif | |
| 389 | 377 |
| 390 DCHECK(!file_path.empty()); | 378 DCHECK(!file_path.empty()); |
| 391 FilePath::StringType pure_file_name = | 379 FilePath::StringType pure_file_name = |
| 392 file_path.RemoveExtension().BaseName().value(); | 380 file_path.RemoveExtension().BaseName().value(); |
| 393 FilePath::StringType file_name_ext = file_path.Extension(); | 381 FilePath::StringType file_name_ext = file_path.Extension(); |
| 394 | 382 |
| 395 // If it is HTML resource, use ".htm{l,}" as its extension. | 383 // If it is HTML resource, use ".htm{l,}" as its extension. |
| 396 if (need_html_ext) { | 384 if (need_html_ext) { |
| 397 file_name_ext = FILE_PATH_LITERAL("."); | 385 file_name_ext = FILE_PATH_LITERAL("."); |
| 398 file_name_ext.append(kDefaultHtmlExtension); | 386 file_name_ext.append(kDefaultHtmlExtension); |
| (...skipping 872 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1271 | 1259 |
| 1272 content::GetContentClient()->browser()->ChooseSavePath( | 1260 content::GetContentClient()->browser()->ChooseSavePath( |
| 1273 AsWeakPtr(), suggested_path, can_save_as_complete); | 1261 AsWeakPtr(), suggested_path, can_save_as_complete); |
| 1274 } | 1262 } |
| 1275 | 1263 |
| 1276 // Called after the save file dialog box returns. | 1264 // Called after the save file dialog box returns. |
| 1277 void SavePackage::OnPathPicked(const FilePath& final_name, | 1265 void SavePackage::OnPathPicked(const FilePath& final_name, |
| 1278 SavePackageType type) { | 1266 SavePackageType type) { |
| 1279 // Ensure the filename is safe. | 1267 // Ensure the filename is safe. |
| 1280 saved_main_file_path_ = final_name; | 1268 saved_main_file_path_ = final_name; |
| 1281 download_util::GenerateSafeFileName(tab_contents()->contents_mime_type(), | 1269 // TODO(asanka): This call is going to block on IO and shouldn't be |
| 1282 &saved_main_file_path_); | 1270 // made from the UI thread. |
|
rvargas (doing something else)
2011/07/26 22:25:41
Could you clarify (for me) what does this mean?. A
asanka
2011/07/28 20:04:38
This is documenting a pre-existing problem. net::
| |
| 1271 net::GenerateSafeFileName(tab_contents()->contents_mime_type(), | |
| 1272 &saved_main_file_path_); | |
| 1283 | 1273 |
| 1284 saved_main_directory_path_ = saved_main_file_path_.DirName(); | 1274 saved_main_directory_path_ = saved_main_file_path_.DirName(); |
| 1285 | 1275 |
| 1286 PrefService* prefs = tab_contents()->profile()->GetPrefs(); | 1276 PrefService* prefs = tab_contents()->profile()->GetPrefs(); |
| 1287 StringPrefMember save_file_path; | 1277 StringPrefMember save_file_path; |
| 1288 save_file_path.Init(prefs::kSaveFileDefaultDirectory, prefs, NULL); | 1278 save_file_path.Init(prefs::kSaveFileDefaultDirectory, prefs, NULL); |
| 1289 #if defined(OS_POSIX) | 1279 #if defined(OS_POSIX) |
| 1290 std::string path_string = saved_main_directory_path_.value(); | 1280 std::string path_string = saved_main_directory_path_.value(); |
| 1291 #elif defined(OS_WIN) | 1281 #elif defined(OS_WIN) |
| 1292 std::string path_string = WideToUTF8(saved_main_directory_path_.value()); | 1282 std::string path_string = WideToUTF8(saved_main_directory_path_.value()); |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1326 bool SavePackage::IsSavableContents(const std::string& contents_mime_type) { | 1316 bool SavePackage::IsSavableContents(const std::string& contents_mime_type) { |
| 1327 // WebKit creates Document object when MIME type is application/xhtml+xml, | 1317 // WebKit creates Document object when MIME type is application/xhtml+xml, |
| 1328 // so we also support this MIME type. | 1318 // so we also support this MIME type. |
| 1329 return contents_mime_type == "text/html" || | 1319 return contents_mime_type == "text/html" || |
| 1330 contents_mime_type == "text/xml" || | 1320 contents_mime_type == "text/xml" || |
| 1331 contents_mime_type == "application/xhtml+xml" || | 1321 contents_mime_type == "application/xhtml+xml" || |
| 1332 contents_mime_type == "text/plain" || | 1322 contents_mime_type == "text/plain" || |
| 1333 contents_mime_type == "text/css" || | 1323 contents_mime_type == "text/css" || |
| 1334 net::IsSupportedJavascriptMimeType(contents_mime_type.c_str()); | 1324 net::IsSupportedJavascriptMimeType(contents_mime_type.c_str()); |
| 1335 } | 1325 } |
| OLD | NEW |