aboutsummaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorGravatar junov@chromium.org <junov@chromium.org@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-02-23 21:34:34 +0000
committerGravatar junov@chromium.org <junov@chromium.org@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-02-23 21:34:34 +0000
commit87f982c80833eeebf541becec8e27b96c8c889f7 (patch)
treed969da661578cdb6fe017ac6d4b87ca8842e3657 /src
parent809a2a9fb7deffacd9d2d37ba06a5202d90ee649 (diff)
Fix for crash in SkDeferredCanvas when optional SkPaint argument is NULL
Diffstat (limited to 'src')
-rw-r--r--src/utils/SkDeferredCanvas.cpp35
1 files changed, 20 insertions, 15 deletions
diff --git a/src/utils/SkDeferredCanvas.cpp b/src/utils/SkDeferredCanvas.cpp
index 19b98a8f63..00a26b91dd 100644
--- a/src/utils/SkDeferredCanvas.cpp
+++ b/src/utils/SkDeferredCanvas.cpp
@@ -15,47 +15,52 @@
namespace {
-bool isPaintOpaque(const SkPaint& paint, const SkBitmap* bmpReplacesShader = NULL) {
+bool isPaintOpaque(const SkPaint* paint, const SkBitmap* bmpReplacesShader = NULL) {
// TODO: SkXfermode should have a virtual isOpaque method, which would
// make it possible to test modes that do not have a Coeff representation.
+
+ if (!paint) {
+ return bmpReplacesShader ? bmpReplacesShader->isOpaque() : true;
+ }
+
SkXfermode::Coeff srcCoeff, dstCoeff;
- if (SkXfermode::AsCoeff(paint.getXfermode(), &srcCoeff, &dstCoeff)){
+ if (SkXfermode::AsCoeff(paint->getXfermode(), &srcCoeff, &dstCoeff)){
switch (dstCoeff) {
case SkXfermode::kZero_Coeff:
return true;
case SkXfermode::kISA_Coeff:
- if (paint.getAlpha() != 255) {
+ if (paint->getAlpha() != 255) {
break;
}
if (bmpReplacesShader) {
if (!bmpReplacesShader->isOpaque()) {
break;
}
- } else if (paint.getShader() && !paint.getShader()->isOpaque()) {
+ } else if (paint->getShader() && !paint->getShader()->isOpaque()) {
break;
}
- if (paint.getColorFilter() && ((paint.getColorFilter()->getFlags() &
+ if (paint->getColorFilter() && ((paint->getColorFilter()->getFlags() &
SkColorFilter::kAlphaUnchanged_Flag) == 0)) {
break;
}
return true;
case SkXfermode::kSA_Coeff:
- if (paint.getAlpha() != 0) {
+ if (paint->getAlpha() != 0) {
break;
}
- if (paint.getColorFilter() && ((paint.getColorFilter()->getFlags() &
+ if (paint->getColorFilter() && ((paint->getColorFilter()->getFlags() &
SkColorFilter::kAlphaUnchanged_Flag) == 0)) {
break;
}
return true;
case SkXfermode::kSC_Coeff:
- if (paint.getColor() != 0) { // all components must be 0
+ if (paint->getColor() != 0) { // all components must be 0
break;
}
- if (bmpReplacesShader || paint.getShader()) {
+ if (bmpReplacesShader || paint->getShader()) {
break;
}
- if (paint.getColorFilter() && ((paint.getColorFilter()->getFlags() &
+ if (paint->getColorFilter() && ((paint->getColorFilter()->getFlags() &
SkColorFilter::kAlphaUnchanged_Flag) == 0)) {
break;
}
@@ -297,7 +302,7 @@ void SkDeferredCanvas::clear(SkColor color)
void SkDeferredCanvas::drawPaint(const SkPaint& paint)
{
- if (fDeferredDrawing && isFullFrame(NULL, &paint) && isPaintOpaque(paint)) {
+ if (fDeferredDrawing && isFullFrame(NULL, &paint) && isPaintOpaque(&paint)) {
getDeferredDevice()->contentsCleared();
}
@@ -312,7 +317,7 @@ void SkDeferredCanvas::drawPoints(PointMode mode, size_t count,
void SkDeferredCanvas::drawRect(const SkRect& rect, const SkPaint& paint)
{
- if (fDeferredDrawing && isFullFrame(&rect, &paint) && isPaintOpaque(paint)) {
+ if (fDeferredDrawing && isFullFrame(&rect, &paint) && isPaintOpaque(&paint)) {
getDeferredDevice()->contentsCleared();
}
@@ -331,7 +336,7 @@ void SkDeferredCanvas::drawBitmap(const SkBitmap& bitmap, SkScalar left,
SkIntToScalar(bitmap.width()), SkIntToScalar(bitmap.height()));
if (fDeferredDrawing &&
isFullFrame(&bitmapRect, paint) &&
- isPaintOpaque(*paint, &bitmap)) {
+ isPaintOpaque(paint, &bitmap)) {
getDeferredDevice()->contentsCleared();
}
@@ -345,7 +350,7 @@ void SkDeferredCanvas::drawBitmapRect(const SkBitmap& bitmap,
{
if (fDeferredDrawing &&
isFullFrame(&dst, paint) &&
- isPaintOpaque(*paint, &bitmap)) {
+ isPaintOpaque(paint, &bitmap)) {
getDeferredDevice()->contentsCleared();
}
@@ -386,7 +391,7 @@ void SkDeferredCanvas::drawSprite(const SkBitmap& bitmap, int left, int top,
SkIntToScalar(bitmap.height()));
if (fDeferredDrawing &&
isFullFrame(&bitmapRect, paint) &&
- isPaintOpaque(*paint, &bitmap)) {
+ isPaintOpaque(paint, &bitmap)) {
getDeferredDevice()->contentsCleared();
}