mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-04-03 21:51:06 +02:00
- Mac: Add CefDownloadManagerDelegate::ChooseDownloadPath implementation (issue #634).
- Persist downloaded files after CEF exits (issue #634). - Shutdown the DownloadManager when CEF exits. - Don't show an error message when downloading files with cefclient. git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@682 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
This commit is contained in:
parent
f79d18d510
commit
a782ae94df
2
cef.gyp
2
cef.gyp
@ -875,6 +875,7 @@
|
|||||||
'<@(includes_win)',
|
'<@(includes_win)',
|
||||||
'libcef/browser/browser_host_impl_win.cc',
|
'libcef/browser/browser_host_impl_win.cc',
|
||||||
'libcef/browser/browser_main_win.cc',
|
'libcef/browser/browser_main_win.cc',
|
||||||
|
'libcef/browser/download_manager_delegate_win.cc',
|
||||||
'libcef/browser/javascript_dialog_win.cc',
|
'libcef/browser/javascript_dialog_win.cc',
|
||||||
'libcef/browser/menu_creator_runner_win.cc',
|
'libcef/browser/menu_creator_runner_win.cc',
|
||||||
'libcef/browser/menu_creator_runner_win.h',
|
'libcef/browser/menu_creator_runner_win.h',
|
||||||
@ -897,6 +898,7 @@
|
|||||||
'libcef/browser/application_mac.mm',
|
'libcef/browser/application_mac.mm',
|
||||||
'libcef/browser/browser_host_impl_mac.mm',
|
'libcef/browser/browser_host_impl_mac.mm',
|
||||||
'libcef/browser/browser_main_mac.mm',
|
'libcef/browser/browser_main_mac.mm',
|
||||||
|
'libcef/browser/download_manager_delegate_mac.mm',
|
||||||
'libcef/browser/javascript_dialog_mac.mm',
|
'libcef/browser/javascript_dialog_mac.mm',
|
||||||
'libcef/browser/menu_creator_runner_mac.h',
|
'libcef/browser/menu_creator_runner_mac.h',
|
||||||
'libcef/browser/menu_creator_runner_mac.mm',
|
'libcef/browser/menu_creator_runner_mac.mm',
|
||||||
|
@ -200,6 +200,9 @@ CefBrowserContext::CefBrowserContext() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
CefBrowserContext::~CefBrowserContext() {
|
CefBrowserContext::~CefBrowserContext() {
|
||||||
|
if (download_manager_.get())
|
||||||
|
download_manager_->Shutdown();
|
||||||
|
|
||||||
if (resource_context_.get()) {
|
if (resource_context_.get()) {
|
||||||
BrowserThread::DeleteSoon(
|
BrowserThread::DeleteSoon(
|
||||||
BrowserThread::IO, FROM_HERE, resource_context_.release());
|
BrowserThread::IO, FROM_HERE, resource_context_.release());
|
||||||
|
@ -76,27 +76,8 @@ void CefDownloadManagerDelegate::ChooseDownloadPath(
|
|||||||
const FilePath& suggested_path,
|
const FilePath& suggested_path,
|
||||||
int32 download_id) {
|
int32 download_id) {
|
||||||
FilePath result;
|
FilePath result;
|
||||||
#if defined(OS_WIN) && !defined(USE_AURA)
|
#if defined(OS_WIN) || defined(OS_MACOSX)
|
||||||
std::wstring file_part = FilePath(suggested_path).BaseName().value();
|
result = PlatformChooseDownloadPath(web_contents, suggested_path);
|
||||||
wchar_t file_name[MAX_PATH];
|
|
||||||
base::wcslcpy(file_name, file_part.c_str(), arraysize(file_name));
|
|
||||||
OPENFILENAME save_as;
|
|
||||||
ZeroMemory(&save_as, sizeof(save_as));
|
|
||||||
save_as.lStructSize = sizeof(OPENFILENAME);
|
|
||||||
save_as.hwndOwner = web_contents->GetNativeView();
|
|
||||||
save_as.lpstrFile = file_name;
|
|
||||||
save_as.nMaxFile = arraysize(file_name);
|
|
||||||
|
|
||||||
std::wstring directory;
|
|
||||||
if (!suggested_path.empty())
|
|
||||||
directory = suggested_path.DirName().value();
|
|
||||||
|
|
||||||
save_as.lpstrInitialDir = directory.c_str();
|
|
||||||
save_as.Flags = OFN_OVERWRITEPROMPT | OFN_EXPLORER | OFN_ENABLESIZING |
|
|
||||||
OFN_NOCHANGEDIR | OFN_PATHMUSTEXIST;
|
|
||||||
|
|
||||||
if (GetSaveFileName(&save_as))
|
|
||||||
result = FilePath(std::wstring(save_as.lpstrFile));
|
|
||||||
#else
|
#else
|
||||||
NOTIMPLEMENTED();
|
NOTIMPLEMENTED();
|
||||||
#endif
|
#endif
|
||||||
@ -108,6 +89,12 @@ void CefDownloadManagerDelegate::ChooseDownloadPath(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CefDownloadManagerDelegate::AddItemToPersistentStore(
|
||||||
|
content::DownloadItem* item) {
|
||||||
|
static int next_id;
|
||||||
|
download_manager_->OnItemAddedToPersistentStore(item->GetId(), ++next_id);
|
||||||
|
}
|
||||||
|
|
||||||
void CefDownloadManagerDelegate::GenerateFilename(
|
void CefDownloadManagerDelegate::GenerateFilename(
|
||||||
int32 download_id,
|
int32 download_id,
|
||||||
const FilePath& generated_name) {
|
const FilePath& generated_name) {
|
||||||
|
@ -30,6 +30,7 @@ class CefDownloadManagerDelegate
|
|||||||
virtual void ChooseDownloadPath(content::WebContents* web_contents,
|
virtual void ChooseDownloadPath(content::WebContents* web_contents,
|
||||||
const FilePath& suggested_path,
|
const FilePath& suggested_path,
|
||||||
int32 download_id) OVERRIDE;
|
int32 download_id) OVERRIDE;
|
||||||
|
virtual void AddItemToPersistentStore(content::DownloadItem* item) OVERRIDE;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
friend class base::RefCountedThreadSafe<CefDownloadManagerDelegate>;
|
friend class base::RefCountedThreadSafe<CefDownloadManagerDelegate>;
|
||||||
@ -41,6 +42,9 @@ class CefDownloadManagerDelegate
|
|||||||
void RestartDownload(int32 download_id,
|
void RestartDownload(int32 download_id,
|
||||||
const FilePath& suggested_path);
|
const FilePath& suggested_path);
|
||||||
|
|
||||||
|
FilePath PlatformChooseDownloadPath(content::WebContents* web_contents,
|
||||||
|
const FilePath& suggested_path);
|
||||||
|
|
||||||
content::DownloadManager* download_manager_;
|
content::DownloadManager* download_manager_;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(CefDownloadManagerDelegate);
|
DISALLOW_COPY_AND_ASSIGN(CefDownloadManagerDelegate);
|
||||||
|
41
libcef/browser/download_manager_delegate_mac.mm
Normal file
41
libcef/browser/download_manager_delegate_mac.mm
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
// Copyright (c) 2012 The Chromium Embedded Framework Authors.
|
||||||
|
// Portions copyright (c) 2011 The Chromium Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#include "libcef/browser/download_manager_delegate.h"
|
||||||
|
|
||||||
|
#import <Cocoa/Cocoa.h>
|
||||||
|
|
||||||
|
#include "base/sys_string_conversions.h"
|
||||||
|
#include "content/public/browser/web_contents.h"
|
||||||
|
|
||||||
|
FilePath CefDownloadManagerDelegate::PlatformChooseDownloadPath(
|
||||||
|
content::WebContents* web_contents,
|
||||||
|
const FilePath& suggested_path) {
|
||||||
|
FilePath result;
|
||||||
|
NSSavePanel* savePanel = [NSSavePanel savePanel];
|
||||||
|
|
||||||
|
if (!suggested_path.BaseName().empty()) {
|
||||||
|
NSString* defaultName = base::SysUTF8ToNSString(
|
||||||
|
suggested_path.BaseName().value());
|
||||||
|
[savePanel setNameFieldStringValue:defaultName];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!suggested_path.DirName().empty()) {
|
||||||
|
NSString* defaultDir = base::SysUTF8ToNSString(
|
||||||
|
suggested_path.DirName().value());
|
||||||
|
[savePanel setDirectoryURL:[NSURL fileURLWithPath:defaultDir]];
|
||||||
|
}
|
||||||
|
|
||||||
|
NSView* view = web_contents->GetNativeView();
|
||||||
|
[savePanel beginSheetModalForWindow:[view window] completionHandler:nil];
|
||||||
|
if ([savePanel runModal] == NSFileHandlingPanelOKButton) {
|
||||||
|
NSURL * url = [savePanel URL];
|
||||||
|
NSString* path = [url path];
|
||||||
|
result = FilePath([path UTF8String]);
|
||||||
|
}
|
||||||
|
[NSApp endSheet:savePanel];
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
42
libcef/browser/download_manager_delegate_win.cc
Normal file
42
libcef/browser/download_manager_delegate_win.cc
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
// Copyright (c) 2012 The Chromium Embedded Framework Authors.
|
||||||
|
// Portions copyright (c) 2011 The Chromium Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#include "libcef/browser/download_manager_delegate.h"
|
||||||
|
|
||||||
|
#include <commdlg.h>
|
||||||
|
#include <windows.h>
|
||||||
|
|
||||||
|
#include "base/string_util.h"
|
||||||
|
#include "content/public/browser/web_contents.h"
|
||||||
|
|
||||||
|
|
||||||
|
FilePath CefDownloadManagerDelegate::PlatformChooseDownloadPath(
|
||||||
|
content::WebContents* web_contents,
|
||||||
|
const FilePath& suggested_path) {
|
||||||
|
FilePath result;
|
||||||
|
|
||||||
|
std::wstring file_part = FilePath(suggested_path).BaseName().value();
|
||||||
|
wchar_t file_name[MAX_PATH];
|
||||||
|
base::wcslcpy(file_name, file_part.c_str(), arraysize(file_name));
|
||||||
|
OPENFILENAME save_as;
|
||||||
|
ZeroMemory(&save_as, sizeof(save_as));
|
||||||
|
save_as.lStructSize = sizeof(OPENFILENAME);
|
||||||
|
save_as.hwndOwner = web_contents->GetNativeView();
|
||||||
|
save_as.lpstrFile = file_name;
|
||||||
|
save_as.nMaxFile = arraysize(file_name);
|
||||||
|
|
||||||
|
std::wstring directory;
|
||||||
|
if (!suggested_path.empty())
|
||||||
|
directory = suggested_path.DirName().value();
|
||||||
|
|
||||||
|
save_as.lpstrInitialDir = directory.c_str();
|
||||||
|
save_as.Flags = OFN_OVERWRITEPROMPT | OFN_EXPLORER | OFN_ENABLESIZING |
|
||||||
|
OFN_NOCHANGEDIR | OFN_PATHMUSTEXIST;
|
||||||
|
|
||||||
|
if (GetSaveFileName(&save_as))
|
||||||
|
result = FilePath(std::wstring(save_as.lpstrFile));
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
@ -270,6 +270,10 @@ void ClientHandler::OnLoadError(CefRefPtr<CefBrowser> browser,
|
|||||||
const CefString& failedUrl) {
|
const CefString& failedUrl) {
|
||||||
REQUIRE_UI_THREAD();
|
REQUIRE_UI_THREAD();
|
||||||
|
|
||||||
|
// Don't display an error for downloaded files.
|
||||||
|
if (errorCode == ERR_ABORTED)
|
||||||
|
return;
|
||||||
|
|
||||||
// Display a load error message.
|
// Display a load error message.
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
ss << "<html><body><h2>Failed to load URL " << std::string(failedUrl) <<
|
ss << "<html><body><h2>Failed to load URL " << std::string(failedUrl) <<
|
||||||
|
Loading…
x
Reference in New Issue
Block a user