| Index: src/effects/gradients/SkTwoPointRadialGradient.cpp
 | 
| diff --git a/src/effects/gradients/SkTwoPointRadialGradient.cpp b/src/effects/gradients/SkTwoPointRadialGradient.cpp
 | 
| index a598c6e0e371d0ae9d8d368ebae987b81895f9b9..e1359b12ddce37f130deed9f1e90e1cb52cc7d48 100644
 | 
| --- a/src/effects/gradients/SkTwoPointRadialGradient.cpp
 | 
| +++ b/src/effects/gradients/SkTwoPointRadialGradient.cpp
 | 
| @@ -220,60 +220,23 @@
 | 
|      return kRadial2_GradientType;
 | 
|  }
 | 
|  
 | 
| -size_t SkTwoPointRadialGradient::contextSize() const {
 | 
| -    return sizeof(TwoPointRadialGradientContext);
 | 
| -}
 | 
| -
 | 
| -bool SkTwoPointRadialGradient::validContext(const SkBitmap& device, const SkPaint& paint,
 | 
| -                                            const SkMatrix& matrix, SkMatrix* totalInverse) const {
 | 
| -    // For now, we might have divided by zero, so detect that.
 | 
| -    if (0 == fDiffRadius) {
 | 
| -        return false;
 | 
| -    }
 | 
| -
 | 
| -    return this->INHERITED::validContext(device, paint, matrix, totalInverse);
 | 
| -}
 | 
| -
 | 
| -SkShader::Context* SkTwoPointRadialGradient::createContext(
 | 
| -        const SkBitmap& device, const SkPaint& paint,
 | 
| -        const SkMatrix& matrix, void* storage) const {
 | 
| -    if (!this->validContext(device, paint, matrix)) {
 | 
| -        return NULL;
 | 
| -    }
 | 
| -
 | 
| -    return SkNEW_PLACEMENT_ARGS(storage, TwoPointRadialGradientContext,
 | 
| -                                (*this, device, paint, matrix));
 | 
| -}
 | 
| -
 | 
| -SkTwoPointRadialGradient::TwoPointRadialGradientContext::TwoPointRadialGradientContext(
 | 
| -        const SkTwoPointRadialGradient& shader, const SkBitmap& device,
 | 
| -        const SkPaint& paint, const SkMatrix& matrix)
 | 
| -    : INHERITED(shader, device, paint, matrix)
 | 
| -{
 | 
| -    // we don't have a span16 proc
 | 
| -    fFlags &= ~kHasSpan16_Flag;
 | 
| -}
 | 
| -
 | 
