aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/gpu/GrProcessorSet.h
diff options
context:
space:
mode:
authorGravatar Brian Salomon <bsalomon@google.com>2017-03-27 13:09:36 -0400
committerGravatar Skia Commit-Bot <skia-commit-bot@chromium.org>2017-03-27 17:45:29 +0000
commitc0b642ca48d58416409e555549434066f09692b7 (patch)
tree42de3fb562c64c5bd22f9f7622ba8ae699ad3e08 /src/gpu/GrProcessorSet.h
parent88f9c1eff96a12cfa42db5c238ed42623762d90c (diff)
Split GrPipelineInput into separate color and coverage types, the latter of which is just an enum.
Assign names that indicate that they aren't just for the input phase since I plan to use them at the boundary between FPs and XPs as well. Renamed GrProcOptInfo to GrColorFragmentProcessorAnalysis. This is now only used on the color side and the new name seems clearer to me. Change GrMeshDrawOp::getFragmentProcessorAnalysisInputs to use the new color/coverage types directly rather than a class that has been reduced to simply bundling them together. Change-Id: If93bae74c9d590486eecdf63f302418c96deab65 Reviewed-on: https://skia-review.googlesource.com/10161 Commit-Queue: Brian Salomon <bsalomon@google.com> Reviewed-by: Greg Daniel <egdaniel@google.com>
Diffstat (limited to 'src/gpu/GrProcessorSet.h')
-rw-r--r--src/gpu/GrProcessorSet.h30
1 files changed, 15 insertions, 15 deletions
diff --git a/src/gpu/GrProcessorSet.h b/src/gpu/GrProcessorSet.h
index 71ab2d0f9f..bfad769a18 100644
--- a/src/gpu/GrProcessorSet.h
+++ b/src/gpu/GrProcessorSet.h
@@ -10,7 +10,7 @@
#include "GrFragmentProcessor.h"
#include "GrPaint.h"
-#include "GrPipelineInput.h"
+#include "GrPipelineAnalysis.h"
#include "SkTemplates.h"
class GrAppliedClip;
@@ -79,16 +79,16 @@ public:
: fIsInitializedWithProcessorSet(false)
, fCompatibleWithCoverageAsAlpha(true)
, fValidInputColor(false)
- , fOutputCoverageType(static_cast<unsigned>(CoverageType::kNone))
+ , fOutputCoverageType(static_cast<unsigned>(GrPipelineAnalysisCoverage::kNone))
, fOutputColorType(static_cast<unsigned>(ColorType::kUnknown))
, fInitialColorProcessorsToEliminate(0) {}
// This version is used by a unit test that assumes no clip, no processors, and no PLS.
- FragmentProcessorAnalysis(const GrPipelineInput& colorInput,
- const GrPipelineInput coverageInput, const GrCaps&);
+ FragmentProcessorAnalysis(const GrPipelineAnalysisColor&, GrPipelineAnalysisCoverage,
+ const GrCaps&);
- void init(const GrPipelineInput& colorInput, const GrPipelineInput coverageInput,
- const GrProcessorSet&, const GrAppliedClip*, const GrCaps&);
+ void init(const GrPipelineAnalysisColor&, GrPipelineAnalysisCoverage, const GrProcessorSet&,
+ const GrAppliedClip*, const GrCaps&);
bool isInitializedWithProcessorSet() const { return fIsInitializedWithProcessorSet; }
@@ -132,19 +132,19 @@ public:
}
return constant;
}
- bool hasCoverage() const { return CoverageType::kNone != this->outputCoverageType(); }
- bool hasLCDCoverage() const { return CoverageType::kLCD == this->outputCoverageType(); }
+ GrPipelineAnalysisCoverage outputCoverageType() const {
+ return static_cast<GrPipelineAnalysisCoverage>(fOutputCoverageType);
+ }
+ bool hasCoverage() const {
+ return this->outputCoverageType() != GrPipelineAnalysisCoverage::kNone;
+ }
private:
enum class ColorType : unsigned { kUnknown, kOpaqueConstant, kConstant, kOpaque };
- enum class CoverageType : unsigned { kNone, kSingleChannel, kLCD };
- CoverageType outputCoverageType() const {
- return static_cast<CoverageType>(fOutputCoverageType);
- }
ColorType outputColorType() const { return static_cast<ColorType>(fOutputColorType); }
- void internalInit(const GrPipelineInput& colorInput, const GrPipelineInput coverageInput,
+ void internalInit(const GrPipelineAnalysisColor&, const GrPipelineAnalysisCoverage,
const GrProcessorSet&, const GrFragmentProcessor* clipFP, const GrCaps&);
// MSVS 2015 won't pack a bool with an unsigned.
@@ -166,8 +166,8 @@ public:
GR_STATIC_ASSERT(sizeof(FragmentProcessorAnalysis) == 2 * sizeof(GrColor) + sizeof(uint32_t));
void analyzeAndEliminateFragmentProcessors(FragmentProcessorAnalysis*,
- const GrPipelineInput& colorInput,
- const GrPipelineInput coverageInput,
+ const GrPipelineAnalysisColor& colorInput,
+ const GrPipelineAnalysisCoverage coverageInput,
const GrAppliedClip*, const GrCaps&);
private: