fix: crash on input file handler dialog (#19897)
* fix: crash on input file handler dialog * invert cancellation logic
This commit is contained in:
parent
c61020e9d3
commit
698120daf0
1 changed files with 19 additions and 6 deletions
|
@ -128,7 +128,9 @@ class FileSelectHelper : public base::RefCounted<FileSelectHelper>,
|
|||
// listener is called from the directory enumerator.
|
||||
bool ready_to_call_listener = false;
|
||||
|
||||
if (!canceled) {
|
||||
if (canceled) {
|
||||
OnSelectionCancelled();
|
||||
} else {
|
||||
std::vector<base::FilePath> paths;
|
||||
if (result.Get("filePaths", &paths)) {
|
||||
// If we are uploading a folder we need to enumerate its contents
|
||||
|
@ -153,27 +155,30 @@ class FileSelectHelper : public base::RefCounted<FileSelectHelper>,
|
|||
paths[0].DirName());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// We should only call this if we have not cancelled the dialog
|
||||
if (ready_to_call_listener)
|
||||
OnFilesSelected(std::move(file_info), lister_base_dir_);
|
||||
}
|
||||
}
|
||||
|
||||
void OnSaveDialogDone(mate::Dictionary result) {
|
||||
std::vector<FileChooserFileInfoPtr> file_info;
|
||||
bool canceled = true;
|
||||
result.Get("canceled", &canceled);
|
||||
|
||||
if (!canceled) {
|
||||
if (canceled) {
|
||||
OnSelectionCancelled();
|
||||
} else {
|
||||
base::FilePath path;
|
||||
if (result.Get("filePath", &path)) {
|
||||
file_info.push_back(FileChooserFileInfo::NewNativeFile(
|
||||
blink::mojom::NativeFileInfo::New(
|
||||
path, path.BaseName().AsUTF16Unsafe())));
|
||||
}
|
||||
}
|
||||
// We should only call this if we have not cancelled the dialog
|
||||
OnFilesSelected(std::move(file_info), base::FilePath());
|
||||
}
|
||||
}
|
||||
|
||||
void OnFilesSelected(std::vector<FileChooserFileInfoPtr> file_info,
|
||||
base::FilePath base_dir) {
|
||||
|
@ -184,6 +189,14 @@ class FileSelectHelper : public base::RefCounted<FileSelectHelper>,
|
|||
render_frame_host_ = nullptr;
|
||||
}
|
||||
|
||||
void OnSelectionCancelled() {
|
||||
if (listener_) {
|
||||
listener_->FileSelectionCanceled();
|
||||
listener_.reset();
|
||||
}
|
||||
render_frame_host_ = nullptr;
|
||||
}
|
||||
|
||||
// content::WebContentsObserver:
|
||||
void RenderFrameHostChanged(content::RenderFrameHost* old_host,
|
||||
content::RenderFrameHost* new_host) override {
|
||||
|
|
Loading…
Reference in a new issue