Changeset 65330 in webkit
- Timestamp:
- Aug 13, 2010, 10:12:19 AM (15 years ago)
- Location:
- trunk
- Files:
- 
      - 9 edited
 
 - 
          
  LayoutTests/ChangeLog (modified) (1 diff)
- 
          
  LayoutTests/fast/canvas/webgl/program-test-expected.txt (modified) (2 diffs)
- 
          
  LayoutTests/fast/canvas/webgl/program-test.html (modified) (8 diffs)
- 
          
  WebCore/ChangeLog (modified) (1 diff)
- 
          
  WebCore/html/canvas/WebGLObject.cpp (modified) (4 diffs)
- 
          
  WebCore/html/canvas/WebGLObject.h (modified) (3 diffs)
- 
          
  WebCore/html/canvas/WebGLProgram.cpp (modified) (2 diffs)
- 
          
  WebCore/html/canvas/WebGLProgram.h (modified) (3 diffs)
- 
          
  WebCore/html/canvas/WebGLRenderingContext.cpp (modified) (6 diffs)
 
Legend:
- Unmodified
- Added
- Removed
- 
      trunk/LayoutTests/ChangeLogr65329 r65330 1 2010-08-11 Zhenyao Mo <zmo@google.com> 2 3 Reviewed by Dimitri Glazkov. 4 5 Regression in linking of programs 6 https://bugs.webkit.org/show_bug.cgi?id=43820 7 8 * fast/canvas/webgl/program-test-expected.txt: Fix the tests so a second shader of the same type attaching to a program will generate error; also, add tests for deleteShader/deleteProgram behavior. 9 * fast/canvas/webgl/program-test.html: Ditto. 10 1 11 2010-08-13 Steve Block <steveblock@google.com> 2 12 