| -void SkTwoPointRadialGradient::TwoPointRadialGradientContext::shadeSpan(
 | 
| -        int x, int y, SkPMColor* dstCParam, int count) {
 | 
| +void SkTwoPointRadialGradient::shadeSpan(int x, int y, SkPMColor* dstCParam,
 | 
| +                                         int count) {
 | 
|      SkASSERT(count > 0);
 | 
|  
 | 
| -    const SkTwoPointRadialGradient& twoPointRadialGradient =
 | 
| -            static_cast<const SkTwoPointRadialGradient&>(fShader);
 | 
| -
 | 
|      SkPMColor* SK_RESTRICT dstC = dstCParam;
 | 
|  
 | 
|      // Zero difference between radii:  fill with transparent black.
 | 
| -    if (twoPointRadialGradient.fDiffRadius == 0) {
 | 
| +    if (fDiffRadius == 0) {
 | 
|        sk_bzero(dstC, count * sizeof(*dstC));
 | 
|        return;
 | 
|      }
 | 
|      SkMatrix::MapXYProc dstProc = fDstToIndexProc;
 | 
| -    TileProc            proc = twoPointRadialGradient.fTileProc;
 | 
| -    const SkPMColor* SK_RESTRICT cache = fCache->getCache32();
 | 
| -
 | 
| -    SkScalar foura = twoPointRadialGradient.fA * 4;
 | 
| -    bool posRoot = twoPointRadialGradient.fDiffRadius < 0;
 | 
| +    TileProc            proc = fTileProc;
 | 
| +    const SkPMColor* SK_RESTRICT cache = this->getCache32();
 | 
| +
 | 
| +    SkScalar foura = fA * 4;
 | 
| +    bool posRoot = fDiffRadius < 0;
 | 
|      if (fDstToIndexClass != kPerspective_MatrixClass) {
 | 
|          SkPoint srcPt;
 | 
|          dstProc(fDstToIndex, SkIntToScalar(x) + SK_ScalarHalf,
 | 
| @@ -291,23 +254,21 @@
 | 
|              dx = fDstToIndex.getScaleX();
 | 
|              dy = fDstToIndex.getSkewY();
 | 
|          }
 | 
| -        SkScalar b = (SkScalarMul(twoPointRadialGradient.fDiff.fX, fx) +
 | 
| -                     SkScalarMul(twoPointRadialGradient.fDiff.fY, fy) -
 | 
| -                     twoPointRadialGradient.fStartRadius) * 2;
 | 
| -        SkScalar db = (SkScalarMul(twoPointRadialGradient.fDiff.fX, dx) +
 | 
| -                      SkScalarMul(twoPointRadialGradient.fDiff.fY, dy)) * 2;
 | 
| +        SkScalar b = (SkScalarMul(fDiff.fX, fx) +
 | 
| +                     SkScalarMul(fDiff.fY, fy) - fStartRadius) * 2;
 | 
| +        SkScalar db = (SkScalarMul(fDiff.fX, dx) +
 | 
| +                      SkScalarMul(fDiff.fY, dy)) * 2;
 | 
|  
 | 
|          TwoPointRadialShadeProc shadeProc = shadeSpan_twopoint_repeat;
 | 
| -        if (SkShader::kClamp_TileMode == twoPointRadialGradient.fTileMode) {
 | 
| +        if (SkShader::kClamp_TileMode == fTileMode) {
 | 
|              shadeProc = shadeSpan_twopoint_clamp;
 | 
| -        } else if (SkShader::kMirror_TileMode == twoPointRadialGradient.fTileMode) {
 | 
| +        } else if (SkShader::kMirror_TileMode == fTileMode) {
 | 
|              shadeProc = shadeSpan_twopoint_mirror;
 | 
|          } else {
 | 
| -            SkASSERT(SkShader::kRepeat_TileMode == twoPointRadialGradient.fTileMode);
 | 
| +            SkASSERT(SkShader::kRepeat_TileMode == fTileMode);
 | 
|          }
 | 
|          (*shadeProc)(fx, dx, fy, dy, b, db,
 | 
| -                     twoPointRadialGradient.fSr2D2, foura,
 | 
| -                     twoPointRadialGradient.fOneOverTwoA, posRoot,
 | 
| +                     fSr2D2, foura, fOneOverTwoA, posRoot,
 | 
|                       dstC, cache, count);
 | 
|      } else {    // perspective case
 | 
|          SkScalar dstX = SkIntToScalar(x);
 | 
| @@ -317,17 +278,33 @@
 | 
|              dstProc(fDstToIndex, dstX, dstY, &srcPt);
 | 
|              SkScalar fx = srcPt.fX;
 | 
|              SkScalar fy = srcPt.fY;
 | 
| -            SkScalar b = (SkScalarMul(twoPointRadialGradient.fDiff.fX, fx) +
 | 
| -                         SkScalarMul(twoPointRadialGradient.fDiff.fY, fy) -
 | 
| -                         twoPointRadialGradient.fStartRadius) * 2;
 | 
| -            SkFixed t = two_point_radial(b, fx, fy, twoPointRadialGradient.fSr2D2, foura,
 | 
| -                                         twoPointRadialGradient.fOneOverTwoA, posRoot);
 | 
| +            SkScalar b = (SkScalarMul(fDiff.fX, fx) +
 | 
| +                         SkScalarMul(fDiff.fY, fy) - fStartRadius) * 2;
 | 
| +            SkFixed t = two_point_radial(b, fx, fy, fSr2D2, foura,
 | 
| +                                         fOneOverTwoA, posRoot);
 | 
|              SkFixed index = proc(t);
 | 
|              SkASSERT(index <= 0xFFFF);
 | 
|              *dstC++ = cache[index >> SkGradientShaderBase::kCache32Shift];
 | 
|              dstX += SK_Scalar1;
 | 
|          }
 | 
|      }
 | 
| +}
 | 
| +
 | 
| +bool SkTwoPointRadialGradient::setContext( const SkBitmap& device,
 | 
| +                                          const SkPaint& paint,
 | 
| +                                          const SkMatrix& matrix){
 | 
| +    // For now, we might have divided by zero, so detect that
 | 
| +    if (0 == fDiffRadius) {
 | 
| +        return false;
 | 
| +    }
 | 
| +
 | 
| +    if (!this->INHERITED::setContext(device, paint, matrix)) {
 | 
| +        return false;
 | 
| +    }
 | 
| +
 | 
| +    // we don't have a span16 proc
 | 
| +    fFlags &= ~kHasSpan16_Flag;
 | 
| +    return true;
 | 
|  }
 | 
|  
 | 
|  #ifndef SK_IGNORE_TO_STRING
 | 
| 
 |