From 55d4d44f02856f3f46b1eae2f719ead8b5567dac Mon Sep 17 00:00:00 2001 From: Cheng Zhao Date: Thu, 26 Jan 2017 16:10:28 +0900 Subject: [PATCH] Fix Debug building on Windows --- .../osr/osr_render_widget_host_view.cc | 19 ++++------- .../browser/osr/osr_render_widget_host_view.h | 9 ++--- atom/browser/ui/drag_util_views.cc | 2 +- atom/browser/ui/file_dialog_win.cc | 19 ++++++----- atom/browser/ui/message_box_win.cc | 2 +- atom/browser/ui/views/submenu_button.cc | 33 ++++++++----------- atom/browser/ui/views/submenu_button.h | 4 +-- atom/browser/ui/win/notify_icon_host.cc | 5 ++- .../browser/printing/pdf_to_emf_converter.cc | 2 +- .../chrome/browser/printing/print_job.cc | 2 +- .../browser/ui/views/color_chooser_dialog.cc | 2 +- .../chrome/utility/printing_handler_win.cc | 27 +++++---------- common.gypi | 1 + script/lib/config.py | 2 +- vendor/brightray | 2 +- 15 files changed, 52 insertions(+), 79 deletions(-) diff --git a/atom/browser/osr/osr_render_widget_host_view.cc b/atom/browser/osr/osr_render_widget_host_view.cc index d5452a7abf3..7355f1a0c1e 100644 --- a/atom/browser/osr/osr_render_widget_host_view.cc +++ b/atom/browser/osr/osr_render_widget_host_view.cc @@ -20,6 +20,7 @@ #include "content/public/browser/browser_thread.h" #include "content/public/browser/context_factory.h" #include "content/public/browser/render_widget_host_view_frame_subscriber.h" +#include "ui/compositor/compositor.h" #include "ui/compositor/layer.h" #include "ui/compositor/layer_type.h" #include "ui/events/latency_info.h" @@ -349,14 +350,16 @@ OffScreenRenderWidgetHostView::OffScreenRenderWidgetHostView( is_showing_(!render_widget_host_->is_hidden()), size_(native_window->GetSize()), painting_(true), -#if !defined(OS_MACOSX) - delegated_frame_host_(new content::DelegatedFrameHost(this)), -#endif weak_ptr_factory_(this) { DCHECK(render_widget_host_); render_widget_host_->SetView(this); #if !defined(OS_MACOSX) + content::ImageTransportFactory* factory = + content::ImageTransportFactory::GetInstance(); + delegated_frame_host_ = base::MakeUnique( + factory->GetContextFactory()->AllocateFrameSinkId(), this); + root_layer_.reset(new ui::Layer(ui::LAYER_SOLID_COLOR)); #endif @@ -743,16 +746,6 @@ OffScreenRenderWidgetHostView::DelegatedFrameHostSendReclaimCompositorResources( resources)); } -void OffScreenRenderWidgetHostView:: - DelegatedFrameHostOnLostCompositorResources() { - render_widget_host_->ScheduleComposite(); -} - -void OffScreenRenderWidgetHostView::DelegatedFrameHostUpdateVSyncParameters( - const base::TimeTicks& timebase, const base::TimeDelta& interval) { - render_widget_host_->UpdateVSyncParameters(timebase, interval); -} - void OffScreenRenderWidgetHostView::SetBeginFrameSource( cc::BeginFrameSource* source) { } diff --git a/atom/browser/osr/osr_render_widget_host_view.h b/atom/browser/osr/osr_render_widget_host_view.h index ca5dae52f9d..7380476bee6 100644 --- a/atom/browser/osr/osr_render_widget_host_view.h +++ b/atom/browser/osr/osr_render_widget_host_view.h @@ -160,12 +160,9 @@ class OffScreenRenderWidgetHostView bool defer_compositor_lock) override; void DelegatedFrameHostResizeLockWasReleased(void) override; void DelegatedFrameHostSendReclaimCompositorResources( - int output_surface_id, - bool is_swap_ack, - const cc::ReturnedResourceArray& resources) override; - void DelegatedFrameHostOnLostCompositorResources(void) override; - void DelegatedFrameHostUpdateVSyncParameters( - const base::TimeTicks &, const base::TimeDelta &) override; + int output_surface_id, + bool is_swap_ack, + const cc::ReturnedResourceArray& resources) override; void SetBeginFrameSource(cc::BeginFrameSource* source) override; #endif // !defined(OS_MACOSX) diff --git a/atom/browser/ui/drag_util_views.cc b/atom/browser/ui/drag_util_views.cc index 058aed443c1..2c7857412ae 100644 --- a/atom/browser/ui/drag_util_views.cc +++ b/atom/browser/ui/drag_util_views.cc @@ -12,7 +12,7 @@ #include "ui/display/screen.h" #include "ui/gfx/geometry/point.h" #include "ui/views/widget/widget.h" -#include "ui/wm/public/drag_drop_client.h" +#include "ui/aura/client/drag_drop_client.h" namespace atom { diff --git a/atom/browser/ui/file_dialog_win.cc b/atom/browser/ui/file_dialog_win.cc index cab4e214018..8e973432f5a 100644 --- a/atom/browser/ui/file_dialog_win.cc +++ b/atom/browser/ui/file_dialog_win.cc @@ -18,6 +18,7 @@ #include "base/strings/string_util.h" #include "base/strings/utf_string_conversions.h" #include "base/threading/thread.h" +#include "base/threading/thread_task_runner_handle.h" #include "base/win/registry.h" #include "third_party/wtl/include/atlapp.h" #include "third_party/wtl/include/atldlgs.h" @@ -143,7 +144,7 @@ class FileDialog { struct RunState { base::Thread* dialog_thread; - base::MessageLoop* ui_message_loop; + scoped_refptr ui_task_runner; }; bool CreateDialogThread(RunState* run_state) { @@ -154,7 +155,7 @@ bool CreateDialogThread(RunState* run_state) { return false; run_state->dialog_thread = thread.release(); - run_state->ui_message_loop = base::MessageLoop::current(); + run_state->ui_task_runner = base::ThreadTaskRunnerHandle::Get(); return true; } @@ -169,9 +170,9 @@ void RunOpenDialogInNewThread(const RunState& run_state, std::vector paths; bool result = ShowOpenDialog(parent, title, button_label, default_path, filters, properties, &paths); - run_state.ui_message_loop->PostTask(FROM_HERE, + run_state.ui_task_runner->PostTask(FROM_HERE, base::Bind(callback, result, paths)); - run_state.ui_message_loop->DeleteSoon(FROM_HERE, run_state.dialog_thread); + run_state.ui_task_runner->DeleteSoon(FROM_HERE, run_state.dialog_thread); } void RunSaveDialogInNewThread(const RunState& run_state, @@ -184,9 +185,9 @@ void RunSaveDialogInNewThread(const RunState& run_state, base::FilePath path; bool result = ShowSaveDialog(parent, title, button_label, default_path, filters, &path); - run_state.ui_message_loop->PostTask(FROM_HERE, - base::Bind(callback, result, path)); - run_state.ui_message_loop->DeleteSoon(FROM_HERE, run_state.dialog_thread); + run_state.ui_task_runner->PostTask(FROM_HERE, + base::Bind(callback, result, path)); + run_state.ui_task_runner->DeleteSoon(FROM_HERE, run_state.dialog_thread); } } // namespace @@ -256,7 +257,7 @@ void ShowOpenDialog(atom::NativeWindow* parent, return; } - run_state.dialog_thread->message_loop()->PostTask( + run_state.dialog_thread->task_runner()->PostTask( FROM_HERE, base::Bind(&RunOpenDialogInNewThread, run_state, parent, title, button_label, default_path, filters, properties, callback)); @@ -295,7 +296,7 @@ void ShowSaveDialog(atom::NativeWindow* parent, return; } - run_state.dialog_thread->message_loop()->PostTask( + run_state.dialog_thread->task_runner()->PostTask( FROM_HERE, base::Bind(&RunSaveDialogInNewThread, run_state, parent, title, button_label, default_path, filters, callback)); diff --git a/atom/browser/ui/message_box_win.cc b/atom/browser/ui/message_box_win.cc index 074e13bad23..b6777fb1da2 100644 --- a/atom/browser/ui/message_box_win.cc +++ b/atom/browser/ui/message_box_win.cc @@ -233,7 +233,7 @@ void ShowMessageBox(NativeWindow* parent, } base::Thread* unretained = thread.release(); - unretained->message_loop()->PostTask( + unretained->task_runner()->PostTask( FROM_HERE, base::Bind(&RunMessageBoxInNewThread, base::Unretained(unretained), parent, type, buttons, default_id, cancel_id, options, title, diff --git a/atom/browser/ui/views/submenu_button.cc b/atom/browser/ui/views/submenu_button.cc index f8257b00274..d2a4cb60cc2 100644 --- a/atom/browser/ui/views/submenu_button.cc +++ b/atom/browser/ui/views/submenu_button.cc @@ -10,6 +10,7 @@ #include "ui/gfx/color_utils.h" #include "ui/gfx/text_utils.h" #include "ui/views/animation/flood_fill_ink_drop_ripple.h" +#include "ui/views/animation/ink_drop_impl.h" #include "ui/views/animation/ink_drop_host_view.h" #include "ui/views/controls/button/label_button_border.h" @@ -59,28 +60,20 @@ SubmenuButton::~SubmenuButton() { std::unique_ptr SubmenuButton::CreateInkDropRipple() const { - return base::MakeUnique( - GetLocalBounds(), - GetInkDropCenterBasedOnLastEvent(), - GetInkDropBaseColor(), - ink_drop_visible_opacity()); + std::unique_ptr ripple( + new views::FloodFillInkDropRipple( + size(), + GetInkDropCenterBasedOnLastEvent(), + GetInkDropBaseColor(), + ink_drop_visible_opacity())); + return ripple; } -std::unique_ptr - SubmenuButton::CreateInkDropHighlight() const { - if (!ShouldShowInkDropHighlight()) - return nullptr; - - gfx::Size size = GetLocalBounds().size(); - return base::MakeUnique( - size, - kInkDropSmallCornerRadius, - gfx::RectF(gfx::SizeF(size)).CenterPoint(), - GetInkDropBaseColor()); -} - -bool SubmenuButton::ShouldShowInkDropForFocus() const { - return false; +std::unique_ptr SubmenuButton::CreateInkDrop() { + std::unique_ptr ink_drop = + CustomButton::CreateDefaultInkDropImpl(); + ink_drop->SetShowHighlightOnHover(false); + return std::move(ink_drop); } void SubmenuButton::SetAcceleratorVisibility(bool visible) { diff --git a/atom/browser/ui/views/submenu_button.h b/atom/browser/ui/views/submenu_button.h index 02e25cd0deb..901234fdf54 100644 --- a/atom/browser/ui/views/submenu_button.h +++ b/atom/browser/ui/views/submenu_button.h @@ -31,9 +31,7 @@ class SubmenuButton : public views::MenuButton { // views::InkDropHostView: std::unique_ptr CreateInkDropRipple() const override; - std::unique_ptr CreateInkDropHighlight() - const override; - bool ShouldShowInkDropForFocus() const override; + std::unique_ptr CreateInkDrop() override; private: bool GetUnderlinePosition(const base::string16& text, diff --git a/atom/browser/ui/win/notify_icon_host.cc b/atom/browser/ui/win/notify_icon_host.cc index d63df9097b0..ee5c8bab093 100644 --- a/atom/browser/ui/win/notify_icon_host.cc +++ b/atom/browser/ui/win/notify_icon_host.cc @@ -86,9 +86,8 @@ NotifyIconHost::~NotifyIconHost() { if (atom_) UnregisterClass(MAKEINTATOM(atom_), instance_); - NotifyIcons copied_container(notify_icons_); - base::STLDeleteContainerPointers( - copied_container.begin(), copied_container.end()); + for (NotifyIcon* ptr : notify_icons_) + delete ptr; } NotifyIcon* NotifyIconHost::CreateNotifyIcon() { diff --git a/chromium_src/chrome/browser/printing/pdf_to_emf_converter.cc b/chromium_src/chrome/browser/printing/pdf_to_emf_converter.cc index 17c379631ab..503d192feec 100644 --- a/chromium_src/chrome/browser/printing/pdf_to_emf_converter.cc +++ b/chromium_src/chrome/browser/printing/pdf_to_emf_converter.cc @@ -38,7 +38,7 @@ class RefCountedTempDir public: RefCountedTempDir() { ignore_result(temp_dir_.CreateUniqueTempDir()); } bool IsValid() const { return temp_dir_.IsValid(); } - const base::FilePath& GetPath() const { return temp_dir_.path(); } + const base::FilePath& GetPath() const { return temp_dir_.GetPath(); } private: friend struct BrowserThread::DeleteOnThread; diff --git a/chromium_src/chrome/browser/printing/print_job.cc b/chromium_src/chrome/browser/printing/print_job.cc index 1707a6f684a..5dce9ccdc55 100644 --- a/chromium_src/chrome/browser/printing/print_job.cc +++ b/chromium_src/chrome/browser/printing/print_job.cc @@ -418,7 +418,7 @@ void PrintJob::ControlledWorkerShutdown() { // Delay shutdown until the worker terminates. We want this code path // to wait on the thread to quit before continuing. if (worker_->IsRunning()) { - base::MessageLoop::current()->PostDelayedTask( + base::ThreadTaskRunnerHandle::Get()->PostDelayedTask( FROM_HERE, base::Bind(&PrintJob::ControlledWorkerShutdown, this), base::TimeDelta::FromMilliseconds(100)); diff --git a/chromium_src/chrome/browser/ui/views/color_chooser_dialog.cc b/chromium_src/chrome/browser/ui/views/color_chooser_dialog.cc index 347f1043aac..5c7882b1fc1 100644 --- a/chromium_src/chrome/browser/ui/views/color_chooser_dialog.cc +++ b/chromium_src/chrome/browser/ui/views/color_chooser_dialog.cc @@ -36,7 +36,7 @@ ColorChooserDialog::ColorChooserDialog(views::ColorChooserListener* listener, HWND owning_hwnd = views::HWNDForNativeWindow(owning_window); ExecuteOpenParams execute_params(initial_color, BeginRun(owning_hwnd), owning_hwnd); - execute_params.run_state.dialog_thread->message_loop()->PostTask(FROM_HERE, + execute_params.run_state.dialog_thread->task_runner()->PostTask(FROM_HERE, base::Bind(&ColorChooserDialog::ExecuteOpen, this, execute_params)); } diff --git a/chromium_src/chrome/utility/printing_handler_win.cc b/chromium_src/chrome/utility/printing_handler_win.cc index 105e574f735..c29dd5f9f69 100644 --- a/chromium_src/chrome/utility/printing_handler_win.cc +++ b/chromium_src/chrome/utility/printing_handler_win.cc @@ -105,30 +105,21 @@ bool PrintingHandlerWin::RenderPdfPageToMetafile(int page_number, // original coordinates and we'll be able to print in full resolution. // Before playback we'll need to counter the scaling up that will happen // in the service (print_system_win.cc). - *scale_factor = - gfx::CalculatePageScale(metafile.context(), - pdf_rendering_settings_.area().right(), - pdf_rendering_settings_.area().bottom()); + *scale_factor = gfx::CalculatePageScale( + metafile.context(), pdf_rendering_settings_.area.right(), + pdf_rendering_settings_.area.bottom()); gfx::ScaleDC(metafile.context(), *scale_factor); // The underlying metafile is of type Emf and ignores the arguments passed // to StartPage. metafile.StartPage(gfx::Size(), gfx::Rect(), 1); if (!chrome_pdf::RenderPDFPageToDC( - &pdf_data_.front(), - pdf_data_.size(), - page_number, - metafile.context(), - pdf_rendering_settings_.dpi(), - pdf_rendering_settings_.area().x(), - pdf_rendering_settings_.area().y(), - pdf_rendering_settings_.area().width(), - pdf_rendering_settings_.area().height(), - true, - false, - true, - true, - pdf_rendering_settings_.autorotate())) { + &pdf_data_.front(), pdf_data_.size(), page_number, metafile.context(), + pdf_rendering_settings_.dpi, pdf_rendering_settings_.area.x(), + pdf_rendering_settings_.area.y(), + pdf_rendering_settings_.area.width(), + pdf_rendering_settings_.area.height(), true, false, true, true, + pdf_rendering_settings_.autorotate)) { return false; } metafile.FinishPage(); diff --git a/common.gypi b/common.gypi index 58c0854052c..21685f116ae 100644 --- a/common.gypi +++ b/common.gypi @@ -277,6 +277,7 @@ 'msvs_disabled_warnings': [ 4005, # (node.h) macro redefinition 4091, # (node_extern.h) '__declspec(dllimport)' : ignored on left of 'node::Environment' when no variable is declared + 4099, # (pdf_render_settings.h) type name first seen using 'class' now seen using 'struct' 4189, # local variable is initialized but not referenced 4201, # (uv.h) nameless struct/union 4267, # conversion from 'size_t' to 'int', possible loss of data diff --git a/script/lib/config.py b/script/lib/config.py index ae4d4488dbd..6cfffc77608 100644 --- a/script/lib/config.py +++ b/script/lib/config.py @@ -9,7 +9,7 @@ import sys BASE_URL = os.getenv('LIBCHROMIUMCONTENT_MIRROR') or \ 'https://s3.amazonaws.com/github-janky-artifacts/libchromiumcontent' LIBCHROMIUMCONTENT_COMMIT = os.getenv('LIBCHROMIUMCONTENT_COMMIT') or \ - '455a133fe14b5e33ac6b4fc7f8844ace1cd0a221' + 'b71afafe59998daf0cb275b50140378b8c88b101' PLATFORM = { 'cygwin': 'win32', diff --git a/vendor/brightray b/vendor/brightray index a400856b41a..51b4ff84b28 160000 --- a/vendor/brightray +++ b/vendor/brightray @@ -1 +1 @@ -Subproject commit a400856b41aa0485a4b43ba1714c84fef4bb06f8 +Subproject commit 51b4ff84b282d11d559a425253845f850bf3279b