- 
      trunk/LayoutTests/fast/canvas/webgl/program-test-expected.txtr62396 r65330 13 13 PASS good fragment shader #2 should compile 14 14 PASS bad fragment shader should fail to compile 15 PASS should be no errors at this point 16 PASS attaching a vertex shader should succeed 17 PASS attaching an already attached vertex shader should generate INVALID_OPERATION 18 PASS attaching a fragment shader should succeed 19 PASS attaching an already attached fragment shader should generate INVALID_OPERATION 20 PASS detaching a vertex shader should succeed 21 PASS detaching a not already attached vertex shader should generate INVALID_OPERATION 22 PASS detaching a fragment shader should succeed 23 PASS detaching a not already attached fragment shader should generate INVALID_OPERATION 15 PASS getError was expected value: NO_ERROR : should be no errors at this point 16 PASS getError was expected value: NO_ERROR : attaching a vertex shader should succeed 17 PASS getError was expected value: INVALID_OPERATION : attaching an already attached vertex shader should generate INVALID_OPERATION 18 PASS getError was expected value: NO_ERROR : attaching a fragment shader should succeed 19 PASS getError was expected value: INVALID_OPERATION : attaching an already attached fragment shader should generate INVALID_OPERATION 20 PASS getError was expected value: INVALID_OPERATION : attaching shaders of the same type to a program should generate INVALID_OPERATION 21 PASS getError was expected value: INVALID_OPERATION : attaching shaders of the same type to a program should generate INVALID_OPERATION 22 PASS getError was expected value: NO_ERROR : detaching a vertex shader should succeed 23 PASS getError was expected value: INVALID_OPERATION : detaching a not already attached vertex shader should generate INVALID_OPERATION 24 PASS getError was expected value: NO_ERROR : detaching a fragment shader should succeed 25 PASS getError was expected value: INVALID_OPERATION : detaching a not already attached fragment shader should generate INVALID_OPERATION 24 26 PASS getAttachedShaders should return an empty list by default 25 27 PASS attaching a single shader should give the expected list … … 33 35 PASS attaching shaders, including one that failed to compile, should still show the it in the list 34 36 PASS valid program should link 35 PASS using a valid program should succeed37 PASS getError was expected value: NO_ERROR : using a valid program should succeed 36 38 PASS valid program #2 should link 37 PASS using a valid program should succeed39 PASS getError was expected value: NO_ERROR : using a valid program should succeed 38 40 PASS program with no fragment shader should fail to link 39 PASS using an invalid program should generate INVALID_OPERATION41 PASS getError was expected value: INVALID_OPERATION : using an invalid program should generate INVALID_OPERATION 40 42 PASS program with no vertex shader should fail to link 41 PASS using an invalid program should generate INVALID_OPERATION43 PASS getError was expected value: INVALID_OPERATION : using an invalid program should generate INVALID_OPERATION 42 44 PASS program with bad vertex shader should fail to link 43 PASS using an invalid program should generate INVALID_OPERATION45 PASS getError was expected value: INVALID_OPERATION : using an invalid program should generate INVALID_OPERATION 44 46 PASS program with bad fragment shader should fail to link 45 PASS using an invalid program should generate INVALID_OPERATION47 PASS getError was expected value: INVALID_OPERATION : using an invalid program should generate INVALID_OPERATION 46 48 PASS program with bad shaders should fail to link 47 PASS using an invalid program should generate INVALID_OPERATION 48 PASS using a valid program shouldn't generate a GL error 49 PASS should be no errors at this point #2 50 PASS drawing with a valid program shouldn't generate a GL error 51 PASS using an invalid program should generate INVALID_OPERATION 52 PASS drawing with an invalid program should generate some GL error XXX 49 PASS getError was expected value: INVALID_OPERATION : using an invalid program should generate INVALID_OPERATION 50 PASS getError was expected value: NO_ERROR : using a valid program shouldn't generate a GL error 51 PASS getError was expected value: NO_ERROR : should be no errors at this point #2 52 PASS getError was expected value: NO_ERROR : drawing with a valid program shouldn't generate a GL error 53 PASS getError was expected value: INVALID_OPERATION : using an invalid program should generate INVALID_OPERATION 54 PASS getError was expected value: NO_ERROR : Try to use an invalid program should not change the current rendering state 55 PASS getError was expected value: NO_ERROR : drawing with a valid program shouldn't generate a GL error 53 56 PASS linking should fail with in-use formerly good program, with new bad shader attached 54 PASS drawing with a valid when last used program shouldn't generate a GL error 57 PASS getError was expected value: NO_ERROR : drawing with a valid when last used program shouldn't generate a GL error 58 PASS delete shaders after attaching them and before linking program should not affect linkProgram 59 PASS getError was expected value: NO_ERROR : using a valid program should succeed 60 PASS getError was expected value: NO_ERROR : drawing with a valid when last used program shouldn't generate a GL error 61 PASS getError was expected value: NO_ERROR : delete the current program shouldn't change the current rendering state 62 PASS getError was expected value: NO_ERROR : The current program shouldn't be deleted 63 PASS good fragment shader should compile 64 PASS getError was expected value: INVALID_VALUE : an unattached shader should be deleted immediately 65 PASS good fragment shader should compile 66 PASS an attached shader shouldn't be deleted 67 PASS getError was expected value: INVALID_VALUE : a delete-marked program should be deleted once it's no longer the current program 68 PASS getError was expected value: INVALID_VALUE : a delete-marked shader should be deleted once all its attachments are removed 55 69 PASS successfullyParsed is true 56 70 
