From 4c5197fe6ee0674bc482b435e81eb60553cec554 Mon Sep 17 00:00:00 2001 From: "trop[bot]" <37223003+trop[bot]@users.noreply.github.com> Date: Tue, 7 Apr 2020 22:11:03 -0700 Subject: [PATCH] fix: nullptr check when closing windows (#23024) --- shell/browser/window_list.cc | 32 +++++++++++++++++++++++++------- 1 file changed, 25 insertions(+), 7 deletions(-) diff --git a/shell/browser/window_list.cc b/shell/browser/window_list.cc index 494114edd9e03..8dd4bf37745ee 100644 --- a/shell/browser/window_list.cc +++ b/shell/browser/window_list.cc @@ -10,6 +10,18 @@ #include "shell/browser/native_window.h" #include "shell/browser/window_list_observer.h" +namespace { +template +std::vector> ConvertToWeakPtrVector(std::vector raw_ptrs) { + std::vector> converted_to_weak; + converted_to_weak.reserve(raw_ptrs.size()); + for (auto* raw_ptr : raw_ptrs) { + converted_to_weak.push_back(raw_ptr->GetWeakPtr()); + } + return converted_to_weak; +} +} // namespace + namespace electron { // static @@ -80,20 +92,26 @@ void WindowList::RemoveObserver(WindowListObserver* observer) { // static void WindowList::CloseAllWindows() { - WindowVector windows = GetInstance()->windows_; + std::vector> weak_windows = + ConvertToWeakPtrVector(GetInstance()->windows_); #if defined(OS_MACOSX) - std::reverse(windows.begin(), windows.end()); + std::reverse(weak_windows.begin(), weak_windows.end()); #endif - for (auto* const& window : windows) - if (!window->IsClosed()) + for (const auto& window : weak_windows) { + if (window && !window->IsClosed()) window->Close(); + } } // static void WindowList::DestroyAllWindows() { - WindowVector windows = GetInstance()->windows_; - for (auto* const& window : windows) - window->CloseImmediately(); // e.g. Destroy() + std::vector> weak_windows = + ConvertToWeakPtrVector(GetInstance()->windows_); + + for (const auto& window : weak_windows) { + if (window) + window->CloseImmediately(); + } } WindowList::WindowList() {}