blob: 2de81ddd60efb85bbe1eefdf205454735910bbe0 [file] [log] [blame]
jvanverthcba99b82015-06-24 06:59:57 -07001/*
2 * Copyright 2011 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8#include "GrGLSL.h"
egdanielcb7ba1e2015-10-26 08:38:25 -07009#include "GrGLSLCaps.h"
jvanverthcba99b82015-06-24 06:59:57 -070010#include "SkString.h"
11
12bool GrGLSLSupportsNamedFragmentShaderOutputs(GrGLSLGeneration gen) {
13 switch (gen) {
14 case k110_GrGLSLGeneration:
15 return false;
16 case k130_GrGLSLGeneration:
17 case k140_GrGLSLGeneration:
18 case k150_GrGLSLGeneration:
19 case k330_GrGLSLGeneration:
20 case k310es_GrGLSLGeneration:
21 return true;
22 }
23 return false;
24}
25
egdanielcb7ba1e2015-10-26 08:38:25 -070026void GrGLSLAppendDefaultFloatPrecisionDeclaration(GrSLPrecision p,
27 const GrGLSLCaps& glslCaps,
28 SkString* out) {
29 if (glslCaps.usesPrecisionModifiers()) {
30 switch (p) {
31 case kHigh_GrSLPrecision:
32 out->append("precision highp float;\n");
33 break;
34 case kMedium_GrSLPrecision:
35 out->append("precision mediump float;\n");
36 break;
37 case kLow_GrSLPrecision:
38 out->append("precision lowp float;\n");
39 break;
40 default:
41 SkFAIL("Unknown precision value.");
42 }
43 }
44}
45
jvanverthcba99b82015-06-24 06:59:57 -070046void GrGLSLMulVarBy4f(SkString* outAppend, const char* vec4VarName, const GrGLSLExpr4& mulFactor) {
47 if (mulFactor.isOnes()) {
48 *outAppend = SkString();
49 }
50
51 if (mulFactor.isZeros()) {
52 outAppend->appendf("%s = vec4(0);", vec4VarName);
53 } else {
54 outAppend->appendf("%s *= %s;", vec4VarName, mulFactor.c_str());
55 }
56}