- 
      trunk/LayoutTests/fast/canvas/webgl/program-test.htmlr62396 r65330 76 76 "bad fragment shader should fail to compile"); 77 77 78 assertMsg(gl.getError() == gl.NO_ERROR, 79 "should be no errors at this point"); 78 glErrorShouldBe(gl, gl.NO_ERROR, "should be no errors at this point"); 80 79 81 80 /////// Check attachShader() ///////////////////////////// … … 88 87 assertMsg(false, "unexpected error in attachShader()"); 89 88 gl.attachShader(prog, shader); 90 assertMsg(gl.getError() ==expected_error_code, errmsg);89 glErrorShouldBe(gl, expected_error_code, errmsg); 91 90 } 92 91 … … 97 96 checkAttachShader([fs], fs, gl.INVALID_OPERATION, 98 97 "attaching an already attached fragment shader should generate INVALID_OPERATION"); 98 checkAttachShader([vs], vs2, gl.INVALID_OPERATION, 99 "attaching shaders of the same type to a program should generate INVALID_OPERATION"); 100 checkAttachShader([fs], fs2, gl.INVALID_OPERATION, 101 "attaching shaders of the same type to a program should generate INVALID_OPERATION"); 99 102 100 103 /////// Check detachShader() ///////////////////////////// … … 107 110 assertMsg(false, "unexpected error in attachShader()"); 108 111 gl.detachShader(prog, shader); 109 assertMsg(gl.getError() ==expected_error_code, errmsg);112 glErrorShouldBe(gl, expected_error_code, errmsg); 110 113 } 111 114 … … 133 136 checkGetAttachedShaders([], [], [], "getAttachedShaders should return an empty list by default"); 134 137 checkGetAttachedShaders([fs], [], [fs], "attaching a single shader should give the expected list"); 135 checkGetAttachedShaders([fs, vs , fs2, vs2], [], [fs, vs, fs2, vs2],138 checkGetAttachedShaders([fs, vs], [], [fs, vs], 136 139 "attaching some shaders should give the expected list"); 137 140 checkGetAttachedShaders([fs], [fs], [], "attaching a shader and detaching it shoud leave an empty list"); 138 checkGetAttachedShaders([fs, vs , fs2, vs2], [fs, vs, fs2, vs2], [],141 checkGetAttachedShaders([fs, vs], [fs, vs], [], 139 142 "attaching some shaders and detaching them in same order shoud leave an empty list"); 140 checkGetAttachedShaders([fs, vs , fs2, vs2], [fs, vs2, vs, fs2], [],143 checkGetAttachedShaders([fs, vs], [vs, fs], [], 141 144 "attaching some shaders and detaching them in random order shoud leave an empty list"); 142 checkGetAttachedShaders([fs, vs , fs2, vs2], [vs], [fs, fs2, vs2],145 checkGetAttachedShaders([fs, vs], [vs], [fs], 143 146 "attaching and detaching some shaders should leave the difference list"); 144 checkGetAttachedShaders([fs, vs , fs2, vs2], [fs, vs2], [vs, fs2],147 checkGetAttachedShaders([fs, vs], [fs], [vs], 145 148 "attaching and detaching some shaders should leave the difference list"); 146 149 checkGetAttachedShaders([fsBad], [], [fsBad], 147 150 "attaching a shader that failed to compile should still show it in the list"); 148 checkGetAttachedShaders([fs, vsBad , fs2], [], [fs, vsBad, fs2],151 checkGetAttachedShaders([fs, vsBad], [], [fs, vsBad], 149 152 "attaching shaders, including one that failed to compile, should still show the it in the list"); 150 153 151 154 /////// Check linkProgram() and useProgram ///////////////////////////// 152 155 153 function checkLinkAndUse(shaders, expected_status, errmsg) {154 var prog = gl.createProgram(); 155 for (var i = 0; i < shaders.length; ++i) 156 function checkLinkAndUse(shaders, deleteShaderAfterAttach, expected_status, errmsg) { 157 var prog = gl.createProgram(); 158 for (var i = 0; i < shaders.length; ++i) { 156 159 gl.attachShader(prog, shaders[i]); 160 if (deleteShaderAfterAttach) 161 gl.deleteShader(shaders[i]); 162 } 157 163 gl.bindAttribLocation(prog, 0, "aVertex"); 158 164 gl.bindAttribLocation(prog, 1, "aColor"); … … 167 173 gl.useProgram(prog); 168 174 if (expected_status == true) 169 assertMsg(gl.getError() ==gl.NO_ERROR, "using a valid program should succeed");175 glErrorShouldBe(gl, gl.NO_ERROR, "using a valid program should succeed"); 170 176 if (expected_status == false) 171 assertMsg(gl.getError() ==gl.INVALID_OPERATION, "using an invalid program should generate INVALID_OPERATION");177 glErrorShouldBe(gl, gl.INVALID_OPERATION, "using an invalid program should generate INVALID_OPERATION"); 172 178 return prog; 173 179 } 174 180 175 var progGood1 = checkLinkAndUse([vs, fs], true, "valid program should link"); 176 var progGood2 = checkLinkAndUse([vs, fs2], true, "valid program #2 should link"); 177 var progBad1 = checkLinkAndUse([vs], false, "program with no fragment shader should fail to link"); 178 var progBad2 = checkLinkAndUse([fs], false, "program with no vertex shader should fail to link"); 179 var progBad3 = checkLinkAndUse([vsBad, fs], false, "program with bad vertex shader should fail to link"); 180 var progBad4 = checkLinkAndUse([vs, fsBad], false, "program with bad fragment shader should fail to link"); 181 var progBad5 = checkLinkAndUse([vsBad, fsBad], false, "program with bad shaders should fail to link"); 182 183 gl.useProgram(progGood1); 184 assertMsg(gl.getError() == gl.NO_ERROR, 185 "using a valid program shouldn't generate a GL error"); 181 var progGood1 = checkLinkAndUse([vs, fs], false, true, "valid program should link"); 182 var progGood2 = checkLinkAndUse([vs, fs2], false, true, "valid program #2 should link"); 183 var progBad1 = checkLinkAndUse([vs], false, false, "program with no fragment shader should fail to link"); 184 var progBad2 = checkLinkAndUse([fs], false, false, "program with no vertex shader should fail to link"); 185 var progBad3 = checkLinkAndUse([vsBad, fs], false, false, "program with bad vertex shader should fail to link"); 186 var progBad4 = checkLinkAndUse([vs, fsBad], false, false, "program with bad fragment shader should fail to link"); 187 var progBad5 = checkLinkAndUse([vsBad, fsBad], false, false, "program with bad shaders should fail to link"); 188 189 gl.useProgram(progGood1); 190 glErrorShouldBe(gl, gl.NO_ERROR, "using a valid program shouldn't generate a GL error"); 186 191 187 192 var vbuf = gl.createBuffer(); … … 198 203 gl.vertexAttrib3f(1, 1.0, 0.0, 0.0); 199 204 200 assertMsg(gl.getError() == gl.NO_ERROR, 201 "should be no errors at this point #2"); 205 glErrorShouldBe(gl, gl.NO_ERROR, "should be no errors at this point #2"); 202 206 203 207 gl.useProgram(progGood1); 204 208 gl.drawArrays(gl.TRIANGLES, 0, 3); 205 assertMsg(gl.getError() == gl.NO_ERROR, 206 "drawing with a valid program shouldn't generate a GL error"); 209 glErrorShouldBe(gl, gl.NO_ERROR, "drawing with a valid program shouldn't generate a GL error"); 207 210 208 211 gl.useProgram(progBad1); 209 assertMsg(gl.getError() == gl.INVALID_OPERATION, 210 "using an invalid program should generate INVALID_OPERATION"); 212 glErrorShouldBe(gl, gl.INVALID_OPERATION, "using an invalid program should generate INVALID_OPERATION"); 211 213 gl.drawArrays(gl.TRIANGLES, 0, 3); 212 assertMsg(gl.getError() != gl.NO_ERROR, 213 "drawing with an invalid program should generate some GL error XXX"); 214 glErrorShouldBe(gl, gl.NO_ERROR, "Try to use an invalid program should not change the current rendering state"); 214 215 215 216 gl.useProgram(progGood2); 217 gl.drawArrays(gl.TRIANGLES, 0, 3); 218 glErrorShouldBe(gl, gl.NO_ERROR, "drawing with a valid program shouldn't generate a GL error"); 219 gl.detachShader(progGood2, fs2); 216 220 gl.attachShader(progGood2, fsBad); 217 221 gl.linkProgram(progGood2); … … 221 225 gl.useProgram(progGood1); 222 226 gl.drawArrays(gl.TRIANGLES, 0, 4); 223 assertMsg(gl.getError() == gl.NO_ERROR, 224 "drawing with a valid when last used program shouldn't generate a GL error"); 227 glErrorShouldBe(gl, gl.NO_ERROR, "drawing with a valid when last used program shouldn't generate a GL error"); 228 229 var progGood1 = checkLinkAndUse([vs, fs], true, true, "delete shaders after attaching them and before linking program should not affect linkProgram"); 230 gl.useProgram(progGood1); 231 gl.drawArrays(gl.TRIANGLES, 0, 4); 232 glErrorShouldBe(gl, gl.NO_ERROR, "drawing with a valid when last used program shouldn't generate a GL error"); 233 234 /////// Check deleteProgram() and deleteShader() ///////////////////////////// 235 236 gl.useProgram(progGood1); 237 gl.deleteProgram(progGood1); 238 gl.drawArrays(gl.TRIANGLES, 0, 4); 239 glErrorShouldBe(gl, gl.NO_ERROR, "delete the current program shouldn't change the current rendering state"); 240 241 gl.linkProgram(progGood1); 242 glErrorShouldBe(gl, gl.NO_ERROR, "The current program shouldn't be deleted"); 243 244 var fs3 = gl.createShader(gl.FRAGMENT_SHADER); 245 gl.shaderSource(fs3, "#ifdef GL_ES\nprecision mediump float;\n#endif\n varying vec4 vColor; void main() { gl_FragColor = vColor; }"); 246 gl.compileShader(fs3); 247 248 assertMsg(gl.getShaderParameter(fs3, gl.COMPILE_STATUS) == true, 249 "good fragment shader should compile"); 250 251 gl.deleteShader(fs3); 252 gl.compileShader(fs3); 253 glErrorShouldBe(gl, gl.INVALID_VALUE, "an unattached shader should be deleted immediately"); 254 255 fs3 = gl.createShader(gl.FRAGMENT_SHADER); 256 gl.shaderSource(fs3, "#ifdef GL_ES\nprecision mediump float;\n#endif\n varying vec4 vColor; void main() { gl_FragColor = vColor; }"); 257 gl.compileShader(fs3); 258 259 assertMsg(gl.getShaderParameter(fs3, gl.COMPILE_STATUS) == true, 260 "good fragment shader should compile"); 261 262 gl.detachShader(progGood1, fs); 263 gl.attachShader(progGood1, fs3); 264 265 gl.deleteShader(fs3); 266 gl.compileShader(fs3); 267 assertMsg(gl.getShaderParameter(fs3, gl.COMPILE_STATUS) == true, 268 "an attached shader shouldn't be deleted"); 269 270 gl.useProgram(null); 271 gl.linkProgram(progGood1); 272 glErrorShouldBe(gl, gl.INVALID_VALUE, "a delete-marked program should be deleted once it's no longer the current program"); 273 274 gl.compileShader(fs3); 275 glErrorShouldBe(gl, gl.INVALID_VALUE, "a delete-marked shader should be deleted once all its attachments are removed"); 225 276 } 226 277 227 278 debug(""); 279 go(); 280 228 281 successfullyParsed = true; 229 230 go();231 282 </script> 232 283 <script src="../../js/resources/js-test-post.js"></script> 
