| Absolute File Name: | /home/qt/qt5_coco/qt5/qtbase/src/opengl/gl2paintengineex/qglengineshadermanager.cpp |
| Switch to Source code | Preprocessed file |
| Line | Source | Count | ||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | - | |||||||||||||||||||||||||
| 2 | - | |||||||||||||||||||||||||
| 3 | - | |||||||||||||||||||||||||
| 4 | - | |||||||||||||||||||||||||
| 5 | - | |||||||||||||||||||||||||
| 6 | - | |||||||||||||||||||||||||
| 7 | - | |||||||||||||||||||||||||
| 8 | - | |||||||||||||||||||||||||
| 9 | - | |||||||||||||||||||||||||
| 10 | class QGLEngineSharedShadersResource : public QOpenGLSharedResource | - | ||||||||||||||||||||||||
| 11 | { | - | ||||||||||||||||||||||||
| 12 | public: | - | ||||||||||||||||||||||||
| 13 | QGLEngineSharedShadersResource(QOpenGLContext *ctx) | - | ||||||||||||||||||||||||
| 14 | : QOpenGLSharedResource(ctx->shareGroup()) | - | ||||||||||||||||||||||||
| 15 | , m_shaders(new QGLEngineSharedShaders(QGLContext::fromOpenGLContext(ctx))) | - | ||||||||||||||||||||||||
| 16 | { | - | ||||||||||||||||||||||||
| 17 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 18 | - | |||||||||||||||||||||||||
| 19 | ~QGLEngineSharedShadersResource() | - | ||||||||||||||||||||||||
| 20 | { | - | ||||||||||||||||||||||||
| 21 | delete m_shaders; | - | ||||||||||||||||||||||||
| 22 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 23 | - | |||||||||||||||||||||||||
| 24 | void invalidateResource() override | - | ||||||||||||||||||||||||
| 25 | { | - | ||||||||||||||||||||||||
| 26 | delete m_shaders; | - | ||||||||||||||||||||||||
| 27 | m_shaders = 0; | - | ||||||||||||||||||||||||
| 28 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 29 | - | |||||||||||||||||||||||||
| 30 | void freeResource(QOpenGLContext *) override | - | ||||||||||||||||||||||||
| 31 | { | - | ||||||||||||||||||||||||
| 32 | } | - | ||||||||||||||||||||||||
| 33 | - | |||||||||||||||||||||||||
| 34 | QGLEngineSharedShaders *shaders() const { return executed 2 times by 1 test: m_shaders;return m_shaders;Executed by:
executed 2 times by 1 test: }return m_shaders;Executed by:
| 2 | ||||||||||||||||||||||||
| 35 | - | |||||||||||||||||||||||||
| 36 | private: | - | ||||||||||||||||||||||||
| 37 | QGLEngineSharedShaders *m_shaders; | - | ||||||||||||||||||||||||
| 38 | }; | - | ||||||||||||||||||||||||
| 39 | - | |||||||||||||||||||||||||
| 40 | class QGLShaderStorage | - | ||||||||||||||||||||||||
| 41 | { | - | ||||||||||||||||||||||||
| 42 | public: | - | ||||||||||||||||||||||||
| 43 | QGLEngineSharedShaders *shadersForThread(const QGLContext *context) { | - | ||||||||||||||||||||||||
| 44 | QOpenGLMultiGroupSharedResource *&shaders = m_storage.localData(); | - | ||||||||||||||||||||||||
| 45 | if (!shaders
| 1 | ||||||||||||||||||||||||
| 46 | shaders = new QOpenGLMultiGroupSharedResource; executed 1 time by 1 test: shaders = new QOpenGLMultiGroupSharedResource;Executed by:
| 1 | ||||||||||||||||||||||||
| 47 | QGLEngineSharedShadersResource *resource = | - | ||||||||||||||||||||||||
| 48 | shaders->value<QGLEngineSharedShadersResource>(context->contextHandle()); | - | ||||||||||||||||||||||||
| 49 | return executed 2 times by 1 test: resourcereturn resource ? resource->shaders() : 0;Executed by:
executed 2 times by 1 test: return resource ? resource->shaders() : 0;Executed by:
| 0-2 | ||||||||||||||||||||||||
| 50 | } | - | ||||||||||||||||||||||||
| 51 | - | |||||||||||||||||||||||||
| 52 | private: | - | ||||||||||||||||||||||||
| 53 | QThreadStorage<QOpenGLMultiGroupSharedResource *> m_storage; | - | ||||||||||||||||||||||||
| 54 | }; | - | ||||||||||||||||||||||||
| 55 | - | |||||||||||||||||||||||||
| 56 | namespace { namespace Q_QGS_qt_shader_storage { typedef QGLShaderStorage Type; QBasicAtomicInt guard = { QtGlobalStatic::Uninitialized }; __attribute__((visibility("hidden"))) inline Type *innerFunction() { struct HolderBase { ~HolderBase() noexcept { if (guard.load() == QtGlobalStatic::Initialized
executed 1 time by 1 test: }guard.store(QtGlobalStatic::Destroyed);Executed by:
executed 1 time by 1 test: }; static struct Holder : public HolderBase { Type value; Holder() noexcept(noexcept(Type ())) : value () { guard.store(QtGlobalStatic::Initialized); } } holder; returnend of blockExecuted by:
executed 2 times by 1 test: &holder.value;return &holder.value;Executed by:
executed 2 times by 1 test: } } } static QGlobalStatic<QGLShaderStorage, Q_QGS_qt_shader_storage::innerFunction, Q_QGS_qt_shader_storage::guard> qt_shader_storage;;return &holder.value;Executed by:
| 0-2 | ||||||||||||||||||||||||
| 57 | - | |||||||||||||||||||||||||
| 58 | QGLEngineSharedShaders *QGLEngineSharedShaders::shadersForContext(const QGLContext *context) | - | ||||||||||||||||||||||||
| 59 | { | - | ||||||||||||||||||||||||
| 60 | return executed 2 times by 1 test: qt_shader_storage()->shadersForThread(context);return qt_shader_storage()->shadersForThread(context);Executed by:
executed 2 times by 1 test: return qt_shader_storage()->shadersForThread(context);Executed by:
| 2 | ||||||||||||||||||||||||
| 61 | } | - | ||||||||||||||||||||||||
| 62 | - | |||||||||||||||||||||||||
| 63 | const char* QGLEngineSharedShaders::qShaderSnippets[] = { | - | ||||||||||||||||||||||||
| 64 | 0,0,0,0,0,0,0,0,0,0, | - | ||||||||||||||||||||||||
| 65 | 0,0,0,0,0,0,0,0,0,0, | - | ||||||||||||||||||||||||
| 66 | 0,0,0,0,0,0,0,0,0,0, | - | ||||||||||||||||||||||||
| 67 | 0,0,0,0,0 | - | ||||||||||||||||||||||||
| 68 | }; | - | ||||||||||||||||||||||||
| 69 | - | |||||||||||||||||||||||||
| 70 | QGLEngineSharedShaders::QGLEngineSharedShaders(const QGLContext* context) | - | ||||||||||||||||||||||||
| 71 | : blitShaderProg(0) | - | ||||||||||||||||||||||||
| 72 | , simpleShaderProg(0) | - | ||||||||||||||||||||||||
| 73 | { | - | ||||||||||||||||||||||||
| 74 | - | |||||||||||||||||||||||||
| 75 | - | |||||||||||||||||||||||||
| 76 | - | |||||||||||||||||||||||||
| 77 | - | |||||||||||||||||||||||||
| 78 | - | |||||||||||||||||||||||||
| 79 | - | |||||||||||||||||||||||||
| 80 | - | |||||||||||||||||||||||||
| 81 | static bool snippetsPopulated = false; | - | ||||||||||||||||||||||||
| 82 | if (!snippetsPopulated
| 0-1 | ||||||||||||||||||||||||
| 83 | - | |||||||||||||||||||||||||
| 84 | const char** code = qShaderSnippets; | - | ||||||||||||||||||||||||
| 85 | - | |||||||||||||||||||||||||
| 86 | code[MainVertexShader] = qglslMainVertexShader; | - | ||||||||||||||||||||||||
| 87 | code[MainWithTexCoordsVertexShader] = qglslMainWithTexCoordsVertexShader; | - | ||||||||||||||||||||||||
| 88 | code[MainWithTexCoordsAndOpacityVertexShader] = qglslMainWithTexCoordsAndOpacityVertexShader; | - | ||||||||||||||||||||||||
| 89 | - | |||||||||||||||||||||||||
| 90 | code[UntransformedPositionVertexShader] = qglslUntransformedPositionVertexShader; | - | ||||||||||||||||||||||||
| 91 | code[PositionOnlyVertexShader] = qglslPositionOnlyVertexShader; | - | ||||||||||||||||||||||||
| 92 | code[ComplexGeometryPositionOnlyVertexShader] = qglslComplexGeometryPositionOnlyVertexShader; | - | ||||||||||||||||||||||||
| 93 | code[PositionWithPatternBrushVertexShader] = qglslPositionWithPatternBrushVertexShader; | - | ||||||||||||||||||||||||
| 94 | code[PositionWithLinearGradientBrushVertexShader] = qglslPositionWithLinearGradientBrushVertexShader; | - | ||||||||||||||||||||||||
| 95 | code[PositionWithConicalGradientBrushVertexShader] = qglslPositionWithConicalGradientBrushVertexShader; | - | ||||||||||||||||||||||||
| 96 | code[PositionWithRadialGradientBrushVertexShader] = qglslPositionWithRadialGradientBrushVertexShader; | - | ||||||||||||||||||||||||
| 97 | code[PositionWithTextureBrushVertexShader] = qglslPositionWithTextureBrushVertexShader; | - | ||||||||||||||||||||||||
| 98 | code[AffinePositionWithPatternBrushVertexShader] = qglslAffinePositionWithPatternBrushVertexShader; | - | ||||||||||||||||||||||||
| 99 | code[AffinePositionWithLinearGradientBrushVertexShader] = qglslAffinePositionWithLinearGradientBrushVertexShader; | - | ||||||||||||||||||||||||
| 100 | code[AffinePositionWithConicalGradientBrushVertexShader] = qglslAffinePositionWithConicalGradientBrushVertexShader; | - | ||||||||||||||||||||||||
| 101 | code[AffinePositionWithRadialGradientBrushVertexShader] = qglslAffinePositionWithRadialGradientBrushVertexShader; | - | ||||||||||||||||||||||||
| 102 | code[AffinePositionWithTextureBrushVertexShader] = qglslAffinePositionWithTextureBrushVertexShader; | - | ||||||||||||||||||||||||
| 103 | - | |||||||||||||||||||||||||
| 104 | code[MainFragmentShader_CMO] = qglslMainFragmentShader_CMO; | - | ||||||||||||||||||||||||
| 105 | code[MainFragmentShader_CM] = qglslMainFragmentShader_CM; | - | ||||||||||||||||||||||||
| 106 | code[MainFragmentShader_MO] = qglslMainFragmentShader_MO; | - | ||||||||||||||||||||||||
| 107 | code[MainFragmentShader_M] = qglslMainFragmentShader_M; | - | ||||||||||||||||||||||||
| 108 | code[MainFragmentShader_CO] = qglslMainFragmentShader_CO; | - | ||||||||||||||||||||||||
| 109 | code[MainFragmentShader_C] = qglslMainFragmentShader_C; | - | ||||||||||||||||||||||||
| 110 | code[MainFragmentShader_O] = qglslMainFragmentShader_O; | - | ||||||||||||||||||||||||
| 111 | code[MainFragmentShader] = qglslMainFragmentShader; | - | ||||||||||||||||||||||||
| 112 | code[MainFragmentShader_ImageArrays] = qglslMainFragmentShader_ImageArrays; | - | ||||||||||||||||||||||||
| 113 | - | |||||||||||||||||||||||||
| 114 | code[ImageSrcFragmentShader] = qglslImageSrcFragmentShader; | - | ||||||||||||||||||||||||
| 115 | code[ImageSrcWithPatternFragmentShader] = qglslImageSrcWithPatternFragmentShader; | - | ||||||||||||||||||||||||
| 116 | code[NonPremultipliedImageSrcFragmentShader] = qglslNonPremultipliedImageSrcFragmentShader; | - | ||||||||||||||||||||||||
| 117 | code[CustomImageSrcFragmentShader] = qglslCustomSrcFragmentShader; | - | ||||||||||||||||||||||||
| 118 | code[SolidBrushSrcFragmentShader] = qglslSolidBrushSrcFragmentShader; | - | ||||||||||||||||||||||||
| 119 | if (!context->contextHandle()->isOpenGLES()
| 0-1 | ||||||||||||||||||||||||
| 120 | code[TextureBrushSrcFragmentShader] = qglslTextureBrushSrcFragmentShader_desktop; executed 1 time by 1 test: code[TextureBrushSrcFragmentShader] = qglslTextureBrushSrcFragmentShader_desktop;Executed by:
| 1 | ||||||||||||||||||||||||
| 121 | else | - | ||||||||||||||||||||||||
| 122 | code[TextureBrushSrcFragmentShader] = qglslTextureBrushSrcFragmentShader_ES; never executed: code[TextureBrushSrcFragmentShader] = qglslTextureBrushSrcFragmentShader_ES; | 0 | ||||||||||||||||||||||||
| 123 | code[TextureBrushSrcWithPatternFragmentShader] = qglslTextureBrushSrcWithPatternFragmentShader; | - | ||||||||||||||||||||||||
| 124 | code[PatternBrushSrcFragmentShader] = qglslPatternBrushSrcFragmentShader; | - | ||||||||||||||||||||||||
| 125 | code[LinearGradientBrushSrcFragmentShader] = qglslLinearGradientBrushSrcFragmentShader; | - | ||||||||||||||||||||||||
| 126 | code[RadialGradientBrushSrcFragmentShader] = qglslRadialGradientBrushSrcFragmentShader; | - | ||||||||||||||||||||||||
| 127 | code[ConicalGradientBrushSrcFragmentShader] = qglslConicalGradientBrushSrcFragmentShader; | - | ||||||||||||||||||||||||
| 128 | code[ShockingPinkSrcFragmentShader] = qglslShockingPinkSrcFragmentShader; | - | ||||||||||||||||||||||||
| 129 | - | |||||||||||||||||||||||||
| 130 | code[NoMaskFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 131 | code[MaskFragmentShader] = qglslMaskFragmentShader; | - | ||||||||||||||||||||||||
| 132 | code[RgbMaskFragmentShaderPass1] = qglslRgbMaskFragmentShaderPass1; | - | ||||||||||||||||||||||||
| 133 | code[RgbMaskFragmentShaderPass2] = qglslRgbMaskFragmentShaderPass2; | - | ||||||||||||||||||||||||
| 134 | code[RgbMaskWithGammaFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 135 | - | |||||||||||||||||||||||||
| 136 | code[NoCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 137 | code[MultiplyCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 138 | code[ScreenCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 139 | code[OverlayCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 140 | code[DarkenCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 141 | code[LightenCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 142 | code[ColorDodgeCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 143 | code[ColorBurnCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 144 | code[HardLightCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 145 | code[SoftLightCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 146 | code[DifferenceCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 147 | code[ExclusionCompositionModeFragmentShader] = ""; | - | ||||||||||||||||||||||||
| 148 | - | |||||||||||||||||||||||||
| 149 | - | |||||||||||||||||||||||||
| 150 | - | |||||||||||||||||||||||||
| 151 | for (int i = 0; i < TotalSnippetCount
| 1-54 | ||||||||||||||||||||||||
| 152 | if (qShaderSnippets[i] == 0
| 0-54 | ||||||||||||||||||||||||
| 153 | QMessageLogger(__FILE__, 192, __PRETTY_FUNCTION__).fatal("Shader snippet for %s (#%d) is missing!", | - | ||||||||||||||||||||||||
| 154 | snippetNameStr(SnippetName(i)).constData(), i); | - | ||||||||||||||||||||||||
| 155 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 156 | } executed 54 times by 1 test: end of blockExecuted by:
| 54 | ||||||||||||||||||||||||
| 157 | - | |||||||||||||||||||||||||
| 158 | snippetsPopulated = true; | - | ||||||||||||||||||||||||
| 159 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 160 | - | |||||||||||||||||||||||||
| 161 | QGLShader* fragShader; | - | ||||||||||||||||||||||||
| 162 | QGLShader* vertexShader; | - | ||||||||||||||||||||||||
| 163 | QByteArray vertexSource; | - | ||||||||||||||||||||||||
| 164 | QByteArray fragSource; | - | ||||||||||||||||||||||||
| 165 | - | |||||||||||||||||||||||||
| 166 | - | |||||||||||||||||||||||||
| 167 | vertexSource.append(qShaderSnippets[MainVertexShader]); | - | ||||||||||||||||||||||||
| 168 | vertexSource.append(qShaderSnippets[PositionOnlyVertexShader]); | - | ||||||||||||||||||||||||
| 169 | - | |||||||||||||||||||||||||
| 170 | fragSource.append(qShaderSnippets[MainFragmentShader]); | - | ||||||||||||||||||||||||
| 171 | fragSource.append(qShaderSnippets[ShockingPinkSrcFragmentShader]); | - | ||||||||||||||||||||||||
| 172 | - | |||||||||||||||||||||||||
| 173 | simpleShaderProg = new QGLShaderProgram(context, 0); | - | ||||||||||||||||||||||||
| 174 | - | |||||||||||||||||||||||||
| 175 | CachedShader simpleShaderCache(fragSource, vertexSource); | - | ||||||||||||||||||||||||
| 176 | - | |||||||||||||||||||||||||
| 177 | bool inCache = simpleShaderCache.load(simpleShaderProg, context); | - | ||||||||||||||||||||||||
| 178 | - | |||||||||||||||||||||||||
| 179 | if (!inCache
| 0-1 | ||||||||||||||||||||||||
| 180 | vertexShader = new QGLShader(QGLShader::Vertex, context, 0); | - | ||||||||||||||||||||||||
| 181 | shaders.append(vertexShader); | - | ||||||||||||||||||||||||
| 182 | if (!vertexShader->compileSourceCode(vertexSource)
| 0-1 | ||||||||||||||||||||||||
| 183 | QMessageLogger(__FILE__, 222, __PRETTY_FUNCTION__).warning("Vertex shader for simpleShaderProg (MainVertexShader & PositionOnlyVertexShader) failed to compile"); never executed: QMessageLogger(__FILE__, 222, __PRETTY_FUNCTION__).warning("Vertex shader for simpleShaderProg (MainVertexShader & PositionOnlyVertexShader) failed to compile"); | 0 | ||||||||||||||||||||||||
| 184 | - | |||||||||||||||||||||||||
| 185 | fragShader = new QGLShader(QGLShader::Fragment, context, 0); | - | ||||||||||||||||||||||||
| 186 | shaders.append(fragShader); | - | ||||||||||||||||||||||||
| 187 | if (!fragShader->compileSourceCode(fragSource)
| 0-1 | ||||||||||||||||||||||||
| 188 | QMessageLogger(__FILE__, 227, __PRETTY_FUNCTION__).warning("Fragment shader for simpleShaderProg (MainFragmentShader & ShockingPinkSrcFragmentShader) failed to compile"); never executed: QMessageLogger(__FILE__, 227, __PRETTY_FUNCTION__).warning("Fragment shader for simpleShaderProg (MainFragmentShader & ShockingPinkSrcFragmentShader) failed to compile"); | 0 | ||||||||||||||||||||||||
| 189 | - | |||||||||||||||||||||||||
| 190 | simpleShaderProg->addShader(vertexShader); | - | ||||||||||||||||||||||||
| 191 | simpleShaderProg->addShader(fragShader); | - | ||||||||||||||||||||||||
| 192 | - | |||||||||||||||||||||||||
| 193 | simpleShaderProg->bindAttributeLocation("vertexCoordsArray", QT_VERTEX_COORDS_ATTR); | - | ||||||||||||||||||||||||
| 194 | simpleShaderProg->bindAttributeLocation("pmvMatrix1", QT_PMV_MATRIX_1_ATTR); | - | ||||||||||||||||||||||||
| 195 | simpleShaderProg->bindAttributeLocation("pmvMatrix2", QT_PMV_MATRIX_2_ATTR); | - | ||||||||||||||||||||||||
| 196 | simpleShaderProg->bindAttributeLocation("pmvMatrix3", QT_PMV_MATRIX_3_ATTR); | - | ||||||||||||||||||||||||
| 197 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 198 | - | |||||||||||||||||||||||||
| 199 | simpleShaderProg->link(); | - | ||||||||||||||||||||||||
| 200 | - | |||||||||||||||||||||||||
| 201 | if (simpleShaderProg->isLinked()
| 0-1 | ||||||||||||||||||||||||
| 202 | if (!inCache
| 0-1 | ||||||||||||||||||||||||
| 203 | simpleShaderCache.store(simpleShaderProg, context); executed 1 time by 1 test: simpleShaderCache.store(simpleShaderProg, context);Executed by:
| 1 | ||||||||||||||||||||||||
| 204 | } executed 1 time by 1 test: else {end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 205 | QMessageLogger(__FILE__, 244, __PRETTY_FUNCTION__).critical("Errors linking simple shader: %s", QString(simpleShaderProg->log()).toLocal8Bit().constData()); | - | ||||||||||||||||||||||||
| 206 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 207 | - | |||||||||||||||||||||||||
| 208 | - | |||||||||||||||||||||||||
| 209 | vertexSource.clear(); | - | ||||||||||||||||||||||||
| 210 | vertexSource.append(qShaderSnippets[MainWithTexCoordsVertexShader]); | - | ||||||||||||||||||||||||
| 211 | vertexSource.append(qShaderSnippets[UntransformedPositionVertexShader]); | - | ||||||||||||||||||||||||
| 212 | - | |||||||||||||||||||||||||
| 213 | fragSource.clear(); | - | ||||||||||||||||||||||||
| 214 | fragSource.append(qShaderSnippets[MainFragmentShader]); | - | ||||||||||||||||||||||||
| 215 | fragSource.append(qShaderSnippets[ImageSrcFragmentShader]); | - | ||||||||||||||||||||||||
| 216 | - | |||||||||||||||||||||||||
| 217 | blitShaderProg = new QGLShaderProgram(context, 0); | - | ||||||||||||||||||||||||
| 218 | - | |||||||||||||||||||||||||
| 219 | CachedShader blitShaderCache(fragSource, vertexSource); | - | ||||||||||||||||||||||||
| 220 | - | |||||||||||||||||||||||||
| 221 | inCache = blitShaderCache.load(blitShaderProg, context); | - | ||||||||||||||||||||||||
| 222 | - | |||||||||||||||||||||||||
| 223 | if (!inCache
| 0-1 | ||||||||||||||||||||||||
| 224 | vertexShader = new QGLShader(QGLShader::Vertex, context, 0); | - | ||||||||||||||||||||||||
| 225 | shaders.append(vertexShader); | - | ||||||||||||||||||||||||
| 226 | if (!vertexShader->compileSourceCode(vertexSource)
| 0-1 | ||||||||||||||||||||||||
| 227 | QMessageLogger(__FILE__, 266, __PRETTY_FUNCTION__).warning("Vertex shader for blitShaderProg (MainWithTexCoordsVertexShader & UntransformedPositionVertexShader) failed to compile"); never executed: QMessageLogger(__FILE__, 266, __PRETTY_FUNCTION__).warning("Vertex shader for blitShaderProg (MainWithTexCoordsVertexShader & UntransformedPositionVertexShader) failed to compile"); | 0 | ||||||||||||||||||||||||
| 228 | - | |||||||||||||||||||||||||
| 229 | fragShader = new QGLShader(QGLShader::Fragment, context, 0); | - | ||||||||||||||||||||||||
| 230 | shaders.append(fragShader); | - | ||||||||||||||||||||||||
| 231 | if (!fragShader->compileSourceCode(fragSource)
| 0-1 | ||||||||||||||||||||||||
| 232 | QMessageLogger(__FILE__, 271, __PRETTY_FUNCTION__).warning("Fragment shader for blitShaderProg (MainFragmentShader & ImageSrcFragmentShader) failed to compile"); never executed: QMessageLogger(__FILE__, 271, __PRETTY_FUNCTION__).warning("Fragment shader for blitShaderProg (MainFragmentShader & ImageSrcFragmentShader) failed to compile"); | 0 | ||||||||||||||||||||||||
| 233 | - | |||||||||||||||||||||||||
| 234 | blitShaderProg->addShader(vertexShader); | - | ||||||||||||||||||||||||
| 235 | blitShaderProg->addShader(fragShader); | - | ||||||||||||||||||||||||
| 236 | - | |||||||||||||||||||||||||
| 237 | blitShaderProg->bindAttributeLocation("textureCoordArray", QT_TEXTURE_COORDS_ATTR); | - | ||||||||||||||||||||||||
| 238 | blitShaderProg->bindAttributeLocation("vertexCoordsArray", QT_VERTEX_COORDS_ATTR); | - | ||||||||||||||||||||||||
| 239 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 240 | - | |||||||||||||||||||||||||
| 241 | blitShaderProg->link(); | - | ||||||||||||||||||||||||
| 242 | if (blitShaderProg->isLinked()
| 0-1 | ||||||||||||||||||||||||
| 243 | if (!inCache
| 0-1 | ||||||||||||||||||||||||
| 244 | blitShaderCache.store(blitShaderProg, context); executed 1 time by 1 test: blitShaderCache.store(blitShaderProg, context);Executed by:
| 1 | ||||||||||||||||||||||||
| 245 | } executed 1 time by 1 test: else {end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 246 | QMessageLogger(__FILE__, 285, __PRETTY_FUNCTION__).critical("Errors linking blit shader: %s", QString(blitShaderProg->log()).toLocal8Bit().constData()); | - | ||||||||||||||||||||||||
| 247 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 248 | - | |||||||||||||||||||||||||
| 249 | - | |||||||||||||||||||||||||
| 250 | - | |||||||||||||||||||||||||
| 251 | - | |||||||||||||||||||||||||
| 252 | } | - | ||||||||||||||||||||||||
| 253 | - | |||||||||||||||||||||||||
| 254 | QGLEngineSharedShaders::~QGLEngineSharedShaders() | - | ||||||||||||||||||||||||
| 255 | { | - | ||||||||||||||||||||||||
| 256 | - | |||||||||||||||||||||||||
| 257 | - | |||||||||||||||||||||||||
| 258 | - | |||||||||||||||||||||||||
| 259 | qDeleteAll(shaders); | - | ||||||||||||||||||||||||
| 260 | shaders.clear(); | - | ||||||||||||||||||||||||
| 261 | - | |||||||||||||||||||||||||
| 262 | qDeleteAll(cachedPrograms); | - | ||||||||||||||||||||||||
| 263 | cachedPrograms.clear(); | - | ||||||||||||||||||||||||
| 264 | - | |||||||||||||||||||||||||
| 265 | if (blitShaderProg
| 0-1 | ||||||||||||||||||||||||
| 266 | delete blitShaderProg; | - | ||||||||||||||||||||||||
| 267 | blitShaderProg = 0; | - | ||||||||||||||||||||||||
| 268 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 269 | - | |||||||||||||||||||||||||
| 270 | if (simpleShaderProg
| 0-1 | ||||||||||||||||||||||||
| 271 | delete simpleShaderProg; | - | ||||||||||||||||||||||||
| 272 | simpleShaderProg = 0; | - | ||||||||||||||||||||||||
| 273 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 274 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 275 | - | |||||||||||||||||||||||||
| 276 | - | |||||||||||||||||||||||||
| 277 | QByteArray QGLEngineSharedShaders::snippetNameStr(SnippetName name) | - | ||||||||||||||||||||||||
| 278 | { | - | ||||||||||||||||||||||||
| 279 | QMetaEnum m = staticMetaObject.enumerator(staticMetaObject.indexOfEnumerator("SnippetName")); | - | ||||||||||||||||||||||||
| 280 | return executed 6 times by 1 test: QByteArray(m.valueToKey(name));return QByteArray(m.valueToKey(name));Executed by:
executed 6 times by 1 test: return QByteArray(m.valueToKey(name));Executed by:
| 6 | ||||||||||||||||||||||||
| 281 | } | - | ||||||||||||||||||||||||
| 282 | - | |||||||||||||||||||||||||
| 283 | - | |||||||||||||||||||||||||
| 284 | - | |||||||||||||||||||||||||
| 285 | - | |||||||||||||||||||||||||
| 286 | QGLEngineShaderProg *QGLEngineSharedShaders::findProgramInCache(const QGLEngineShaderProg &prog) | - | ||||||||||||||||||||||||
| 287 | { | - | ||||||||||||||||||||||||
| 288 | for (int i = 0; i < cachedPrograms.size()
| 1 | ||||||||||||||||||||||||
| 289 | QGLEngineShaderProg *cachedProg = cachedPrograms[i]; | - | ||||||||||||||||||||||||
| 290 | if (*
| 0-1 | ||||||||||||||||||||||||
| 291 | - | |||||||||||||||||||||||||
| 292 | cachedPrograms.move(i, 0); | - | ||||||||||||||||||||||||
| 293 | cachedProg->program->bind(); | - | ||||||||||||||||||||||||
| 294 | return executed 1 time by 1 test: cachedProg;return cachedProg;Executed by:
executed 1 time by 1 test: return cachedProg;Executed by:
| 1 | ||||||||||||||||||||||||
| 295 | } | - | ||||||||||||||||||||||||
| 296 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 297 | - | |||||||||||||||||||||||||
| 298 | QScopedPointer<QGLEngineShaderProg> newProg; | - | ||||||||||||||||||||||||
| 299 | - | |||||||||||||||||||||||||
| 300 | do { | - | ||||||||||||||||||||||||
| 301 | QByteArray fragSource; | - | ||||||||||||||||||||||||
| 302 | - | |||||||||||||||||||||||||
| 303 | - | |||||||||||||||||||||||||
| 304 | if (prog.srcPixelFragShader == CustomImageSrcFragmentShader
| 0-1 | ||||||||||||||||||||||||
| 305 | fragSource.append(prog.customStageSource); never executed: fragSource.append(prog.customStageSource); | 0 | ||||||||||||||||||||||||
| 306 | fragSource.append(qShaderSnippets[prog.mainFragShader]); | - | ||||||||||||||||||||||||
| 307 | fragSource.append(qShaderSnippets[prog.srcPixelFragShader]); | - | ||||||||||||||||||||||||
| 308 | if (prog.compositionFragShader
| 0-1 | ||||||||||||||||||||||||
| 309 | fragSource.append(qShaderSnippets[prog.compositionFragShader]); executed 1 time by 1 test: fragSource.append(qShaderSnippets[prog.compositionFragShader]);Executed by:
| 1 | ||||||||||||||||||||||||
| 310 | if (prog.maskFragShader
| 0-1 | ||||||||||||||||||||||||
| 311 | fragSource.append(qShaderSnippets[prog.maskFragShader]); executed 1 time by 1 test: fragSource.append(qShaderSnippets[prog.maskFragShader]);Executed by:
| 1 | ||||||||||||||||||||||||
| 312 | - | |||||||||||||||||||||||||
| 313 | QByteArray vertexSource; | - | ||||||||||||||||||||||||
| 314 | vertexSource.append(qShaderSnippets[prog.mainVertexShader]); | - | ||||||||||||||||||||||||
| 315 | vertexSource.append(qShaderSnippets[prog.positionVertexShader]); | - | ||||||||||||||||||||||||
| 316 | - | |||||||||||||||||||||||||
| 317 | QScopedPointer<QGLShaderProgram> shaderProgram(new QGLShaderProgram); | - | ||||||||||||||||||||||||
| 318 | - | |||||||||||||||||||||||||
| 319 | CachedShader shaderCache(fragSource, vertexSource); | - | ||||||||||||||||||||||||
| 320 | bool inCache = shaderCache.load(shaderProgram.data(), QGLContext::currentContext()); | - | ||||||||||||||||||||||||
| 321 | - | |||||||||||||||||||||||||
| 322 | if (!inCache
| 0-1 | ||||||||||||||||||||||||
| 323 | - | |||||||||||||||||||||||||
| 324 | QScopedPointer<QGLShader> fragShader(new QGLShader(QGLShader::Fragment)); | - | ||||||||||||||||||||||||
| 325 | QByteArray description; | - | ||||||||||||||||||||||||
| 326 | - | |||||||||||||||||||||||||
| 327 | - | |||||||||||||||||||||||||
| 328 | description.append("Fragment shader: main="); | - | ||||||||||||||||||||||||
| 329 | description.append(snippetNameStr(prog.mainFragShader)); | - | ||||||||||||||||||||||||
| 330 | description.append(", srcPixel="); | - | ||||||||||||||||||||||||
| 331 | description.append(snippetNameStr(prog.srcPixelFragShader)); | - | ||||||||||||||||||||||||
| 332 | if (prog.compositionFragShader
| 0-1 | ||||||||||||||||||||||||
| 333 | description.append(", composition="); | - | ||||||||||||||||||||||||
| 334 | description.append(snippetNameStr(prog.compositionFragShader)); | - | ||||||||||||||||||||||||
| 335 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 336 | if (prog.maskFragShader
| 0-1 | ||||||||||||||||||||||||
| 337 | description.append(", mask="); | - | ||||||||||||||||||||||||
| 338 | description.append(snippetNameStr(prog.maskFragShader)); | - | ||||||||||||||||||||||||
| 339 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 340 | fragShader->setObjectName(QString::fromLatin1(description)); | - | ||||||||||||||||||||||||
| 341 | - | |||||||||||||||||||||||||
| 342 | if (!fragShader->compileSourceCode(fragSource)
| 0-1 | ||||||||||||||||||||||||
| 343 | QMessageLogger(__FILE__, 382, __PRETTY_FUNCTION__).warning() << "Warning:" << description << "failed to compile!"; | - | ||||||||||||||||||||||||
| 344 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 345 | } | - | ||||||||||||||||||||||||
| 346 | - | |||||||||||||||||||||||||
| 347 | QScopedPointer<QGLShader> vertexShader(new QGLShader(QGLShader::Vertex)); | - | ||||||||||||||||||||||||
| 348 | - | |||||||||||||||||||||||||
| 349 | - | |||||||||||||||||||||||||
| 350 | description.clear(); | - | ||||||||||||||||||||||||
| 351 | description.append("Vertex shader: main="); | - | ||||||||||||||||||||||||
| 352 | description.append(snippetNameStr(prog.mainVertexShader)); | - | ||||||||||||||||||||||||
| 353 | description.append(", position="); | - | ||||||||||||||||||||||||
| 354 | description.append(snippetNameStr(prog.positionVertexShader)); | - | ||||||||||||||||||||||||
| 355 | vertexShader->setObjectName(QString::fromLatin1(description)); | - | ||||||||||||||||||||||||
| 356 | - | |||||||||||||||||||||||||
| 357 | if (!vertexShader->compileSourceCode(vertexSource)
| 0-1 | ||||||||||||||||||||||||
| 358 | QMessageLogger(__FILE__, 397, __PRETTY_FUNCTION__).warning() << "Warning:" << description << "failed to compile!"; | - | ||||||||||||||||||||||||
| 359 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 360 | } | - | ||||||||||||||||||||||||
| 361 | - | |||||||||||||||||||||||||
| 362 | shaders.append(vertexShader.data()); | - | ||||||||||||||||||||||||
| 363 | shaders.append(fragShader.data()); | - | ||||||||||||||||||||||||
| 364 | shaderProgram->addShader(vertexShader.take()); | - | ||||||||||||||||||||||||
| 365 | shaderProgram->addShader(fragShader.take()); | - | ||||||||||||||||||||||||
| 366 | - | |||||||||||||||||||||||||
| 367 | - | |||||||||||||||||||||||||
| 368 | shaderProgram->bindAttributeLocation("vertexCoordsArray", QT_VERTEX_COORDS_ATTR); | - | ||||||||||||||||||||||||
| 369 | if (prog.useTextureCoords
| 0-1 | ||||||||||||||||||||||||
| 370 | shaderProgram->bindAttributeLocation("textureCoordArray", QT_TEXTURE_COORDS_ATTR); never executed: shaderProgram->bindAttributeLocation("textureCoordArray", QT_TEXTURE_COORDS_ATTR); | 0 | ||||||||||||||||||||||||
| 371 | if (prog.useOpacityAttribute
| 0-1 | ||||||||||||||||||||||||
| 372 | shaderProgram->bindAttributeLocation("opacityArray", QT_OPACITY_ATTR); never executed: shaderProgram->bindAttributeLocation("opacityArray", QT_OPACITY_ATTR); | 0 | ||||||||||||||||||||||||
| 373 | if (prog.usePmvMatrixAttribute
| 0-1 | ||||||||||||||||||||||||
| 374 | shaderProgram->bindAttributeLocation("pmvMatrix1", QT_PMV_MATRIX_1_ATTR); | - | ||||||||||||||||||||||||
| 375 | shaderProgram->bindAttributeLocation("pmvMatrix2", QT_PMV_MATRIX_2_ATTR); | - | ||||||||||||||||||||||||
| 376 | shaderProgram->bindAttributeLocation("pmvMatrix3", QT_PMV_MATRIX_3_ATTR); | - | ||||||||||||||||||||||||
| 377 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 378 | } executed 1 time by 1 test: end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 379 | - | |||||||||||||||||||||||||
| 380 | newProg.reset(new QGLEngineShaderProg(prog)); | - | ||||||||||||||||||||||||
| 381 | newProg->program = shaderProgram.take(); | - | ||||||||||||||||||||||||
| 382 | - | |||||||||||||||||||||||||
| 383 | newProg->program->link(); | - | ||||||||||||||||||||||||
| 384 | if (newProg->program->isLinked()
| 0-1 | ||||||||||||||||||||||||
| 385 | if (!inCache
| 0-1 | ||||||||||||||||||||||||
| 386 | shaderCache.store(newProg->program, QGLContext::currentContext()); executed 1 time by 1 test: shaderCache.store(newProg->program, QGLContext::currentContext());Executed by:
| 1 | ||||||||||||||||||||||||
| 387 | } executed 1 time by 1 test: else {end of blockExecuted by:
| 1 | ||||||||||||||||||||||||
| 388 | QString error; | - | ||||||||||||||||||||||||
| 389 | error = QLatin1String("Shader program failed to link,"); | - | ||||||||||||||||||||||||
| 390 | - | |||||||||||||||||||||||||
| 391 | QLatin1String br("\n"); | - | ||||||||||||||||||||||||
| 392 | error += QLatin1String("\n Shaders Used:\n"); | - | ||||||||||||||||||||||||
| 393 | for (int i = 0; i < newProg->program->shaders().count()
| 0 | ||||||||||||||||||||||||
| 394 | QGLShader *shader = newProg->program->shaders().at(i); | - | ||||||||||||||||||||||||
| 395 | error += QLatin1String(" ") + shader->objectName() + QLatin1String(": \n") | - | ||||||||||||||||||||||||
| 396 | + QLatin1String(shader->sourceCode()) + br; | - | ||||||||||||||||||||||||
| 397 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 398 | - | |||||||||||||||||||||||||
| 399 | error += QLatin1String(" Error Log:\n") | - | ||||||||||||||||||||||||
| 400 | + QLatin1String(" ") + newProg->program->log(); | - | ||||||||||||||||||||||||
| 401 | QMessageLogger(__FILE__, 440, __PRETTY_FUNCTION__).warning() << error; | - | ||||||||||||||||||||||||
| 402 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 403 | } | - | ||||||||||||||||||||||||
| 404 | - | |||||||||||||||||||||||||
| 405 | newProg->program->bind(); | - | ||||||||||||||||||||||||
| 406 | - | |||||||||||||||||||||||||
| 407 | if (newProg->maskFragShader != QGLEngineSharedShaders::NoMaskFragmentShader
| 0-1 | ||||||||||||||||||||||||
| 408 | GLuint location = newProg->program->uniformLocation("maskTexture"); | - | ||||||||||||||||||||||||
| 409 | newProg->program->setUniformValue(location, GLuint(1)); | - | ||||||||||||||||||||||||
| 410 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 411 | - | |||||||||||||||||||||||||
| 412 | if (cachedPrograms.count() > 30
| 0-1 | ||||||||||||||||||||||||
| 413 | - | |||||||||||||||||||||||||
| 414 | - | |||||||||||||||||||||||||
| 415 | - | |||||||||||||||||||||||||
| 416 | for (int i = 0; i < 5
| 0 | ||||||||||||||||||||||||
| 417 | delete cachedPrograms.last(); | - | ||||||||||||||||||||||||
| 418 | cachedPrograms.removeLast(); | - | ||||||||||||||||||||||||
| 419 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 420 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 421 | - | |||||||||||||||||||||||||
| 422 | cachedPrograms.insert(0, newProg.data()); | - | ||||||||||||||||||||||||
| 423 | } while (false); | - | ||||||||||||||||||||||||
| 424 | - | |||||||||||||||||||||||||
| 425 | return executed 1 time by 1 test: newProg.take();return newProg.take();Executed by:
executed 1 time by 1 test: return newProg.take();Executed by:
| 1 | ||||||||||||||||||||||||
| 426 | } | - | ||||||||||||||||||||||||
| 427 | - | |||||||||||||||||||||||||
| 428 | void QGLEngineSharedShaders::cleanupCustomStage(QGLCustomShaderStage* stage) | - | ||||||||||||||||||||||||
| 429 | { | - | ||||||||||||||||||||||||
| 430 | - | |||||||||||||||||||||||||
| 431 | for (int i = 0; i < cachedPrograms.size()
| 0 | ||||||||||||||||||||||||
| 432 | QGLEngineShaderProg *cachedProg = cachedPrograms[i]; | - | ||||||||||||||||||||||||
| 433 | if (cachedProg->customStageSource == stage->source()
| 0 | ||||||||||||||||||||||||
| 434 | delete cachedProg; | - | ||||||||||||||||||||||||
| 435 | cachedPrograms.removeAt(i); | - | ||||||||||||||||||||||||
| 436 | i--; | - | ||||||||||||||||||||||||
| 437 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 438 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 439 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 440 | - | |||||||||||||||||||||||||
| 441 | - | |||||||||||||||||||||||||
| 442 | QGLEngineShaderManager::QGLEngineShaderManager(QGLContext* context) | - | ||||||||||||||||||||||||
| 443 | : ctx(context), | - | ||||||||||||||||||||||||
| 444 | shaderProgNeedsChanging(true), | - | ||||||||||||||||||||||||
| 445 | complexGeometry(false), | - | ||||||||||||||||||||||||
| 446 | srcPixelType(Qt::NoBrush), | - | ||||||||||||||||||||||||
| 447 | opacityMode(NoOpacity), | - | ||||||||||||||||||||||||
| 448 | maskType(NoMask), | - | ||||||||||||||||||||||||
| 449 | compositionMode(QPainter::CompositionMode_SourceOver), | - | ||||||||||||||||||||||||
| 450 | customSrcStage(0), | - | ||||||||||||||||||||||||
| 451 | currentShaderProg(0) | - | ||||||||||||||||||||||||
| 452 | { | - | ||||||||||||||||||||||||
| 453 | sharedShaders = QGLEngineSharedShaders::shadersForContext(context); | - | ||||||||||||||||||||||||
| 454 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 455 | - | |||||||||||||||||||||||||
| 456 | QGLEngineShaderManager::~QGLEngineShaderManager() | - | ||||||||||||||||||||||||
| 457 | { | - | ||||||||||||||||||||||||
| 458 | - | |||||||||||||||||||||||||
| 459 | removeCustomStage(); | - | ||||||||||||||||||||||||
| 460 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 461 | - | |||||||||||||||||||||||||
| 462 | GLuint QGLEngineShaderManager::getUniformLocation(Uniform id) | - | ||||||||||||||||||||||||
| 463 | { | - | ||||||||||||||||||||||||
| 464 | if (!currentShaderProg
| 0-2 | ||||||||||||||||||||||||
| 465 | return never executed: 0;return 0;never executed: return 0; | 0 | ||||||||||||||||||||||||
| 466 | - | |||||||||||||||||||||||||
| 467 | QVector<uint> &uniformLocations = currentShaderProg->uniformLocations; | - | ||||||||||||||||||||||||
| 468 | if (uniformLocations.isEmpty()
| 1 | ||||||||||||||||||||||||
| 469 | uniformLocations.fill(GLuint(-1), NumUniforms); executed 1 time by 1 test: uniformLocations.fill(GLuint(-1), NumUniforms);Executed by:
| 1 | ||||||||||||||||||||||||
| 470 | - | |||||||||||||||||||||||||
| 471 | static const char *const uniformNames[] = { | - | ||||||||||||||||||||||||
| 472 | "imageTexture", | - | ||||||||||||||||||||||||
| 473 | "patternColor", | - | ||||||||||||||||||||||||
| 474 | "globalOpacity", | - | ||||||||||||||||||||||||
| 475 | "depth", | - | ||||||||||||||||||||||||
| 476 | "maskTexture", | - | ||||||||||||||||||||||||
| 477 | "fragmentColor", | - | ||||||||||||||||||||||||
| 478 | "linearData", | - | ||||||||||||||||||||||||
| 479 | "angle", | - | ||||||||||||||||||||||||
| 480 | "halfViewportSize", | - | ||||||||||||||||||||||||
| 481 | "fmp", | - | ||||||||||||||||||||||||
| 482 | "fmp2_m_radius2", | - | ||||||||||||||||||||||||
| 483 | "inverse_2_fmp2_m_radius2", | - | ||||||||||||||||||||||||
| 484 | "sqrfr", | - | ||||||||||||||||||||||||
| 485 | "bradius", | - | ||||||||||||||||||||||||
| 486 | "invertedTextureSize", | - | ||||||||||||||||||||||||
| 487 | "brushTransform", | - | ||||||||||||||||||||||||
| 488 | "brushTexture", | - | ||||||||||||||||||||||||
| 489 | "matrix", | - | ||||||||||||||||||||||||
| 490 | "translateZ" | - | ||||||||||||||||||||||||
| 491 | }; | - | ||||||||||||||||||||||||
| 492 | - | |||||||||||||||||||||||||
| 493 | if (uniformLocations.at(id) == GLuint(-1)
| 1 | ||||||||||||||||||||||||
| 494 | uniformLocations[id] = currentShaderProg->program->uniformLocation(uniformNames[id]); executed 1 time by 1 test: uniformLocations[id] = currentShaderProg->program->uniformLocation(uniformNames[id]);Executed by:
| 1 | ||||||||||||||||||||||||
| 495 | - | |||||||||||||||||||||||||
| 496 | return executed 2 times by 1 test: uniformLocations.at(id);return uniformLocations.at(id);Executed by:
executed 2 times by 1 test: return uniformLocations.at(id);Executed by:
| 2 | ||||||||||||||||||||||||
| 497 | } | - | ||||||||||||||||||||||||
| 498 | - | |||||||||||||||||||||||||
| 499 | - | |||||||||||||||||||||||||
| 500 | void QGLEngineShaderManager::optimiseForBrushTransform(QTransform::TransformationType transformType) | - | ||||||||||||||||||||||||
| 501 | { | - | ||||||||||||||||||||||||
| 502 | (void)transformType;; | - | ||||||||||||||||||||||||
| 503 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 504 | - | |||||||||||||||||||||||||
| 505 | void QGLEngineShaderManager::setDirty() | - | ||||||||||||||||||||||||
| 506 | { | - | ||||||||||||||||||||||||
| 507 | shaderProgNeedsChanging = true; | - | ||||||||||||||||||||||||
| 508 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 509 | - | |||||||||||||||||||||||||
| 510 | void QGLEngineShaderManager::setSrcPixelType(Qt::BrushStyle style) | - | ||||||||||||||||||||||||
| 511 | { | - | ||||||||||||||||||||||||
| 512 | ((!(style != Qt::NoBrush)) ? qt_assert("style != Qt::NoBrush",__FILE__,551) : qt_noop()); | - | ||||||||||||||||||||||||
| 513 | if (srcPixelType == PixelSrcType(style)
| 0-2 | ||||||||||||||||||||||||
| 514 | return; never executed: return; | 0 | ||||||||||||||||||||||||
| 515 | - | |||||||||||||||||||||||||
| 516 | srcPixelType = style; | - | ||||||||||||||||||||||||
| 517 | shaderProgNeedsChanging = true; | - | ||||||||||||||||||||||||
| 518 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 519 | - | |||||||||||||||||||||||||
| 520 | void QGLEngineShaderManager::setSrcPixelType(PixelSrcType type) | - | ||||||||||||||||||||||||
| 521 | { | - | ||||||||||||||||||||||||
| 522 | if (srcPixelType == type
| 0 | ||||||||||||||||||||||||
| 523 | return; never executed: return; | 0 | ||||||||||||||||||||||||
| 524 | - | |||||||||||||||||||||||||
| 525 | srcPixelType = type; | - | ||||||||||||||||||||||||
| 526 | shaderProgNeedsChanging = true; | - | ||||||||||||||||||||||||
| 527 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 528 | - | |||||||||||||||||||||||||
| 529 | void QGLEngineShaderManager::setOpacityMode(OpacityMode mode) | - | ||||||||||||||||||||||||
| 530 | { | - | ||||||||||||||||||||||||
| 531 | if (opacityMode == mode
| 0-28 | ||||||||||||||||||||||||
| 532 | return; executed 28 times by 1 test: return;Executed by:
| 28 | ||||||||||||||||||||||||
| 533 | - | |||||||||||||||||||||||||
| 534 | opacityMode = mode; | - | ||||||||||||||||||||||||
| 535 | shaderProgNeedsChanging = true; | - | ||||||||||||||||||||||||
| 536 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 537 | - | |||||||||||||||||||||||||
| 538 | void QGLEngineShaderManager::setMaskType(MaskType type) | - | ||||||||||||||||||||||||
| 539 | { | - | ||||||||||||||||||||||||
| 540 | if (maskType == type
| 0 | ||||||||||||||||||||||||
| 541 | return; never executed: return; | 0 | ||||||||||||||||||||||||
| 542 | - | |||||||||||||||||||||||||
| 543 | maskType = type; | - | ||||||||||||||||||||||||
| 544 | shaderProgNeedsChanging = true; | - | ||||||||||||||||||||||||
| 545 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 546 | - | |||||||||||||||||||||||||
| 547 | void QGLEngineShaderManager::setCompositionMode(QPainter::CompositionMode mode) | - | ||||||||||||||||||||||||
| 548 | { | - | ||||||||||||||||||||||||
| 549 | if (compositionMode == mode
| 0 | ||||||||||||||||||||||||
| 550 | return; never executed: return; | 0 | ||||||||||||||||||||||||
| 551 | - | |||||||||||||||||||||||||
| 552 | compositionMode = mode; | - | ||||||||||||||||||||||||
| 553 | shaderProgNeedsChanging = true; | - | ||||||||||||||||||||||||
| 554 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 555 | - | |||||||||||||||||||||||||
| 556 | void QGLEngineShaderManager::setCustomStage(QGLCustomShaderStage* stage) | - | ||||||||||||||||||||||||
| 557 | { | - | ||||||||||||||||||||||||
| 558 | if (customSrcStage
| 0 | ||||||||||||||||||||||||
| 559 | removeCustomStage(); never executed: removeCustomStage(); | 0 | ||||||||||||||||||||||||
| 560 | customSrcStage = stage; | - | ||||||||||||||||||||||||
| 561 | shaderProgNeedsChanging = true; | - | ||||||||||||||||||||||||
| 562 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 563 | - | |||||||||||||||||||||||||
| 564 | void QGLEngineShaderManager::removeCustomStage() | - | ||||||||||||||||||||||||
| 565 | { | - | ||||||||||||||||||||||||
| 566 | if (customSrcStage
| 0-2 | ||||||||||||||||||||||||
| 567 | customSrcStage->setInactive(); never executed: customSrcStage->setInactive(); | 0 | ||||||||||||||||||||||||
| 568 | customSrcStage = 0; | - | ||||||||||||||||||||||||
| 569 | shaderProgNeedsChanging = true; | - | ||||||||||||||||||||||||
| 570 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 571 | - | |||||||||||||||||||||||||
| 572 | QGLShaderProgram* QGLEngineShaderManager::currentProgram() | - | ||||||||||||||||||||||||
| 573 | { | - | ||||||||||||||||||||||||
| 574 | if (currentShaderProg
| 0-2 | ||||||||||||||||||||||||
| 575 | return executed 2 times by 1 test: currentShaderProg->program;return currentShaderProg->program;Executed by:
executed 2 times by 1 test: return currentShaderProg->program;Executed by:
| 2 | ||||||||||||||||||||||||
| 576 | else | - | ||||||||||||||||||||||||
| 577 | return never executed: sharedShaders->simpleProgram();return sharedShaders->simpleProgram();never executed: return sharedShaders->simpleProgram(); | 0 | ||||||||||||||||||||||||
| 578 | } | - | ||||||||||||||||||||||||
| 579 | - | |||||||||||||||||||||||||
| 580 | void QGLEngineShaderManager::useSimpleProgram() | - | ||||||||||||||||||||||||
| 581 | { | - | ||||||||||||||||||||||||
| 582 | sharedShaders->simpleProgram()->bind(); | - | ||||||||||||||||||||||||
| 583 | QGLContextPrivate* ctx_d = ctx->d_func(); | - | ||||||||||||||||||||||||
| 584 | ctx_d->setVertexAttribArrayEnabled(QT_VERTEX_COORDS_ATTR, true); | - | ||||||||||||||||||||||||
| 585 | ctx_d->setVertexAttribArrayEnabled(QT_TEXTURE_COORDS_ATTR, false); | - | ||||||||||||||||||||||||
| 586 | ctx_d->setVertexAttribArrayEnabled(QT_OPACITY_ATTR, false); | - | ||||||||||||||||||||||||
| 587 | shaderProgNeedsChanging = true; | - | ||||||||||||||||||||||||
| 588 | } executed 4 times by 1 test: end of blockExecuted by:
| 4 | ||||||||||||||||||||||||
| 589 | - | |||||||||||||||||||||||||
| 590 | void QGLEngineShaderManager::useBlitProgram() | - | ||||||||||||||||||||||||
| 591 | { | - | ||||||||||||||||||||||||
| 592 | sharedShaders->blitProgram()->bind(); | - | ||||||||||||||||||||||||
| 593 | QGLContextPrivate* ctx_d = ctx->d_func(); | - | ||||||||||||||||||||||||
| 594 | ctx_d->setVertexAttribArrayEnabled(QT_VERTEX_COORDS_ATTR, true); | - | ||||||||||||||||||||||||
| 595 | ctx_d->setVertexAttribArrayEnabled(QT_TEXTURE_COORDS_ATTR, true); | - | ||||||||||||||||||||||||
| 596 | ctx_d->setVertexAttribArrayEnabled(QT_OPACITY_ATTR, false); | - | ||||||||||||||||||||||||
| 597 | shaderProgNeedsChanging = true; | - | ||||||||||||||||||||||||
| 598 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 599 | - | |||||||||||||||||||||||||
| 600 | QGLShaderProgram* QGLEngineShaderManager::simpleProgram() | - | ||||||||||||||||||||||||
| 601 | { | - | ||||||||||||||||||||||||
| 602 | return never executed: sharedShaders->simpleProgram();return sharedShaders->simpleProgram();never executed: return sharedShaders->simpleProgram(); | 0 | ||||||||||||||||||||||||
| 603 | } | - | ||||||||||||||||||||||||
| 604 | - | |||||||||||||||||||||||||
| 605 | QGLShaderProgram* QGLEngineShaderManager::blitProgram() | - | ||||||||||||||||||||||||
| 606 | { | - | ||||||||||||||||||||||||
| 607 | return never executed: sharedShaders->blitProgram();return sharedShaders->blitProgram();never executed: return sharedShaders->blitProgram(); | 0 | ||||||||||||||||||||||||
| 608 | } | - | ||||||||||||||||||||||||
| 609 | - | |||||||||||||||||||||||||
| 610 | - | |||||||||||||||||||||||||
| 611 | - | |||||||||||||||||||||||||
| 612 | - | |||||||||||||||||||||||||
| 613 | - | |||||||||||||||||||||||||
| 614 | bool QGLEngineShaderManager::useCorrectShaderProg() | - | ||||||||||||||||||||||||
| 615 | { | - | ||||||||||||||||||||||||
| 616 | if (!shaderProgNeedsChanging
| 2-26 | ||||||||||||||||||||||||
| 617 | return executed 26 times by 1 test: false;return false;Executed by:
executed 26 times by 1 test: return false;Executed by:
| 26 | ||||||||||||||||||||||||
| 618 | - | |||||||||||||||||||||||||
| 619 | bool useCustomSrc = customSrcStage != 0; | - | ||||||||||||||||||||||||
| 620 | if (useCustomSrc
| 0-2 | ||||||||||||||||||||||||
| 621 | useCustomSrc = false; | - | ||||||||||||||||||||||||
| 622 | QMessageLogger(__FILE__, 661, __PRETTY_FUNCTION__).warning("QGLEngineShaderManager - Ignoring custom shader stage for non image src"); | - | ||||||||||||||||||||||||
| 623 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 624 | - | |||||||||||||||||||||||||
| 625 | QGLEngineShaderProg requiredProgram; | - | ||||||||||||||||||||||||
| 626 | - | |||||||||||||||||||||||||
| 627 | bool texCoords = false; | - | ||||||||||||||||||||||||
| 628 | - | |||||||||||||||||||||||||
| 629 | - | |||||||||||||||||||||||||
| 630 | - | |||||||||||||||||||||||||
| 631 | requiredProgram.positionVertexShader = QGLEngineSharedShaders::InvalidSnippetName; | - | ||||||||||||||||||||||||
| 632 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::InvalidSnippetName; | - | ||||||||||||||||||||||||
| 633 | bool isAffine = brushTransform.isAffine(); | - | ||||||||||||||||||||||||
| 634 | if ( (
| 0-2 | ||||||||||||||||||||||||
| 635 | if (isAffine
| 0 | ||||||||||||||||||||||||
| 636 | requiredProgram.positionVertexShader = QGLEngineSharedShaders::AffinePositionWithPatternBrushVertexShader; never executed: requiredProgram.positionVertexShader = QGLEngineSharedShaders::AffinePositionWithPatternBrushVertexShader; | 0 | ||||||||||||||||||||||||
| 637 | else | - | ||||||||||||||||||||||||
| 638 | requiredProgram.positionVertexShader = QGLEngineSharedShaders::PositionWithPatternBrushVertexShader; never executed: requiredProgram.positionVertexShader = QGLEngineSharedShaders::PositionWithPatternBrushVertexShader; | 0 | ||||||||||||||||||||||||
| 639 | - | |||||||||||||||||||||||||
| 640 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::PatternBrushSrcFragmentShader; | - | ||||||||||||||||||||||||
| 641 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 642 | else switch (srcPixelType) { | - | ||||||||||||||||||||||||
| 643 | default never executed: :default:never executed: default: | 0 | ||||||||||||||||||||||||
| 644 | case never executed: Qt::NoBrush:case Qt::NoBrush:never executed: case Qt::NoBrush: | 0 | ||||||||||||||||||||||||
| 645 | QMessageLogger(__FILE__, 684, __PRETTY_FUNCTION__).fatal("QGLEngineShaderManager::useCorrectShaderProg() - Qt::NoBrush style is set"); | - | ||||||||||||||||||||||||
| 646 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 647 | case never executed: QGLEngineShaderManager::ImageSrc:case QGLEngineShaderManager::ImageSrc:never executed: case QGLEngineShaderManager::ImageSrc: | 0 | ||||||||||||||||||||||||
| 648 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::ImageSrcFragmentShader; | - | ||||||||||||||||||||||||
| 649 | requiredProgram.positionVertexShader = QGLEngineSharedShaders::PositionOnlyVertexShader; | - | ||||||||||||||||||||||||
| 650 | texCoords = true; | - | ||||||||||||||||||||||||
| 651 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 652 | case never executed: QGLEngineShaderManager::NonPremultipliedImageSrc:case QGLEngineShaderManager::NonPremultipliedImageSrc:never executed: case QGLEngineShaderManager::NonPremultipliedImageSrc: | 0 | ||||||||||||||||||||||||
| 653 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::NonPremultipliedImageSrcFragmentShader; | - | ||||||||||||||||||||||||
| 654 | requiredProgram.positionVertexShader = QGLEngineSharedShaders::PositionOnlyVertexShader; | - | ||||||||||||||||||||||||
| 655 | texCoords = true; | - | ||||||||||||||||||||||||
| 656 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 657 | case never executed: QGLEngineShaderManager::PatternSrc:case QGLEngineShaderManager::PatternSrc:never executed: case QGLEngineShaderManager::PatternSrc: | 0 | ||||||||||||||||||||||||
| 658 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::ImageSrcWithPatternFragmentShader; | - | ||||||||||||||||||||||||
| 659 | requiredProgram.positionVertexShader = QGLEngineSharedShaders::PositionOnlyVertexShader; | - | ||||||||||||||||||||||||
| 660 | texCoords = true; | - | ||||||||||||||||||||||||
| 661 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 662 | case never executed: QGLEngineShaderManager::TextureSrcWithPattern:case QGLEngineShaderManager::TextureSrcWithPattern:never executed: case QGLEngineShaderManager::TextureSrcWithPattern: | 0 | ||||||||||||||||||||||||
| 663 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::TextureBrushSrcWithPatternFragmentShader; | - | ||||||||||||||||||||||||
| 664 | requiredProgram.positionVertexShader = isAffine
| 0 | ||||||||||||||||||||||||
| 665 | : QGLEngineSharedShaders::PositionWithTextureBrushVertexShader; | - | ||||||||||||||||||||||||
| 666 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 667 | case executed 2 times by 1 test: Qt::SolidPattern:case Qt::SolidPattern:Executed by:
executed 2 times by 1 test: case Qt::SolidPattern:Executed by:
| 2 | ||||||||||||||||||||||||
| 668 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::SolidBrushSrcFragmentShader; | - | ||||||||||||||||||||||||
| 669 | requiredProgram.positionVertexShader = QGLEngineSharedShaders::PositionOnlyVertexShader; | - | ||||||||||||||||||||||||
| 670 | break; executed 2 times by 1 test: break;Executed by:
| 2 | ||||||||||||||||||||||||
| 671 | case never executed: Qt::LinearGradientPattern:case Qt::LinearGradientPattern:never executed: case Qt::LinearGradientPattern: | 0 | ||||||||||||||||||||||||
| 672 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::LinearGradientBrushSrcFragmentShader; | - | ||||||||||||||||||||||||
| 673 | requiredProgram.positionVertexShader = isAffine
| 0 | ||||||||||||||||||||||||
| 674 | : QGLEngineSharedShaders::PositionWithLinearGradientBrushVertexShader; | - | ||||||||||||||||||||||||
| 675 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 676 | case never executed: Qt::ConicalGradientPattern:case Qt::ConicalGradientPattern:never executed: case Qt::ConicalGradientPattern: | 0 | ||||||||||||||||||||||||
| 677 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::ConicalGradientBrushSrcFragmentShader; | - | ||||||||||||||||||||||||
| 678 | requiredProgram.positionVertexShader = isAffine
| 0 | ||||||||||||||||||||||||
| 679 | : QGLEngineSharedShaders::PositionWithConicalGradientBrushVertexShader; | - | ||||||||||||||||||||||||
| 680 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 681 | case never executed: Qt::RadialGradientPattern:case Qt::RadialGradientPattern:never executed: case Qt::RadialGradientPattern: | 0 | ||||||||||||||||||||||||
| 682 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::RadialGradientBrushSrcFragmentShader; | - | ||||||||||||||||||||||||
| 683 | requiredProgram.positionVertexShader = isAffine
| 0 | ||||||||||||||||||||||||
| 684 | : QGLEngineSharedShaders::PositionWithRadialGradientBrushVertexShader; | - | ||||||||||||||||||||||||
| 685 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 686 | case never executed: Qt::TexturePattern:case Qt::TexturePattern:never executed: case Qt::TexturePattern: | 0 | ||||||||||||||||||||||||
| 687 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::TextureBrushSrcFragmentShader; | - | ||||||||||||||||||||||||
| 688 | requiredProgram.positionVertexShader = isAffine
| 0 | ||||||||||||||||||||||||
| 689 | : QGLEngineSharedShaders::PositionWithTextureBrushVertexShader; | - | ||||||||||||||||||||||||
| 690 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 691 | }; | - | ||||||||||||||||||||||||
| 692 | - | |||||||||||||||||||||||||
| 693 | if (useCustomSrc
| 0-2 | ||||||||||||||||||||||||
| 694 | requiredProgram.srcPixelFragShader = QGLEngineSharedShaders::CustomImageSrcFragmentShader; | - | ||||||||||||||||||||||||
| 695 | requiredProgram.customStageSource = customSrcStage->source(); | - | ||||||||||||||||||||||||
| 696 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 697 | - | |||||||||||||||||||||||||
| 698 | const bool hasCompose = compositionMode > QPainter::CompositionMode_Plus; | - | ||||||||||||||||||||||||
| 699 | const bool hasMask = maskType != QGLEngineShaderManager::NoMask; | - | ||||||||||||||||||||||||
| 700 | - | |||||||||||||||||||||||||
| 701 | - | |||||||||||||||||||||||||
| 702 | if (opacityMode == AttributeOpacity
| 0-2 | ||||||||||||||||||||||||
| 703 | ((!(!hasCompose && !hasMask)) ? qt_assert("!hasCompose && !hasMask",__FILE__,742) : qt_noop()); | - | ||||||||||||||||||||||||
| 704 | requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_ImageArrays; | - | ||||||||||||||||||||||||
| 705 | } never executed: else {end of block | 0 | ||||||||||||||||||||||||
| 706 | bool useGlobalOpacity = (opacityMode == UniformOpacity); | - | ||||||||||||||||||||||||
| 707 | if (hasCompose
| 0-2 | ||||||||||||||||||||||||
| 708 | requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_CMO; never executed: requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_CMO; | 0 | ||||||||||||||||||||||||
| 709 | if (hasCompose
| 0-2 | ||||||||||||||||||||||||
| 710 | requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_CM; never executed: requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_CM; | 0 | ||||||||||||||||||||||||
| 711 | if (!hasCompose
| 0-2 | ||||||||||||||||||||||||
| 712 | requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_MO; never executed: requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_MO; | 0 | ||||||||||||||||||||||||
| 713 | if (!hasCompose
| 0-2 | ||||||||||||||||||||||||
| 714 | requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_M; never executed: requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_M; | 0 | ||||||||||||||||||||||||
| 715 | if (hasCompose
| 0-2 | ||||||||||||||||||||||||
| 716 | requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_CO; never executed: requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_CO; | 0 | ||||||||||||||||||||||||
| 717 | if (hasCompose
| 0-2 | ||||||||||||||||||||||||
| 718 | requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_C; never executed: requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_C; | 0 | ||||||||||||||||||||||||
| 719 | if (!hasCompose
| 0-2 | ||||||||||||||||||||||||
| 720 | requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_O; never executed: requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader_O; | 0 | ||||||||||||||||||||||||
| 721 | if (!hasCompose
| 0-2 | ||||||||||||||||||||||||
| 722 | requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader; executed 2 times by 1 test: requiredProgram.mainFragShader = QGLEngineSharedShaders::MainFragmentShader;Executed by:
| 2 | ||||||||||||||||||||||||
| 723 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 724 | - | |||||||||||||||||||||||||
| 725 | if (hasMask
| 0-2 | ||||||||||||||||||||||||
| 726 | if (maskType == PixelMask
| 0 | ||||||||||||||||||||||||
| 727 | requiredProgram.maskFragShader = QGLEngineSharedShaders::MaskFragmentShader; | - | ||||||||||||||||||||||||
| 728 | texCoords = true; | - | ||||||||||||||||||||||||
| 729 | } never executed: else if (maskType == SubPixelMaskPass1end of block
| 0 | ||||||||||||||||||||||||
| 730 | requiredProgram.maskFragShader = QGLEngineSharedShaders::RgbMaskFragmentShaderPass1; | - | ||||||||||||||||||||||||
| 731 | texCoords = true; | - | ||||||||||||||||||||||||
| 732 | } never executed: else if (maskType == SubPixelMaskPass2end of block
| 0 | ||||||||||||||||||||||||
| 733 | requiredProgram.maskFragShader = QGLEngineSharedShaders::RgbMaskFragmentShaderPass2; | - | ||||||||||||||||||||||||
| 734 | texCoords = true; | - | ||||||||||||||||||||||||
| 735 | } never executed: else if (maskType == SubPixelWithGammaMaskend of block
| 0 | ||||||||||||||||||||||||
| 736 | requiredProgram.maskFragShader = QGLEngineSharedShaders::RgbMaskWithGammaFragmentShader; | - | ||||||||||||||||||||||||
| 737 | texCoords = true; | - | ||||||||||||||||||||||||
| 738 | } never executed: else {end of block | 0 | ||||||||||||||||||||||||
| 739 | QMessageLogger(__FILE__, 778, __PRETTY_FUNCTION__).critical("QGLEngineShaderManager::useCorrectShaderProg() - Unknown mask type"); | - | ||||||||||||||||||||||||
| 740 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 741 | } else { | - | ||||||||||||||||||||||||
| 742 | requiredProgram.maskFragShader = QGLEngineSharedShaders::NoMaskFragmentShader; | - | ||||||||||||||||||||||||
| 743 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 744 | - | |||||||||||||||||||||||||
| 745 | if (hasCompose
| 0-2 | ||||||||||||||||||||||||
| 746 | switch (compositionMode) { | - | ||||||||||||||||||||||||
| 747 | case never executed: QPainter::CompositionMode_Multiply:case QPainter::CompositionMode_Multiply:never executed: case QPainter::CompositionMode_Multiply: | 0 | ||||||||||||||||||||||||
| 748 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::MultiplyCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 749 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 750 | case never executed: QPainter::CompositionMode_Screen:case QPainter::CompositionMode_Screen:never executed: case QPainter::CompositionMode_Screen: | 0 | ||||||||||||||||||||||||
| 751 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::ScreenCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 752 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 753 | case never executed: QPainter::CompositionMode_Overlay:case QPainter::CompositionMode_Overlay:never executed: case QPainter::CompositionMode_Overlay: | 0 | ||||||||||||||||||||||||
| 754 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::OverlayCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 755 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 756 | case never executed: QPainter::CompositionMode_Darken:case QPainter::CompositionMode_Darken:never executed: case QPainter::CompositionMode_Darken: | 0 | ||||||||||||||||||||||||
| 757 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::DarkenCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 758 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 759 | case never executed: QPainter::CompositionMode_Lighten:case QPainter::CompositionMode_Lighten:never executed: case QPainter::CompositionMode_Lighten: | 0 | ||||||||||||||||||||||||
| 760 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::LightenCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 761 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 762 | case never executed: QPainter::CompositionMode_ColorDodge:case QPainter::CompositionMode_ColorDodge:never executed: case QPainter::CompositionMode_ColorDodge: | 0 | ||||||||||||||||||||||||
| 763 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::ColorDodgeCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 764 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 765 | case never executed: QPainter::CompositionMode_ColorBurn:case QPainter::CompositionMode_ColorBurn:never executed: case QPainter::CompositionMode_ColorBurn: | 0 | ||||||||||||||||||||||||
| 766 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::ColorBurnCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 767 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 768 | case never executed: QPainter::CompositionMode_HardLight:case QPainter::CompositionMode_HardLight:never executed: case QPainter::CompositionMode_HardLight: | 0 | ||||||||||||||||||||||||
| 769 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::HardLightCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 770 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 771 | case never executed: QPainter::CompositionMode_SoftLight:case QPainter::CompositionMode_SoftLight:never executed: case QPainter::CompositionMode_SoftLight: | 0 | ||||||||||||||||||||||||
| 772 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::SoftLightCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 773 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 774 | case never executed: QPainter::CompositionMode_Difference:case QPainter::CompositionMode_Difference:never executed: case QPainter::CompositionMode_Difference: | 0 | ||||||||||||||||||||||||
| 775 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::DifferenceCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 776 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 777 | case never executed: QPainter::CompositionMode_Exclusion:case QPainter::CompositionMode_Exclusion:never executed: case QPainter::CompositionMode_Exclusion: | 0 | ||||||||||||||||||||||||
| 778 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::ExclusionCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 779 | break; never executed: break; | 0 | ||||||||||||||||||||||||
| 780 | default never executed: :default:never executed: default: | 0 | ||||||||||||||||||||||||
| 781 | QMessageLogger(__FILE__, 820, __PRETTY_FUNCTION__).warning("QGLEngineShaderManager::useCorrectShaderProg() - Unsupported composition mode"); | - | ||||||||||||||||||||||||
| 782 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 783 | } else { | - | ||||||||||||||||||||||||
| 784 | requiredProgram.compositionFragShader = QGLEngineSharedShaders::NoCompositionModeFragmentShader; | - | ||||||||||||||||||||||||
| 785 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 786 | - | |||||||||||||||||||||||||
| 787 | - | |||||||||||||||||||||||||
| 788 | if (opacityMode == AttributeOpacity
| 0-2 | ||||||||||||||||||||||||
| 789 | ((!(texCoords)) ? qt_assert("texCoords",__FILE__,828) : qt_noop()); | - | ||||||||||||||||||||||||
| 790 | requiredProgram.mainVertexShader = QGLEngineSharedShaders::MainWithTexCoordsAndOpacityVertexShader; | - | ||||||||||||||||||||||||
| 791 | } never executed: else if (texCoordsend of block
| 0-2 | ||||||||||||||||||||||||
| 792 | requiredProgram.mainVertexShader = QGLEngineSharedShaders::MainWithTexCoordsVertexShader; | - | ||||||||||||||||||||||||
| 793 | } never executed: else {end of block | 0 | ||||||||||||||||||||||||
| 794 | requiredProgram.mainVertexShader = QGLEngineSharedShaders::MainVertexShader; | - | ||||||||||||||||||||||||
| 795 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 796 | requiredProgram.useTextureCoords = texCoords; | - | ||||||||||||||||||||||||
| 797 | requiredProgram.useOpacityAttribute = (opacityMode == AttributeOpacity); | - | ||||||||||||||||||||||||
| 798 | if (complexGeometry
| 0-2 | ||||||||||||||||||||||||
| 799 | requiredProgram.positionVertexShader = QGLEngineSharedShaders::ComplexGeometryPositionOnlyVertexShader; | - | ||||||||||||||||||||||||
| 800 | requiredProgram.usePmvMatrixAttribute = false; | - | ||||||||||||||||||||||||
| 801 | } never executed: else {end of block | 0 | ||||||||||||||||||||||||
| 802 | requiredProgram.usePmvMatrixAttribute = true; | - | ||||||||||||||||||||||||
| 803 | - | |||||||||||||||||||||||||
| 804 | - | |||||||||||||||||||||||||
| 805 | - | |||||||||||||||||||||||||
| 806 | complexGeometry = false; | - | ||||||||||||||||||||||||
| 807 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 808 | - | |||||||||||||||||||||||||
| 809 | - | |||||||||||||||||||||||||
| 810 | currentShaderProg = sharedShaders->findProgramInCache(requiredProgram); | - | ||||||||||||||||||||||||
| 811 | - | |||||||||||||||||||||||||
| 812 | if (currentShaderProg
| 0-2 | ||||||||||||||||||||||||
| 813 | customSrcStage->setUniforms(currentShaderProg->program); | - | ||||||||||||||||||||||||
| 814 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 815 | - | |||||||||||||||||||||||||
| 816 | - | |||||||||||||||||||||||||
| 817 | - | |||||||||||||||||||||||||
| 818 | QGLContextPrivate* ctx_d = ctx->d_func(); | - | ||||||||||||||||||||||||
| 819 | ctx_d->setVertexAttribArrayEnabled(QT_VERTEX_COORDS_ATTR, true); | - | ||||||||||||||||||||||||
| 820 | ctx_d->setVertexAttribArrayEnabled(QT_TEXTURE_COORDS_ATTR, currentShaderProg && currentShaderProg->useTextureCoords); | - | ||||||||||||||||||||||||
| 821 | ctx_d->setVertexAttribArrayEnabled(QT_OPACITY_ATTR, currentShaderProg && currentShaderProg->useOpacityAttribute); | - | ||||||||||||||||||||||||
| 822 | - | |||||||||||||||||||||||||
| 823 | shaderProgNeedsChanging = false; | - | ||||||||||||||||||||||||
| 824 | return executed 2 times by 1 test: true;return true;Executed by:
executed 2 times by 1 test: return true;Executed by:
| 2 | ||||||||||||||||||||||||
| 825 | } | - | ||||||||||||||||||||||||
| 826 | - | |||||||||||||||||||||||||
| 827 | - | |||||||||||||||||||||||||
| Switch to Source code | Preprocessed file |