Reland "SkSL is now pickier about type conversions"
This is a reland of 91c1d08bc391c997418512b9599f3acd3b2c985d
Original change's description:
> SkSL is now pickier about type conversions
>
> Bug: skia:
> Change-Id: I4e8b8f229f4e4344f160b0dbb41832764d0b75bd
> Reviewed-on: https://skia-review.googlesource.com/c/188311
> Commit-Queue: Ethan Nicholas <ethannicholas@google.com>
> Reviewed-by: Brian Salomon <bsalomon@google.com>
Bug: skia:
Change-Id: I727cad061afc0a5ee6f4d2df789330d809dd110a
Reviewed-on: https://skia-review.googlesource.com/c/189643
Reviewed-by: Ethan Nicholas <ethannicholas@google.com>
Commit-Queue: Ethan Nicholas <ethannicholas@google.com>
diff --git a/src/gpu/ccpr/GrCCQuadraticShader.cpp b/src/gpu/ccpr/GrCCQuadraticShader.cpp
index bd79be3..4f248cb 100644
--- a/src/gpu/ccpr/GrCCQuadraticShader.cpp
+++ b/src/gpu/ccpr/GrCCQuadraticShader.cpp
@@ -69,10 +69,10 @@
this->calcHullCoverage(&AccessCodeString(f), fCoord_fGrad.fsIn(),
SkStringPrintf("%s.x", fEdge_fWind_fCorner.fsIn()).c_str(),
outputCoverage);
- f->codeAppendf("%s *= %s.y;", outputCoverage, fEdge_fWind_fCorner.fsIn()); // Wind.
+ f->codeAppendf("%s *= half(%s.y);", outputCoverage, fEdge_fWind_fCorner.fsIn()); // Wind.
if (kFloat4_GrSLType == fEdge_fWind_fCorner.type()) {
- f->codeAppendf("%s = %s.z * %s.w + %s;",// Attenuated corner coverage.
+ f->codeAppendf("%s = half(%s.z * %s.w) + %s;",// Attenuated corner coverage.
outputCoverage, fEdge_fWind_fCorner.fsIn(), fEdge_fWind_fCorner.fsIn(),
outputCoverage);
}
@@ -84,7 +84,9 @@
code->appendf("float2 grad = %s.zw;", coordAndGrad);
code->append ("float f = x*x - y;");
code->append ("float fwidth = abs(grad.x) + abs(grad.y);");
- code->appendf("%s = min(0.5 - f/fwidth, 1);", outputCoverage); // Curve coverage.
- code->appendf("half d = min(%s, 0);", edge); // Flat edge opposite the curve.
- code->appendf("%s = max(%s + d, 0);", outputCoverage, outputCoverage); // Total hull coverage.
+ code->appendf("float curve_coverage = min(0.5 - f/fwidth, 1);");
+ // Flat edge opposite the curve.
+ code->appendf("float edge_coverage = min(%s, 0);", edge);
+ // Total hull coverage.
+ code->appendf("%s = max(half(curve_coverage + edge_coverage), 0);", outputCoverage);
}