diff options
Diffstat (limited to 'src/sksl/SkSLContext.h')
-rw-r--r-- | src/sksl/SkSLContext.h | 210 |
1 files changed, 108 insertions, 102 deletions
diff --git a/src/sksl/SkSLContext.h b/src/sksl/SkSLContext.h index a42a4cc855..05e08f24cb 100644 --- a/src/sksl/SkSLContext.h +++ b/src/sksl/SkSLContext.h @@ -19,114 +19,120 @@ namespace SkSL { class Context { public: Context() - : fInvalid_Type(new Type("<INVALID>")) - , fVoid_Type(new Type("void")) - , fDouble_Type(new Type("double", true)) - , fDVec2_Type(new Type("dvec2", *fDouble_Type, 2)) - , fDVec3_Type(new Type("dvec3", *fDouble_Type, 3)) - , fDVec4_Type(new Type("dvec4", *fDouble_Type, 4)) - , fFloat_Type(new Type("float", true, { fDouble_Type.get() })) - , fVec2_Type(new Type("vec2", *fFloat_Type, 2)) - , fVec3_Type(new Type("vec3", *fFloat_Type, 3)) - , fVec4_Type(new Type("vec4", *fFloat_Type, 4)) - , fUInt_Type(new Type("uint", true, { fFloat_Type.get(), fDouble_Type.get() })) - , fUVec2_Type(new Type("uvec2", *fUInt_Type, 2)) - , fUVec3_Type(new Type("uvec3", *fUInt_Type, 3)) - , fUVec4_Type(new Type("uvec4", *fUInt_Type, 4)) - , fInt_Type(new Type("int", true, { fUInt_Type.get(), fFloat_Type.get(), fDouble_Type.get() })) - , fIVec2_Type(new Type("ivec2", *fInt_Type, 2)) - , fIVec3_Type(new Type("ivec3", *fInt_Type, 3)) - , fIVec4_Type(new Type("ivec4", *fInt_Type, 4)) - , fBool_Type(new Type("bool", false)) - , fBVec2_Type(new Type("bvec2", *fBool_Type, 2)) - , fBVec3_Type(new Type("bvec3", *fBool_Type, 3)) - , fBVec4_Type(new Type("bvec4", *fBool_Type, 4)) - , fMat2x2_Type(new Type("mat2", *fFloat_Type, 2, 2)) - , fMat2x3_Type(new Type("mat2x3", *fFloat_Type, 2, 3)) - , fMat2x4_Type(new Type("mat2x4", *fFloat_Type, 2, 4)) - , fMat3x2_Type(new Type("mat3x2", *fFloat_Type, 3, 2)) - , fMat3x3_Type(new Type("mat3", *fFloat_Type, 3, 3)) - , fMat3x4_Type(new Type("mat3x4", *fFloat_Type, 3, 4)) - , fMat4x2_Type(new Type("mat4x2", *fFloat_Type, 4, 2)) - , fMat4x3_Type(new Type("mat4x3", *fFloat_Type, 4, 3)) - , fMat4x4_Type(new Type("mat4", *fFloat_Type, 4, 4)) - , fDMat2x2_Type(new Type("dmat2", *fFloat_Type, 2, 2)) - , fDMat2x3_Type(new Type("dmat2x3", *fFloat_Type, 2, 3)) - , fDMat2x4_Type(new Type("dmat2x4", *fFloat_Type, 2, 4)) - , fDMat3x2_Type(new Type("dmat3x2", *fFloat_Type, 3, 2)) - , fDMat3x3_Type(new Type("dmat3", *fFloat_Type, 3, 3)) - , fDMat3x4_Type(new Type("dmat3x4", *fFloat_Type, 3, 4)) - , fDMat4x2_Type(new Type("dmat4x2", *fFloat_Type, 4, 2)) - , fDMat4x3_Type(new Type("dmat4x3", *fFloat_Type, 4, 3)) - , fDMat4x4_Type(new Type("dmat4", *fFloat_Type, 4, 4)) - , fSampler1D_Type(new Type("sampler1D", SpvDim1D, false, false, false, true)) - , fSampler2D_Type(new Type("sampler2D", SpvDim2D, false, false, false, true)) - , fSampler3D_Type(new Type("sampler3D", SpvDim3D, false, false, false, true)) - , fSamplerExternalOES_Type(new Type("samplerExternalOES", SpvDim2D, false, false, false, true)) - , fSamplerCube_Type(new Type("samplerCube")) - , fSampler2DRect_Type(new Type("sampler2DRect")) - , fSampler1DArray_Type(new Type("sampler1DArray")) - , fSampler2DArray_Type(new Type("sampler2DArray")) - , fSamplerCubeArray_Type(new Type("samplerCubeArray")) - , fSamplerBuffer_Type(new Type("samplerBuffer")) - , fSampler2DMS_Type(new Type("sampler2DMS")) - , fSampler2DMSArray_Type(new Type("sampler2DMSArray")) - , fSampler1DShadow_Type(new Type("sampler1DShadow")) - , fSampler2DShadow_Type(new Type("sampler2DShadow")) - , fSamplerCubeShadow_Type(new Type("samplerCubeShadow")) - , fSampler2DRectShadow_Type(new Type("sampler2DRectShadow")) - , fSampler1DArrayShadow_Type(new Type("sampler1DArrayShadow")) - , fSampler2DArrayShadow_Type(new Type("sampler2DArrayShadow")) - , fSamplerCubeArrayShadow_Type(new Type("samplerCubeArrayShadow")) + : fInvalid_Type(new Type(SkString("<INVALID>"))) + , fVoid_Type(new Type(SkString("void"))) + , fDouble_Type(new Type(SkString("double"), true)) + , fDVec2_Type(new Type(SkString("dvec2"), *fDouble_Type, 2)) + , fDVec3_Type(new Type(SkString("dvec3"), *fDouble_Type, 3)) + , fDVec4_Type(new Type(SkString("dvec4"), *fDouble_Type, 4)) + , fFloat_Type(new Type(SkString("float"), true, { fDouble_Type.get() })) + , fVec2_Type(new Type(SkString("vec2"), *fFloat_Type, 2)) + , fVec3_Type(new Type(SkString("vec3"), *fFloat_Type, 3)) + , fVec4_Type(new Type(SkString("vec4"), *fFloat_Type, 4)) + , fUInt_Type(new Type(SkString("uint"), true, { fFloat_Type.get(), fDouble_Type.get() })) + , fUVec2_Type(new Type(SkString("uvec2"), *fUInt_Type, 2)) + , fUVec3_Type(new Type(SkString("uvec3"), *fUInt_Type, 3)) + , fUVec4_Type(new Type(SkString("uvec4"), *fUInt_Type, 4)) + , fInt_Type(new Type(SkString("int"), true, { fUInt_Type.get(), fFloat_Type.get(), + fDouble_Type.get() })) + , fIVec2_Type(new Type(SkString("ivec2"), *fInt_Type, 2)) + , fIVec3_Type(new Type(SkString("ivec3"), *fInt_Type, 3)) + , fIVec4_Type(new Type(SkString("ivec4"), *fInt_Type, 4)) + , fBool_Type(new Type(SkString("bool"), false)) + , fBVec2_Type(new Type(SkString("bvec2"), *fBool_Type, 2)) + , fBVec3_Type(new Type(SkString("bvec3"), *fBool_Type, 3)) + , fBVec4_Type(new Type(SkString("bvec4"), *fBool_Type, 4)) + , fMat2x2_Type(new Type(SkString("mat2"), *fFloat_Type, 2, 2)) + , fMat2x3_Type(new Type(SkString("mat2x3"), *fFloat_Type, 2, 3)) + , fMat2x4_Type(new Type(SkString("mat2x4"), *fFloat_Type, 2, 4)) + , fMat3x2_Type(new Type(SkString("mat3x2"), *fFloat_Type, 3, 2)) + , fMat3x3_Type(new Type(SkString("mat3"), *fFloat_Type, 3, 3)) + , fMat3x4_Type(new Type(SkString("mat3x4"), *fFloat_Type, 3, 4)) + , fMat4x2_Type(new Type(SkString("mat4x2"), *fFloat_Type, 4, 2)) + , fMat4x3_Type(new Type(SkString("mat4x3"), *fFloat_Type, 4, 3)) + , fMat4x4_Type(new Type(SkString("mat4"), *fFloat_Type, 4, 4)) + , fDMat2x2_Type(new Type(SkString("dmat2"), *fFloat_Type, 2, 2)) + , fDMat2x3_Type(new Type(SkString("dmat2x3"), *fFloat_Type, 2, 3)) + , fDMat2x4_Type(new Type(SkString("dmat2x4"), *fFloat_Type, 2, 4)) + , fDMat3x2_Type(new Type(SkString("dmat3x2"), *fFloat_Type, 3, 2)) + , fDMat3x3_Type(new Type(SkString("dmat3"), *fFloat_Type, 3, 3)) + , fDMat3x4_Type(new Type(SkString("dmat3x4"), *fFloat_Type, 3, 4)) + , fDMat4x2_Type(new Type(SkString("dmat4x2"), *fFloat_Type, 4, 2)) + , fDMat4x3_Type(new Type(SkString("dmat4x3"), *fFloat_Type, 4, 3)) + , fDMat4x4_Type(new Type(SkString("dmat4"), *fFloat_Type, 4, 4)) + , fSampler1D_Type(new Type(SkString("sampler1D"), SpvDim1D, false, false, false, true)) + , fSampler2D_Type(new Type(SkString("sampler2D"), SpvDim2D, false, false, false, true)) + , fSampler3D_Type(new Type(SkString("sampler3D"), SpvDim3D, false, false, false, true)) + , fSamplerExternalOES_Type(new Type(SkString("samplerExternalOES"), SpvDim2D, false, false, + false, true)) + , fSamplerCube_Type(new Type(SkString("samplerCube"))) + , fSampler2DRect_Type(new Type(SkString("sampler2DRect"))) + , fSampler1DArray_Type(new Type(SkString("sampler1DArray"))) + , fSampler2DArray_Type(new Type(SkString("sampler2DArray"))) + , fSamplerCubeArray_Type(new Type(SkString("samplerCubeArray"))) + , fSamplerBuffer_Type(new Type(SkString("samplerBuffer"))) + , fSampler2DMS_Type(new Type(SkString("sampler2DMS"))) + , fSampler2DMSArray_Type(new Type(SkString("sampler2DMSArray"))) + , fSampler1DShadow_Type(new Type(SkString("sampler1DShadow"))) + , fSampler2DShadow_Type(new Type(SkString("sampler2DShadow"))) + , fSamplerCubeShadow_Type(new Type(SkString("samplerCubeShadow"))) + , fSampler2DRectShadow_Type(new Type(SkString("sampler2DRectShadow"))) + , fSampler1DArrayShadow_Type(new Type(SkString("sampler1DArrayShadow"))) + , fSampler2DArrayShadow_Type(new Type(SkString("sampler2DArrayShadow"))) + , fSamplerCubeArrayShadow_Type(new Type(SkString("samplerCubeArrayShadow"))) // Related to below FIXME, gsampler*s don't currently expand to cover integer case. - , fISampler2D_Type(new Type("isampler2D", SpvDim2D, false, false, false, true)) + , fISampler2D_Type(new Type(SkString("isampler2D"), SpvDim2D, false, false, false, true)) // FIXME express these as "gimage2D" that expand to image2D, iimage2D, and uimage2D. - , fImage2D_Type(new Type("image2D", SpvDim2D, false, false, false, true)) - , fIImage2D_Type(new Type("iimage2D", SpvDim2D, false, false, false, true)) + , fImage2D_Type(new Type(SkString("image2D"), SpvDim2D, false, false, false, true)) + , fIImage2D_Type(new Type(SkString("iimage2D"), SpvDim2D, false, false, false, true)) // FIXME figure out what we're supposed to do with the gsampler et al. types) - , fGSampler1D_Type(new Type("$gsampler1D", static_type(*fSampler1D_Type))) - , fGSampler2D_Type(new Type("$gsampler2D", static_type(*fSampler2D_Type))) - , fGSampler3D_Type(new Type("$gsampler3D", static_type(*fSampler3D_Type))) - , fGSamplerCube_Type(new Type("$gsamplerCube", static_type(*fSamplerCube_Type))) - , fGSampler2DRect_Type(new Type("$gsampler2DRect", static_type(*fSampler2DRect_Type))) - , fGSampler1DArray_Type(new Type("$gsampler1DArray", static_type(*fSampler1DArray_Type))) - , fGSampler2DArray_Type(new Type("$gsampler2DArray", static_type(*fSampler2DArray_Type))) - , fGSamplerCubeArray_Type(new Type("$gsamplerCubeArray", static_type(*fSamplerCubeArray_Type))) - , fGSamplerBuffer_Type(new Type("$gsamplerBuffer", static_type(*fSamplerBuffer_Type))) - , fGSampler2DMS_Type(new Type("$gsampler2DMS", static_type(*fSampler2DMS_Type))) - , fGSampler2DMSArray_Type(new Type("$gsampler2DMSArray", static_type(*fSampler2DMSArray_Type))) - , fGSampler2DArrayShadow_Type(new Type("$gsampler2DArrayShadow", + , fGSampler1D_Type(new Type(SkString("$gsampler1D"), static_type(*fSampler1D_Type))) + , fGSampler2D_Type(new Type(SkString("$gsampler2D"), static_type(*fSampler2D_Type))) + , fGSampler3D_Type(new Type(SkString("$gsampler3D"), static_type(*fSampler3D_Type))) + , fGSamplerCube_Type(new Type(SkString("$gsamplerCube"), static_type(*fSamplerCube_Type))) + , fGSampler2DRect_Type(new Type(SkString("$gsampler2DRect"), static_type(*fSampler2DRect_Type))) + , fGSampler1DArray_Type(new Type(SkString("$gsampler1DArray"), + static_type(*fSampler1DArray_Type))) + , fGSampler2DArray_Type(new Type(SkString("$gsampler2DArray"), + static_type(*fSampler2DArray_Type))) + , fGSamplerCubeArray_Type(new Type(SkString("$gsamplerCubeArray"), + static_type(*fSamplerCubeArray_Type))) + , fGSamplerBuffer_Type(new Type(SkString("$gsamplerBuffer"), static_type(*fSamplerBuffer_Type))) + , fGSampler2DMS_Type(new Type(SkString("$gsampler2DMS"), static_type(*fSampler2DMS_Type))) + , fGSampler2DMSArray_Type(new Type(SkString("$gsampler2DMSArray"), + static_type(*fSampler2DMSArray_Type))) + , fGSampler2DArrayShadow_Type(new Type(SkString("$gsampler2DArrayShadow"), static_type(*fSampler2DArrayShadow_Type))) - , fGSamplerCubeArrayShadow_Type(new Type("$gsamplerCubeArrayShadow", + , fGSamplerCubeArrayShadow_Type(new Type(SkString("$gsamplerCubeArrayShadow"), static_type(*fSamplerCubeArrayShadow_Type))) - , fGenType_Type(new Type("$genType", { fFloat_Type.get(), fVec2_Type.get(), fVec3_Type.get(), - fVec4_Type.get() })) - , fGenDType_Type(new Type("$genDType", { fDouble_Type.get(), fDVec2_Type.get(), - fDVec3_Type.get(), fDVec4_Type.get() })) - , fGenIType_Type(new Type("$genIType", { fInt_Type.get(), fIVec2_Type.get(), fIVec3_Type.get(), - fIVec4_Type.get() })) - , fGenUType_Type(new Type("$genUType", { fUInt_Type.get(), fUVec2_Type.get(), fUVec3_Type.get(), - fUVec4_Type.get() })) - , fGenBType_Type(new Type("$genBType", { fBool_Type.get(), fBVec2_Type.get(), fBVec3_Type.get(), - fBVec4_Type.get() })) - , fMat_Type(new Type("$mat")) - , fVec_Type(new Type("$vec", { fInvalid_Type.get(), fVec2_Type.get(), fVec3_Type.get(), - fVec4_Type.get() })) - , fGVec_Type(new Type("$gvec")) - , fGVec2_Type(new Type("$gvec2")) - , fGVec3_Type(new Type("$gvec3")) - , fGVec4_Type(new Type("$gvec4", static_type(*fVec4_Type))) - , fDVec_Type(new Type("$dvec", { fInvalid_Type.get(), fDVec2_Type.get(), fDVec3_Type.get(), - fDVec4_Type.get() })) - , fIVec_Type(new Type("$ivec", { fInvalid_Type.get(), fIVec2_Type.get(), fIVec3_Type.get(), - fIVec4_Type.get() })) - , fUVec_Type(new Type("$uvec", { fInvalid_Type.get(), fUVec2_Type.get(), fUVec3_Type.get(), - fUVec4_Type.get() })) - , fBVec_Type(new Type("$bvec", { fInvalid_Type.get(), fBVec2_Type.get(), fBVec3_Type.get(), - fBVec4_Type.get() })) + , fGenType_Type(new Type(SkString("$genType"), { fFloat_Type.get(), fVec2_Type.get(), + fVec3_Type.get(), fVec4_Type.get() })) + , fGenDType_Type(new Type(SkString("$genDType"), { fDouble_Type.get(), fDVec2_Type.get(), + fDVec3_Type.get(), fDVec4_Type.get() })) + , fGenIType_Type(new Type(SkString("$genIType"), { fInt_Type.get(), fIVec2_Type.get(), + fIVec3_Type.get(), fIVec4_Type.get() })) + , fGenUType_Type(new Type(SkString("$genUType"), { fUInt_Type.get(), fUVec2_Type.get(), + fUVec3_Type.get(), fUVec4_Type.get() })) + , fGenBType_Type(new Type(SkString("$genBType"), { fBool_Type.get(), fBVec2_Type.get(), + fBVec3_Type.get(), fBVec4_Type.get() })) + , fMat_Type(new Type(SkString("$mat"))) + , fVec_Type(new Type(SkString("$vec"), { fInvalid_Type.get(), fVec2_Type.get(), + fVec3_Type.get(), fVec4_Type.get() })) + , fGVec_Type(new Type(SkString("$gvec"))) + , fGVec2_Type(new Type(SkString("$gvec2"))) + , fGVec3_Type(new Type(SkString("$gvec3"))) + , fGVec4_Type(new Type(SkString("$gvec4"), static_type(*fVec4_Type))) + , fDVec_Type(new Type(SkString("$dvec"), { fInvalid_Type.get(), fDVec2_Type.get(), + fDVec3_Type.get(), fDVec4_Type.get() })) + , fIVec_Type(new Type(SkString("$ivec"), { fInvalid_Type.get(), fIVec2_Type.get(), + fIVec3_Type.get(), fIVec4_Type.get() })) + , fUVec_Type(new Type(SkString("$uvec"), { fInvalid_Type.get(), fUVec2_Type.get(), + fUVec3_Type.get(), fUVec4_Type.get() })) + , fBVec_Type(new Type(SkString("$bvec"), { fInvalid_Type.get(), fBVec2_Type.get(), + fBVec3_Type.get(), fBVec4_Type.get() })) , fDefined_Expression(new Defined(*fInvalid_Type)) {} static std::vector<const Type*> static_type(const Type& t) { @@ -252,8 +258,8 @@ private: Defined(const Type& type) : INHERITED(Position(), kDefined_Kind, type) {} - virtual std::string description() const override { - return "<defined>"; + virtual SkString description() const override { + return SkString("<defined>"); } typedef Expression INHERITED; |