- 
      trunk/WebCore/ChangeLogr65329 r65330 1 2010-08-11 Zhenyao Mo <zmo@google.com> 2 3 Reviewed by Dimitri Glazkov. 4 5 Regression in linking of programs 6 https://bugs.webkit.org/show_bug.cgi?id=43820 7 8 Shaders and programs shouldn't be deleted until their attachments are removed, therefore, we need to track the attach/detach/useProgram. 9 10 * html/canvas/WebGLObject.cpp: Track the object attachment count and whether it should really be deleted. 11 (WebCore::WebGLObject::WebGLObject): 12 (WebCore::WebGLObject::setObject): 13 (WebCore::WebGLObject::deleteObject): 14 * html/canvas/WebGLObject.h: Track the object attachment count and whether it should really be deleted. 15 (WebCore::WebGLObject::onAttached): 16 (WebCore::WebGLObject::onDetached): 17 (WebCore::WebGLObject::getAttachmentCount): 18 * html/canvas/WebGLProgram.cpp: Track the attached shaders. 19 (WebCore::WebGLProgram::WebGLProgram): 20 (WebCore::WebGLProgram::deleteObjectImpl): 21 (WebCore::WebGLProgram::getAttachedShader): 22 (WebCore::WebGLProgram::attachShader): 23 (WebCore::WebGLProgram::detachShader): 24 * html/canvas/WebGLProgram.h: Track the attached shaders. 25 * html/canvas/WebGLRenderingContext.cpp: 26 (WebCore::WebGLRenderingContext::attachShader): Track the attachment of a shader to a program. 27 (WebCore::WebGLRenderingContext::deleteProgram): Detach shaders. 28 (WebCore::WebGLRenderingContext::detachShader): Track the attachment of a shader to a program. 29 (WebCore::WebGLRenderingContext::validateWebGLObject): Also check if object == 0. 30 (WebCore::WebGLRenderingContext::linkProgram): Using the cached attached shaders instead of query from driver. 31 (WebCore::WebGLRenderingContext::useProgram): Track the attachment of a program to the current rendering pipeline. 32 1 33 2010-08-13 Steve Block <steveblock@google.com> 2 34 
