| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #include "GrGLNvprProgramBuilder.h" | 8 #include "GrGLNvprProgramBuilder.h" |
| 9 #include "../GrGpuGL.h" | 9 #include "../GrGpuGL.h" |
| 10 | 10 |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 48 SkNEW_APPEND_TO_TARRAY(outCoords, GrGLProcessor::TransformedCoords, | 48 SkNEW_APPEND_TO_TARRAY(outCoords, GrGLProcessor::TransformedCoords, |
| 49 (SkString(fsVaryingName), varyingType)); | 49 (SkString(fsVaryingName), varyingType)); |
| 50 } | 50 } |
| 51 } | 51 } |
| 52 | 52 |
| 53 GrGLInstalledFragProc::ShaderVarHandle | 53 GrGLInstalledFragProc::ShaderVarHandle |
| 54 GrGLNvprProgramBuilder::addSeparableVarying(GrSLType type, | 54 GrGLNvprProgramBuilder::addSeparableVarying(GrSLType type, |
| 55 const char* name, | 55 const char* name, |
| 56 const char** vsOutName, | 56 const char** vsOutName, |
| 57 const char** fsInName) { | 57 const char** fsInName) { |
| 58 addVarying(type, name, vsOutName, fsInName); |
| 58 SeparableVaryingInfo& varying = fSeparableVaryingInfos.push_back(); | 59 SeparableVaryingInfo& varying = fSeparableVaryingInfos.push_back(); |
| 59 varying.fVariable = fFS.fInputs.back(); | 60 varying.fVariable = fFS.fInputs.back(); |
| 60 return GrGLInstalledFragProc::ShaderVarHandle(fSeparableVaryingInfos.count()
- 1); | 61 return GrGLInstalledFragProc::ShaderVarHandle(fSeparableVaryingInfos.count()
- 1); |
| 61 } | 62 } |
| 62 | 63 |
| 63 void GrGLNvprProgramBuilder::resolveSeparableVaryings(GrGLuint programId) { | 64 void GrGLNvprProgramBuilder::resolveSeparableVaryings(GrGLuint programId) { |
| 64 int count = fSeparableVaryingInfos.count(); | 65 int count = fSeparableVaryingInfos.count(); |
| 65 for (int i = 0; i < count; ++i) { | 66 for (int i = 0; i < count; ++i) { |
| 66 GrGLint location; | 67 GrGLint location; |
| 67 GL_CALL_RET(location, | 68 GL_CALL_RET(location, |
| 68 GetProgramResourceLocation(programId, | 69 GetProgramResourceLocation(programId, |
| 69 GR_GL_FRAGMENT_INPUT, | 70 GR_GL_FRAGMENT_INPUT, |
| 70 fSeparableVaryingInfos[i].fVariab
le.c_str())); | 71 fSeparableVaryingInfos[i].fVariab
le.c_str())); |
| 71 fSeparableVaryingInfos[i].fLocation = location; | 72 fSeparableVaryingInfos[i].fLocation = location; |
| 72 } | 73 } |
| 73 } | 74 } |
| 74 | 75 |
| 75 GrGLProgram* GrGLNvprProgramBuilder::createProgram(GrGLuint programID) { | 76 GrGLProgram* GrGLNvprProgramBuilder::createProgram(GrGLuint programID) { |
| 76 // this is just for nvpr es, which has separable varyings that are plugged i
n after | 77 // this is just for nvpr es, which has separable varyings that are plugged i
n after |
| 77 // building | 78 // building |
| 78 this->resolveSeparableVaryings(programID); | 79 this->resolveSeparableVaryings(programID); |
| 79 return SkNEW_ARGS(GrGLNvprProgram, (fGpu, fDesc, fUniformHandles, programID,
fUniforms, | 80 return SkNEW_ARGS(GrGLNvprProgram, (fGpu, fDesc, fUniformHandles, programID,
fUniforms, |
| 80 fFragmentProcessors.get(), fSeparableVar
yingInfos)); | 81 fFragmentProcessors.get(), fSeparableVar
yingInfos)); |
| 81 } | 82 } |
| OLD | NEW |