Fix crash in offscreen renderer
This commit is contained in:
parent
6d8f900916
commit
4c56c1c2b2
4 changed files with 107 additions and 33 deletions
|
@ -71,8 +71,9 @@ class AtomCopyFrameGenerator {
|
||||||
content::BrowserThread::PostDelayedTask(content::BrowserThread::UI,
|
content::BrowserThread::PostDelayedTask(content::BrowserThread::UI,
|
||||||
FROM_HERE,
|
FROM_HERE,
|
||||||
base::Bind(&AtomCopyFrameGenerator::InternalGenerateCopyFrame,
|
base::Bind(&AtomCopyFrameGenerator::InternalGenerateCopyFrame,
|
||||||
weak_ptr_factory_.GetWeakPtr()), base::TimeDelta::FromMilliseconds(
|
weak_ptr_factory_.GetWeakPtr()),
|
||||||
frame_rate_threshold_ms_ - frame_rate_delta));
|
base::TimeDelta::FromMilliseconds(
|
||||||
|
frame_rate_threshold_ms_ - frame_rate_delta));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -103,9 +104,7 @@ class AtomCopyFrameGenerator {
|
||||||
damage_rect));
|
damage_rect));
|
||||||
|
|
||||||
request->set_area(gfx::Rect(view_->GetPhysicalBackingSize()));
|
request->set_area(gfx::Rect(view_->GetPhysicalBackingSize()));
|
||||||
|
view_->GetRootLayer()->RequestCopyOfOutput(std::move(request));
|
||||||
view_->DelegatedFrameHostGetLayer()->RequestCopyOfOutput(
|
|
||||||
std::move(request));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CopyFromCompositingSurfaceHasResult(
|
void CopyFromCompositingSurfaceHasResult(
|
||||||
|
@ -350,12 +349,17 @@ OffScreenRenderWidgetHostView::OffScreenRenderWidgetHostView(
|
||||||
is_showing_(!render_widget_host_->is_hidden()),
|
is_showing_(!render_widget_host_->is_hidden()),
|
||||||
size_(native_window->GetSize()),
|
size_(native_window->GetSize()),
|
||||||
painting_(true),
|
painting_(true),
|
||||||
root_layer_(new ui::Layer(ui::LAYER_SOLID_COLOR)),
|
#if !defined(OS_MACOSX)
|
||||||
delegated_frame_host_(new content::DelegatedFrameHost(this)),
|
delegated_frame_host_(new content::DelegatedFrameHost(this)),
|
||||||
|
#endif
|
||||||
weak_ptr_factory_(this) {
|
weak_ptr_factory_(this) {
|
||||||
DCHECK(render_widget_host_);
|
DCHECK(render_widget_host_);
|
||||||
render_widget_host_->SetView(this);
|
render_widget_host_->SetView(this);
|
||||||
|
|
||||||
|
#if !defined(OS_MACOSX)
|
||||||
|
root_layer_.reset(new ui::Layer(ui::LAYER_SOLID_COLOR));
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(OS_MACOSX)
|
#if defined(OS_MACOSX)
|
||||||
CreatePlatformWidget();
|
CreatePlatformWidget();
|
||||||
#else
|
#else
|
||||||
|
@ -363,17 +367,25 @@ OffScreenRenderWidgetHostView::OffScreenRenderWidgetHostView(
|
||||||
new ui::Compositor(content::GetContextFactory(),
|
new ui::Compositor(content::GetContextFactory(),
|
||||||
base::ThreadTaskRunnerHandle::Get()));
|
base::ThreadTaskRunnerHandle::Get()));
|
||||||
compositor_->SetAcceleratedWidget(native_window_->GetAcceleratedWidget());
|
compositor_->SetAcceleratedWidget(native_window_->GetAcceleratedWidget());
|
||||||
#endif
|
|
||||||
compositor_->SetDelegate(this);
|
compositor_->SetDelegate(this);
|
||||||
compositor_->SetRootLayer(root_layer_.get());
|
compositor_->SetRootLayer(root_layer_.get());
|
||||||
|
#endif
|
||||||
|
|
||||||
|
LOG(ERROR) << "GetRootLayer: " << GetRootLayer();
|
||||||
ResizeRootLayer();
|
ResizeRootLayer();
|
||||||
}
|
}
|
||||||
|
|
||||||
OffScreenRenderWidgetHostView::~OffScreenRenderWidgetHostView() {
|
OffScreenRenderWidgetHostView::~OffScreenRenderWidgetHostView() {
|
||||||
|
#if defined(OS_MACOSX)
|
||||||
|
if (is_showing_)
|
||||||
|
browser_compositor_->SetRenderWidgetHostIsHidden(true);
|
||||||
|
#else
|
||||||
|
// Marking the DelegatedFrameHost as removed from the window hierarchy is
|
||||||
|
// necessary to remove all connections to its old ui::Compositor.
|
||||||
if (is_showing_)
|
if (is_showing_)
|
||||||
delegated_frame_host_->WasHidden();
|
delegated_frame_host_->WasHidden();
|
||||||
delegated_frame_host_->ResetCompositor();
|
delegated_frame_host_->ResetCompositor();
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(OS_MACOSX)
|
#if defined(OS_MACOSX)
|
||||||
DestroyPlatformWidget();
|
DestroyPlatformWidget();
|
||||||
|
@ -431,8 +443,8 @@ void OffScreenRenderWidgetHostView::SetSize(const gfx::Size& size) {
|
||||||
const gfx::Size& size_in_pixels =
|
const gfx::Size& size_in_pixels =
|
||||||
gfx::ConvertSizeToPixel(scale_factor_, size);
|
gfx::ConvertSizeToPixel(scale_factor_, size);
|
||||||
|
|
||||||
root_layer_->SetBounds(gfx::Rect(size));
|
GetRootLayer()->SetBounds(gfx::Rect(size));
|
||||||
compositor_->SetScaleAndSize(scale_factor_, size_in_pixels);
|
GetCompositor()->SetScaleAndSize(scale_factor_, size_in_pixels);
|
||||||
}
|
}
|
||||||
|
|
||||||
void OffScreenRenderWidgetHostView::SetBounds(const gfx::Rect& new_bounds) {
|
void OffScreenRenderWidgetHostView::SetBounds(const gfx::Rect& new_bounds) {
|
||||||
|
@ -463,7 +475,7 @@ bool OffScreenRenderWidgetHostView::HasFocus() const {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool OffScreenRenderWidgetHostView::IsSurfaceAvailableForCopy() const {
|
bool OffScreenRenderWidgetHostView::IsSurfaceAvailableForCopy() const {
|
||||||
return delegated_frame_host_->CanCopyToBitmap();
|
return GetDelegatedFrameHost()->CanCopyToBitmap();
|
||||||
}
|
}
|
||||||
|
|
||||||
void OffScreenRenderWidgetHostView::Show() {
|
void OffScreenRenderWidgetHostView::Show() {
|
||||||
|
@ -471,10 +483,16 @@ void OffScreenRenderWidgetHostView::Show() {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
is_showing_ = true;
|
is_showing_ = true;
|
||||||
if (render_widget_host_)
|
|
||||||
render_widget_host_->WasShown(ui::LatencyInfo());
|
#if defined(OS_MACOSX)
|
||||||
|
browser_compositor_->SetRenderWidgetHostIsHidden(false);
|
||||||
|
#else
|
||||||
delegated_frame_host_->SetCompositor(compositor_.get());
|
delegated_frame_host_->SetCompositor(compositor_.get());
|
||||||
delegated_frame_host_->WasShown(ui::LatencyInfo());
|
delegated_frame_host_->WasShown(ui::LatencyInfo());
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (render_widget_host_)
|
||||||
|
render_widget_host_->WasShown(ui::LatencyInfo());
|
||||||
}
|
}
|
||||||
|
|
||||||
void OffScreenRenderWidgetHostView::Hide() {
|
void OffScreenRenderWidgetHostView::Hide() {
|
||||||
|
@ -483,8 +501,14 @@ void OffScreenRenderWidgetHostView::Hide() {
|
||||||
|
|
||||||
if (render_widget_host_)
|
if (render_widget_host_)
|
||||||
render_widget_host_->WasHidden();
|
render_widget_host_->WasHidden();
|
||||||
delegated_frame_host_->WasHidden();
|
|
||||||
delegated_frame_host_->ResetCompositor();
|
#if defined(OS_MACOSX)
|
||||||
|
browser_compositor_->SetRenderWidgetHostIsHidden(true);
|
||||||
|
#else
|
||||||
|
GetDelegatedFrameHost()->WasHidden();
|
||||||
|
GetDelegatedFrameHost()->ResetCompositor();
|
||||||
|
#endif
|
||||||
|
|
||||||
is_showing_ = false;
|
is_showing_ = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -537,14 +561,23 @@ void OffScreenRenderWidgetHostView::OnSwapCompositorFrame(
|
||||||
software_output_device_->SetActive(painting_);
|
software_output_device_->SetActive(painting_);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// The compositor will draw directly to the SoftwareOutputDevice which
|
||||||
|
// then calls OnPaint.
|
||||||
|
#if defined(OS_MACOSX)
|
||||||
|
browser_compositor_->SwapCompositorFrame(output_surface_id,
|
||||||
|
std::move(frame));
|
||||||
|
#else
|
||||||
delegated_frame_host_->SwapDelegatedFrame(output_surface_id,
|
delegated_frame_host_->SwapDelegatedFrame(output_surface_id,
|
||||||
std::move(frame));
|
std::move(frame));
|
||||||
|
#endif
|
||||||
} else {
|
} else {
|
||||||
if (!copy_frame_generator_.get()) {
|
if (!copy_frame_generator_.get()) {
|
||||||
copy_frame_generator_.reset(
|
copy_frame_generator_.reset(
|
||||||
new AtomCopyFrameGenerator(frame_rate_threshold_ms_, this));
|
new AtomCopyFrameGenerator(frame_rate_threshold_ms_, this));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Determine the damage rectangle for the current frame. This is the same
|
||||||
|
// calculation that SwapDelegatedFrame uses.
|
||||||
cc::RenderPass* root_pass =
|
cc::RenderPass* root_pass =
|
||||||
frame.delegated_frame_data->render_pass_list.back().get();
|
frame.delegated_frame_data->render_pass_list.back().get();
|
||||||
gfx::Size frame_size = root_pass->output_rect.size();
|
gfx::Size frame_size = root_pass->output_rect.size();
|
||||||
|
@ -552,17 +585,23 @@ void OffScreenRenderWidgetHostView::OnSwapCompositorFrame(
|
||||||
gfx::ToEnclosingRect(gfx::RectF(root_pass->damage_rect));
|
gfx::ToEnclosingRect(gfx::RectF(root_pass->damage_rect));
|
||||||
damage_rect.Intersect(gfx::Rect(frame_size));
|
damage_rect.Intersect(gfx::Rect(frame_size));
|
||||||
|
|
||||||
|
#if defined(OS_MACOSX)
|
||||||
|
browser_compositor_->SwapCompositorFrame(output_surface_id,
|
||||||
|
std::move(frame));
|
||||||
|
#else
|
||||||
delegated_frame_host_->SwapDelegatedFrame(output_surface_id,
|
delegated_frame_host_->SwapDelegatedFrame(output_surface_id,
|
||||||
std::move(frame));
|
std::move(frame));
|
||||||
|
#endif
|
||||||
|
|
||||||
if (painting_)
|
// Request a copy of the last compositor frame which will eventually call
|
||||||
copy_frame_generator_->GenerateCopyFrame(true, damage_rect);
|
// OnPaint asynchronously.
|
||||||
|
copy_frame_generator_->GenerateCopyFrame(true, damage_rect);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void OffScreenRenderWidgetHostView::ClearCompositorFrame() {
|
void OffScreenRenderWidgetHostView::ClearCompositorFrame() {
|
||||||
delegated_frame_host_->ClearDelegatedFrame();
|
GetDelegatedFrameHost()->ClearDelegatedFrame();
|
||||||
}
|
}
|
||||||
|
|
||||||
void OffScreenRenderWidgetHostView::InitAsPopup(
|
void OffScreenRenderWidgetHostView::InitAsPopup(
|
||||||
|
@ -607,7 +646,7 @@ void OffScreenRenderWidgetHostView::CopyFromCompositingSurface(
|
||||||
const gfx::Size& dst_size,
|
const gfx::Size& dst_size,
|
||||||
const content::ReadbackRequestCallback& callback,
|
const content::ReadbackRequestCallback& callback,
|
||||||
const SkColorType preferred_color_type) {
|
const SkColorType preferred_color_type) {
|
||||||
delegated_frame_host_->CopyFromCompositingSurface(
|
GetDelegatedFrameHost()->CopyFromCompositingSurface(
|
||||||
src_subrect, dst_size, callback, preferred_color_type);
|
src_subrect, dst_size, callback, preferred_color_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -615,21 +654,21 @@ void OffScreenRenderWidgetHostView::CopyFromCompositingSurfaceToVideoFrame(
|
||||||
const gfx::Rect& src_subrect,
|
const gfx::Rect& src_subrect,
|
||||||
const scoped_refptr<media::VideoFrame>& target,
|
const scoped_refptr<media::VideoFrame>& target,
|
||||||
const base::Callback<void(const gfx::Rect&, bool)>& callback) {
|
const base::Callback<void(const gfx::Rect&, bool)>& callback) {
|
||||||
delegated_frame_host_->CopyFromCompositingSurfaceToVideoFrame(
|
GetDelegatedFrameHost()->CopyFromCompositingSurfaceToVideoFrame(
|
||||||
src_subrect, target, callback);
|
src_subrect, target, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool OffScreenRenderWidgetHostView::CanCopyToVideoFrame() const {
|
bool OffScreenRenderWidgetHostView::CanCopyToVideoFrame() const {
|
||||||
return delegated_frame_host_->CanCopyToVideoFrame();
|
return GetDelegatedFrameHost()->CanCopyToVideoFrame();
|
||||||
}
|
}
|
||||||
|
|
||||||
void OffScreenRenderWidgetHostView::BeginFrameSubscription(
|
void OffScreenRenderWidgetHostView::BeginFrameSubscription(
|
||||||
std::unique_ptr<content::RenderWidgetHostViewFrameSubscriber> subscriber) {
|
std::unique_ptr<content::RenderWidgetHostViewFrameSubscriber> subscriber) {
|
||||||
delegated_frame_host_->BeginFrameSubscription(std::move(subscriber));
|
GetDelegatedFrameHost()->BeginFrameSubscription(std::move(subscriber));
|
||||||
}
|
}
|
||||||
|
|
||||||
void OffScreenRenderWidgetHostView::EndFrameSubscription() {
|
void OffScreenRenderWidgetHostView::EndFrameSubscription() {
|
||||||
delegated_frame_host_->EndFrameSubscription();
|
GetDelegatedFrameHost()->EndFrameSubscription();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool OffScreenRenderWidgetHostView::HasAcceleratedSurface(const gfx::Size &) {
|
bool OffScreenRenderWidgetHostView::HasAcceleratedSurface(const gfx::Size &) {
|
||||||
|
@ -744,7 +783,7 @@ void OffScreenRenderWidgetHostView::SetBeginFrameSource(
|
||||||
std::unique_ptr<cc::SoftwareOutputDevice>
|
std::unique_ptr<cc::SoftwareOutputDevice>
|
||||||
OffScreenRenderWidgetHostView::CreateSoftwareOutputDevice(
|
OffScreenRenderWidgetHostView::CreateSoftwareOutputDevice(
|
||||||
ui::Compositor* compositor) {
|
ui::Compositor* compositor) {
|
||||||
DCHECK_EQ(compositor_.get(), compositor);
|
DCHECK_EQ(GetCompositor(), compositor);
|
||||||
DCHECK(!copy_frame_generator_);
|
DCHECK(!copy_frame_generator_);
|
||||||
DCHECK(!software_output_device_);
|
DCHECK(!software_output_device_);
|
||||||
|
|
||||||
|
@ -758,7 +797,11 @@ std::unique_ptr<cc::SoftwareOutputDevice>
|
||||||
bool OffScreenRenderWidgetHostView::InstallTransparency() {
|
bool OffScreenRenderWidgetHostView::InstallTransparency() {
|
||||||
if (transparent_) {
|
if (transparent_) {
|
||||||
SetBackgroundColor(SkColor());
|
SetBackgroundColor(SkColor());
|
||||||
|
#if defined(OS_MACOSX)
|
||||||
|
browser_compositor_->SetHasTransparentBackground(true);
|
||||||
|
#else
|
||||||
compositor_->SetHostHasTransparentBackground(true);
|
compositor_->SetHostHasTransparentBackground(true);
|
||||||
|
#endif
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -811,13 +854,28 @@ int OffScreenRenderWidgetHostView::GetFrameRate() const {
|
||||||
return frame_rate_;
|
return frame_rate_;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if !defined(OS_MACOSX)
|
||||||
|
ui::Compositor* OffScreenRenderWidgetHostView::GetCompositor() const {
|
||||||
|
return compositor_.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
ui::Layer* OffScreenRenderWidgetHostView::GetRootLayer() const {
|
||||||
|
return root_layer_.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
content::DelegatedFrameHost*
|
||||||
|
OffScreenRenderWidgetHostView::GetDelegatedFrameHost() const {
|
||||||
|
return delegated_frame_host_.get();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void OffScreenRenderWidgetHostView::SetupFrameRate(bool force) {
|
void OffScreenRenderWidgetHostView::SetupFrameRate(bool force) {
|
||||||
if (!force && frame_rate_threshold_ms_ != 0)
|
if (!force && frame_rate_threshold_ms_ != 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
frame_rate_threshold_ms_ = 1000 / frame_rate_;
|
frame_rate_threshold_ms_ = 1000 / frame_rate_;
|
||||||
|
|
||||||
compositor_->vsync_manager()->SetAuthoritativeVSyncInterval(
|
GetCompositor()->vsync_manager()->SetAuthoritativeVSyncInterval(
|
||||||
base::TimeDelta::FromMilliseconds(frame_rate_threshold_ms_));
|
base::TimeDelta::FromMilliseconds(frame_rate_threshold_ms_));
|
||||||
|
|
||||||
if (copy_frame_generator_.get()) {
|
if (copy_frame_generator_.get()) {
|
||||||
|
@ -843,14 +901,14 @@ void OffScreenRenderWidgetHostView::ResizeRootLayer() {
|
||||||
|
|
||||||
gfx::Size size = GetViewBounds().size();
|
gfx::Size size = GetViewBounds().size();
|
||||||
|
|
||||||
if (!scaleFactorDidChange && size == root_layer_->bounds().size())
|
if (!scaleFactorDidChange && size == GetRootLayer()->bounds().size())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
const gfx::Size& size_in_pixels =
|
const gfx::Size& size_in_pixels =
|
||||||
gfx::ConvertSizeToPixel(scale_factor_, size);
|
gfx::ConvertSizeToPixel(scale_factor_, size);
|
||||||
|
|
||||||
root_layer_->SetBounds(gfx::Rect(size));
|
GetRootLayer()->SetBounds(gfx::Rect(size));
|
||||||
compositor_->SetScaleAndSize(scale_factor_, size_in_pixels);
|
GetCompositor()->SetScaleAndSize(scale_factor_, size_in_pixels);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
|
@ -189,7 +189,10 @@ class OffScreenRenderWidgetHostView
|
||||||
void SetFrameRate(int frame_rate);
|
void SetFrameRate(int frame_rate);
|
||||||
int GetFrameRate() const;
|
int GetFrameRate() const;
|
||||||
|
|
||||||
ui::Compositor* compositor() const { return compositor_.get(); }
|
ui::Compositor* GetCompositor() const;
|
||||||
|
ui::Layer* GetRootLayer() const;
|
||||||
|
content::DelegatedFrameHost* GetDelegatedFrameHost() const;
|
||||||
|
|
||||||
content::RenderWidgetHostImpl* render_widget_host() const
|
content::RenderWidgetHostImpl* render_widget_host() const
|
||||||
{ return render_widget_host_; }
|
{ return render_widget_host_; }
|
||||||
NativeWindow* window() const { return native_window_; }
|
NativeWindow* window() const { return native_window_; }
|
||||||
|
@ -230,7 +233,7 @@ class OffScreenRenderWidgetHostView
|
||||||
|
|
||||||
// Can not be managed by smart pointer because its header can not be included
|
// Can not be managed by smart pointer because its header can not be included
|
||||||
// in the file that has the destructor.
|
// in the file that has the destructor.
|
||||||
MacHelper* nsview_;
|
MacHelper* mac_helper_;
|
||||||
|
|
||||||
// Selected text on the renderer.
|
// Selected text on the renderer.
|
||||||
std::string selected_text_;
|
std::string selected_text_;
|
||||||
|
|
|
@ -137,14 +137,27 @@ void OffScreenRenderWidgetHostView::SelectionChanged(
|
||||||
}
|
}
|
||||||
|
|
||||||
void OffScreenRenderWidgetHostView::CreatePlatformWidget() {
|
void OffScreenRenderWidgetHostView::CreatePlatformWidget() {
|
||||||
nsview_ = new MacHelper(this);
|
mac_helper_ = new MacHelper(this);
|
||||||
browser_compositor_.reset(new content::BrowserCompositorMac(
|
browser_compositor_.reset(new content::BrowserCompositorMac(
|
||||||
nsview_, nsview_, render_widget_host_->is_hidden(), true));
|
mac_helper_, mac_helper_, render_widget_host_->is_hidden(), true));
|
||||||
}
|
}
|
||||||
|
|
||||||
void OffScreenRenderWidgetHostView::DestroyPlatformWidget() {
|
void OffScreenRenderWidgetHostView::DestroyPlatformWidget() {
|
||||||
browser_compositor_.reset();
|
browser_compositor_.reset();
|
||||||
delete nsview_;
|
delete mac_helper_;
|
||||||
|
}
|
||||||
|
|
||||||
|
ui::Compositor* OffScreenRenderWidgetHostView::GetCompositor() const {
|
||||||
|
return browser_compositor_->GetCompositor();
|
||||||
|
}
|
||||||
|
|
||||||
|
ui::Layer* OffScreenRenderWidgetHostView::GetRootLayer() const {
|
||||||
|
return browser_compositor_->GetRootLayer();
|
||||||
|
}
|
||||||
|
|
||||||
|
content::DelegatedFrameHost*
|
||||||
|
OffScreenRenderWidgetHostView::GetDelegatedFrameHost() const {
|
||||||
|
return browser_compositor_->GetDelegatedFrameHost();
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
|
@ -9,7 +9,7 @@ import sys
|
||||||
BASE_URL = os.getenv('LIBCHROMIUMCONTENT_MIRROR') or \
|
BASE_URL = os.getenv('LIBCHROMIUMCONTENT_MIRROR') or \
|
||||||
'https://s3.amazonaws.com/github-janky-artifacts/libchromiumcontent'
|
'https://s3.amazonaws.com/github-janky-artifacts/libchromiumcontent'
|
||||||
LIBCHROMIUMCONTENT_COMMIT = os.getenv('LIBCHROMIUMCONTENT_COMMIT') or \
|
LIBCHROMIUMCONTENT_COMMIT = os.getenv('LIBCHROMIUMCONTENT_COMMIT') or \
|
||||||
'60ec84b4b3ee4862aa8c93c0e0e04871ee3ac177'
|
'346dfe40a9658cc40924d29a1deb1d9669509076'
|
||||||
|
|
||||||
PLATFORM = {
|
PLATFORM = {
|
||||||
'cygwin': 'win32',
|
'cygwin': 'win32',
|
||||||
|
|
Loading…
Reference in a new issue