Index: src/core/SkXfermode.cpp |
diff --git a/src/core/SkXfermode.cpp b/src/core/SkXfermode.cpp |
index 83503659bd61098fe2140a6add8ff7c51c46085b..cfd8352c454b1cee095d7fa67a33869fb8b95626 100644 |
--- a/src/core/SkXfermode.cpp |
+++ b/src/core/SkXfermode.cpp |
@@ -689,25 +689,19 @@ bool SkXfermode::asXPFactory(GrXPFactory**) const { |
bool SkXfermode::AsFragmentProcessorOrXPFactory(SkXfermode* xfermode, |
GrFragmentProcessor** fp, |
- GrXPFactory** xpf, |
- Coeff* src, Coeff* dst) { |
+ GrXPFactory** xpf) { |
+ Coeff src, dst; |
Mode mode; |
if (NULL == xfermode) { |
- SkAssertResult(ModeAsCoeff(kSrcOver_Mode, src, dst)); |
- *xpf = GrPorterDuffXPFactory::Create(*src, *dst); |
+ *xpf = GrPorterDuffXPFactory::Create(kSrcOver_Mode); |
return true; |
} else if (xfermode->asMode(&mode) && mode <= kLastCoeffMode) { |
*xpf = GrPorterDuffXPFactory::Create(mode); |
- // TODO: This Line will be removed in follow up cl that handles blending and thus we won't |
- // have to set coeffs here. |
- SkAssertResult(ModeAsCoeff(mode, src, dst)); |
return true; |
- } else if (xfermode->asCoeff(src, dst)) { |
- *xpf = GrPorterDuffXPFactory::Create(*src, *dst); |
+ } else if (xfermode->asCoeff(&src, &dst)) { |
+ *xpf = GrPorterDuffXPFactory::Create(src, dst); |
return true; |
} else if (xfermode->asXPFactory(xpf)) { |
- *src = SkXfermode::kOne_Coeff; |
- *dst = SkXfermode::kZero_Coeff; |
return true; |
} else { |
return xfermode->asFragmentProcessor(fp); |