- 
      trunk/WebCore/html/canvas/WebGLObject.cppr64767 r65330 36 36 WebGLObject::WebGLObject(WebGLRenderingContext* context) 37 37 : m_object(0) 38 , m_shouldDeleteObject(true)39 38 , m_context(context) 39 , m_attachmentCount(0) 40 , m_deleted(false) 40 41 { 41 42 } … … 47 48 } 48 49 49 void WebGLObject::setObject(Platform3DObject object , bool shouldDeleteObject)50 void WebGLObject::setObject(Platform3DObject object) 50 51 { 51 52 if (object == m_object) … … 54 55 deleteObject(); 55 56 m_object = object; 56 m_shouldDeleteObject = shouldDeleteObject;57 57 } 58 58 … … 60 60 { 61 61 if (m_object) { 62 if (m_shouldDeleteObject) 63 if (m_context) { 64 m_context->graphicsContext3D()->makeContextCurrent(); 65 deleteObjectImpl(m_object); 66 } 67 m_object = 0; 62 if (m_context) { 63 m_context->graphicsContext3D()->makeContextCurrent(); 64 deleteObjectImpl(m_object); 65 } 66 if (!m_attachmentCount) 67 m_object = 0; 68 m_deleted = true; 68 69 } 69 m_shouldDeleteObject = true;70 70 } 71 71 
