Index: third_party/WebKit/Source/core/frame/ImageBitmap.h |
diff --git a/third_party/WebKit/Source/core/frame/ImageBitmap.h b/third_party/WebKit/Source/core/frame/ImageBitmap.h |
index 59fbf3362f5c6d1b4df2c660b749340cbd4c4b32..12e31d0dc68a3db11b99529f2c8698a4e75dd7d5 100644 |
--- a/third_party/WebKit/Source/core/frame/ImageBitmap.h |
+++ b/third_party/WebKit/Source/core/frame/ImageBitmap.h |
@@ -28,13 +28,13 @@ class CORE_EXPORT ImageBitmap final : public RefCountedWillBeGarbageCollectedFin |
DEFINE_WRAPPERTYPEINFO(); |
WILL_BE_USING_GARBAGE_COLLECTED_MIXIN(ImageBitmap); |
public: |
- static PassRefPtrWillBeRawPtr<ImageBitmap> create(HTMLImageElement*, const IntRect&); |
- static PassRefPtrWillBeRawPtr<ImageBitmap> create(HTMLVideoElement*, const IntRect&); |
+ static PassRefPtrWillBeRawPtr<ImageBitmap> create(HTMLImageElement*, const IntRect&, Document*); |
+ static PassRefPtrWillBeRawPtr<ImageBitmap> create(HTMLVideoElement*, const IntRect&, Document*); |
static PassRefPtrWillBeRawPtr<ImageBitmap> create(HTMLCanvasElement*, const IntRect&); |
static PassRefPtrWillBeRawPtr<ImageBitmap> create(ImageData*, const IntRect&); |
static PassRefPtrWillBeRawPtr<ImageBitmap> create(ImageBitmap*, const IntRect&); |
- static PassRefPtrWillBeRawPtr<ImageBitmap> create(Image*, const IntRect&); |
static PassRefPtrWillBeRawPtr<ImageBitmap> create(PassRefPtr<StaticBitmapImage>); |
+ static PassRefPtrWillBeRawPtr<ImageBitmap> create(PassRefPtr<StaticBitmapImage>, const IntRect&); |
StaticBitmapImage* bitmapImage() const { return (m_image) ? m_image.get() : nullptr; } |
unsigned long width() const; |
@@ -42,13 +42,14 @@ public: |
IntSize size() const; |
bool isNeutered() const { return m_isNeutered; } |
+ bool originClean() const { return m_isOriginClean; } |
PassRefPtr<StaticBitmapImage> transfer(); |
~ImageBitmap() override; |
// CanvasImageSource implementation |
PassRefPtr<Image> getSourceImageForCanvas(SourceImageStatus*, AccelerationHint) const override; |
- bool wouldTaintOrigin(SecurityOrigin*) const override { return false; } |
+ bool wouldTaintOrigin(SecurityOrigin*) const override { return !m_isOriginClean; } |
void adjustDrawRects(FloatRect* srcRect, FloatRect* dstRect) const override; |
FloatSize elementSize() const override; |
@@ -59,13 +60,13 @@ public: |
DECLARE_VIRTUAL_TRACE(); |
private: |
- ImageBitmap(HTMLImageElement*, const IntRect&); |
- ImageBitmap(HTMLVideoElement*, const IntRect&); |
+ ImageBitmap(HTMLImageElement*, const IntRect&, Document*); |
+ ImageBitmap(HTMLVideoElement*, const IntRect&, Document*); |
ImageBitmap(HTMLCanvasElement*, const IntRect&); |
ImageBitmap(ImageData*, const IntRect&); |
ImageBitmap(ImageBitmap*, const IntRect&); |
- ImageBitmap(Image*, const IntRect&); |
ImageBitmap(PassRefPtr<StaticBitmapImage>); |
+ ImageBitmap(PassRefPtr<StaticBitmapImage>, const IntRect&); |
// ImageLoaderClient |
void notifyImageSourceChanged() override; |
@@ -73,6 +74,7 @@ private: |
RefPtr<StaticBitmapImage> m_image; |
bool m_isNeutered = false; |
+ bool m_isOriginClean = true; |
Justin Novosad
2016/01/08 22:09:39
Can we safely get rid of this and just always use
xidachen
2016/01/09 12:23:47
This makes perfect sense and it is not hard. Since
|
}; |
} // namespace blink |