- 
      trunk/WebCore/html/canvas/WebGLObject.hr64767 r65330 41 41 42 42 Platform3DObject object() const { return m_object; } 43 void setObject(Platform3DObject , bool shouldDeleteObject = true);43 void setObject(Platform3DObject); 44 44 void deleteObject(); 45 45 … … 59 59 virtual bool isTexture() const { return false; } 60 60 61 void onAttached() { ++m_attachmentCount; } 62 void onDetached() 63 { 64 if (m_attachmentCount) 65 --m_attachmentCount; 66 if (!m_attachmentCount && m_deleted) 67 m_object = 0; 68 } 69 unsigned getAttachmentCount() { return m_attachmentCount; } 70 61 71 protected: 62 72 WebGLObject(WebGLRenderingContext*); … … 65 75 private: 66 76 Platform3DObject m_object; 67 // The shouldDeleteObject flag indicates whether this wrapper68 // owns the underlying resource and should delete it when the69 // wrapper is unreferenced for the last time and deleted. It70 // is only set to false for certain objects returned from get71 // queries. FIXME: should consider canonicalizing all of these72 // objects in the future.73 bool m_shouldDeleteObject;74 77 WebGLRenderingContext* m_context; 78 unsigned m_attachmentCount; 79 bool m_deleted; 75 80 }; 76 81 
- 
      trunk/WebCore/html/canvas/WebGLProgram.cppr64767 r65330 46 46 } 47 47 48 void WebGLProgram::deleteObjectImpl(Platform3DObject obj ect)48 void WebGLProgram::deleteObjectImpl(Platform3DObject obj) 49 49 { 50 context()->graphicsContext3D()->deleteProgram(object); 50 context()->graphicsContext3D()->deleteProgram(obj); 51 if (!object()) { 52 if (m_vertexShader) 53 m_vertexShader->onDetached(); 54 if (m_fragmentShader) 55 m_fragmentShader->onDetached(); 56 } 51 57 } 52 58 … … 95 101 } 96 102 103 WebGLShader* WebGLProgram::getAttachedShader(GraphicsContext3D::WebGLEnumType type) 104 { 105 switch (type) { 106 case GraphicsContext3D::VERTEX_SHADER: 107 return m_vertexShader.get(); 108 case GraphicsContext3D::FRAGMENT_SHADER: 109 return m_fragmentShader.get(); 110 default: 111 return 0; 112 } 113 } 114 115 bool WebGLProgram::attachShader(WebGLShader* shader) 116 { 117 if (!shader || !shader->object()) 118 return false; 119 switch (shader->getType()) { 120 case GraphicsContext3D::VERTEX_SHADER: 121 if (m_vertexShader) 122 return false; 123 m_vertexShader = shader; 124 return true; 125 case GraphicsContext3D::FRAGMENT_SHADER: 126 if (m_fragmentShader) 127 return false; 128 m_fragmentShader = shader; 129 return true; 130 default: 131 return false; 132 } 133 } 134 135 bool WebGLProgram::detachShader(WebGLShader* shader) 136 { 137 if (!shader || !shader->object()) 138 return false; 139 switch (shader->getType()) { 140 case GraphicsContext3D::VERTEX_SHADER: 141 if (m_vertexShader != shader) 142 return false; 143 m_vertexShader = 0; 144 return true; 145 case GraphicsContext3D::FRAGMENT_SHADER: 146 if (m_fragmentShader != shader) 147 return false; 148 m_fragmentShader = 0; 149 return true; 150 default: 151 return false; 152 } 153 } 154 97 155 } 98 156 
- 
      trunk/WebCore/html/canvas/WebGLProgram.hr64767 r65330 29 29 #include "WebGLObject.h" 30 30 31 #include "WebGLShader.h" 32 31 33 #include <wtf/PassRefPtr.h> 32 34 #include <wtf/RefCounted.h> … … 55 57 void setLinkFailureFlag(bool failed) { m_linkFailure = failed; } 56 58 59 WebGLShader* getAttachedShader(GraphicsContext3D::WebGLEnumType); 60 bool attachShader(WebGLShader*); 61 bool detachShader(WebGLShader*); 62 57 63 protected: 58 64 WebGLProgram(WebGLRenderingContext*); … … 66 72 67 73 bool m_linkFailure; 74 75 RefPtr<WebGLShader> m_vertexShader; 76 RefPtr<WebGLShader> m_fragmentShader; 68 77 }; 69 78 
- 
      trunk/WebCore/html/canvas/WebGLRenderingContext.cppr65279 r65330 218 218 if (!validateWebGLObject(program) || !validateWebGLObject(shader)) 219 219 return; 220 if (!program->attachShader(shader)) { 221 m_context->synthesizeGLError(GraphicsContext3D::INVALID_OPERATION); 222 return; 223 } 220 224 m_context->attachShader(objectOrZero(program), objectOrZero(shader)); 225 shader->onAttached(); 221 226 cleanupAfterGraphicsCall(false); 222 227 } … … 651 656 if (!program) 652 657 return; 653 658 if (program->context() != this) { 659 m_context->synthesizeGLError(GraphicsContext3D::INVALID_OPERATION); 660 return; 661 } 662 if (!program->object()) 663 return; 654 664 program->deleteObject(); 655 665 } … … 706 716 if (!validateWebGLObject(program) || !validateWebGLObject(shader)) 707 717 return; 718 if (!program->detachShader(shader)) { 719 m_context->synthesizeGLError(GraphicsContext3D::INVALID_OPERATION); 720 return; 721 } 708 722 m_context->detachShader(objectOrZero(program), objectOrZero(shader)); 723 shader->onDetached(); 709 724 cleanupAfterGraphicsCall(false); 710 725 } … … 893 908 bool WebGLRenderingContext::validateWebGLObject(WebGLObject* object) 894 909 { 895 if (!object ) {910 if (!object || !object->object()) { 896 911 m_context->synthesizeGLError(GraphicsContext3D::INVALID_VALUE); 897 912 return false; … … 1883 1898 return; 1884 1899 if (!isGLES2Compliant()) { 1885 Vector<WebGLShader*> shaders; 1886 bool succeed = getAttachedShaders(program, shaders, ec); 1887 if (succeed) { 1888 bool vShader = false; 1889 bool fShader = false; 1890 for (size_t ii = 0; ii < shaders.size() && (!vShader || !fShader); ++ii) { 1891 if (shaders[ii]->getType() == GraphicsContext3D::VERTEX_SHADER) 1892 vShader = true; 1893 else if (shaders[ii]->getType() == GraphicsContext3D::FRAGMENT_SHADER) 1894 fShader = true; 1895 } 1896 if (!vShader || !fShader) 1897 succeed = false; 1898 } 1899 if (!succeed) { 1900 if (!program->getAttachedShader(GraphicsContext3D::VERTEX_SHADER) || !program->getAttachedShader(GraphicsContext3D::FRAGMENT_SHADER)) { 1900 1901 program->setLinkFailureFlag(true); 1901 1902 return; … … 2702 2703 void WebGLRenderingContext::useProgram(WebGLProgram* program, ExceptionCode& ec) 2703 2704 { 2704 UNUSED_PARAM(ec);2705 2705 if (program && program->context() != this) { 2706 2706 m_context->synthesizeGLError(GraphicsContext3D::INVALID_OPERATION); 2707 2707 return; 2708 2708 } 2709 m_currentProgram = program; 2710 m_context->useProgram(objectOrZero(program)); 2709 if (program && program->object() && !getProgramParameter(program, GraphicsContext3D::LINK_STATUS, ec).getBool()) { 2710 m_context->synthesizeGLError(GraphicsContext3D::INVALID_OPERATION); 2711 cleanupAfterGraphicsCall(false); 2712 return; 2713 } 2714 if (m_currentProgram != program) { 2715 if (m_currentProgram) 2716 m_currentProgram->onDetached(); 2717 m_currentProgram = program; 2718 m_context->useProgram(objectOrZero(program)); 2719 if (program) 2720 program->onAttached(); 2721 } 2711 2722 cleanupAfterGraphicsCall(false); 2712 2723 } 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  
