diff options
-rw-r--r-- | src/webGLClient.js | 70 | ||||
-rw-r--r-- | src/webGLWorker.js | 128 |
2 files changed, 133 insertions, 65 deletions
diff --git a/src/webGLClient.js b/src/webGLClient.js index 82ffdf5c..1ae7332d 100644 --- a/src/webGLClient.js +++ b/src/webGLClient.js @@ -7,6 +7,74 @@ function assert(x) { function WebGLClient() { var objects = {}; + var calls = { + 0: { name: 'NULL' }, + 1: { name: 'getExtension' }, + 2: { name: 'enable' }, + 3: { name: 'disable' }, + 4: { name: 'clear' }, + 5: { name: 'clearColor' }, + 6: { name: 'createShader' }, + 7: { name: 'deleteShader' }, + 8: { name: 'shaderSource' }, + 9: { name: 'compileShader' }, + 10: { name: 'createProgram' }, + 11: { name: 'deleteProgram' }, + 12: { name: 'attachShader' }, + 13: { name: 'bindAttribLocation' }, + 14: { name: 'linkProgram' }, + 15: { name: 'getProgramParameter' }, + 16: { name: 'getUniformLocation' }, + 17: { name: 'useProgram' }, + 18: { name: 'uniform1i' }, + 19: { name: 'uniform1f' }, + 20: { name: 'uniform3fv' }, + 21: { name: 'uniform4fv' }, + 22: { name: 'uniformMatrix4fv' }, + 23: { name: 'vertexAttrib4fv' }, + 24: { name: 'createBuffer' }, + 25: { name: 'deleteBuffer' }, + 26: { name: 'bindBuffer' }, + 27: { name: 'bufferData' }, + 28: { name: 'bufferSubData' }, + 29: { name: 'viewport' }, + 30: { name: 'vertexAttribPointer' }, + 31: { name: 'enableVertexAttribArray' }, + 32: { name: 'disableVertexAttribArray' }, + 33: { name: 'drawArrays' }, + 34: { name: 'drawElements' }, + 35: { name: 'getError' }, + 36: { name: 'createTexture' }, + 37: { name: 'deleteTexture' }, + 38: { name: 'bindTexture' }, + 39: { name: 'texParameteri' }, + 40: { name: 'texImage2D' }, + 41: { name: 'compressedTexImage2D' }, + 42: { name: 'activeTexture' }, + 43: { name: 'getShaderParameter' }, + 44: { name: 'clearDepth' }, + 45: { name: 'depthFunc' }, + 46: { name: 'frontFace' }, + 47: { name: 'cullFace' }, + 48: { name: 'pixelStorei' }, + 49: { name: 'depthMask' }, + 50: { name: 'depthRange' }, + 51: { name: 'blendFunc' }, + 52: { name: 'scissor' }, + 53: { name: 'colorMask' }, + 54: { name: 'lineWidth' }, + 55: { name: 'createFramebuffer' }, + 56: { name: 'deleteFramebuffer' }, + 57: { name: 'bindFramebuffer' }, + 58: { name: 'framebufferTexture2D' }, + 59: { name: 'createRenderbuffer' }, + 60: { name: 'deleteRenderbuffer' }, + 61: { name: 'bindRenderbuffer' }, + 62: { name: 'renderbufferStorage' }, + 63: { name: 'framebufferRenderbuffer' }, + 64: { name: 'debugPrint' }, + }; + function fixArgs(command, args) { switch (command) { case 'deleteFramebuffer': @@ -50,7 +118,7 @@ function WebGLClient() { var len = buffer.length; //dump('issuing commands, buffer len: ' + len + '\n'); while (i < len) { - var command = buffer[i++]; + var command = calls[buffer[i++]].name; assert(typeof command === 'string') var numArgs = buffer[i++]; assert(typeof numArgs === 'number', command); diff --git a/src/webGLWorker.js b/src/webGLWorker.js index 6dae2b15..4ca28fa9 100644 --- a/src/webGLWorker.js +++ b/src/webGLWorker.js @@ -513,61 +513,61 @@ function WebGLWorker() { this.getExtension = function(name) { var i = this.prefetchedExtensions.indexOf(name); if (i < 0) return null; - commandBuffer.push('getExtension', 1, name); + commandBuffer.push(1, 1, name); return true; // TODO: return an object here }; this.getSupportedExtensions = function() { return this.prefetchedExtensions; }; this.enable = function(cap) { - commandBuffer.push('enable', 1, cap); + commandBuffer.push(2, 1, cap); }; this.disable = function(cap) { - commandBuffer.push('disable', 1, cap); + commandBuffer.push(3, 1, cap); }; this.clear = function(mask) { - commandBuffer.push('clear', 1, mask); + commandBuffer.push(4, 1, mask); }; this.clearColor = function(r, g, b, a) { - commandBuffer.push('clearColor', 4, r, g, b, a); + commandBuffer.push(5, 4, r, g, b, a); }; this.createShader = function(type) { var id = nextId++; - commandBuffer.push('createShader', -2, type, id); + commandBuffer.push(6, -2, type, id); return { id: id, what: 'shader', type: type }; }; this.deleteShader = function(shader) { if (!shader) return; - commandBuffer.push('deleteShader', 1, shader.id); + commandBuffer.push(7, 1, shader.id); }; this.shaderSource = function(shader, source) { shader.source = source; - commandBuffer.push('shaderSource', 2, shader.id, source); + commandBuffer.push(8, 2, shader.id, source); }; this.compileShader = function(shader) { - commandBuffer.push('compileShader', 1, shader.id); + commandBuffer.push(9, 1, shader.id); }; this.getShaderInfoLog = function(shader) { return ''; // optimistic assumption of success; no proxying }; this.createProgram = function() { var id = nextId++; - commandBuffer.push('createProgram', -1, id); + commandBuffer.push(10, -1, id); return new WebGLProgram(id); }; this.deleteProgram = function(program) { if (!program) return; - commandBuffer.push('deleteProgram', 1, program.id); + commandBuffer.push(11, 1, program.id); }; this.attachShader = function(program, shader) { program.shaders.push(shader); - commandBuffer.push('attachShader', 2, program.id, shader.id); + commandBuffer.push(12, 2, program.id, shader.id); }; this.bindAttribLocation = function(program, index, name) { program.attributes[name] = { what: 'attribute', name: name, size: -1, location: index }; // fill in size later program.attributeVec[index] = name; - commandBuffer.push('bindAttribLocation', 3, program.id, index, name); + commandBuffer.push(13, 3, program.id, index, name); }; this.getAttribLocation = function(program, name) { // all existing attribs are cached locally @@ -621,7 +621,7 @@ function WebGLWorker() { program.attributes[attr].size = existingAttributes[attr].size; } - commandBuffer.push('linkProgram', 1, program.id); + commandBuffer.push(14, 1, program.id); }; this.getProgramParameter = function(program, name) { switch (name) { @@ -629,7 +629,7 @@ function WebGLWorker() { case this.ACTIVE_ATTRIBUTES: return program.attributeVec.length; case this.LINK_STATUS: { // optimisticaly return success; client will abort on an actual error. we assume an error-free async workflow - commandBuffer.push('getProgramParameter', 2, program.id, name); + commandBuffer.push(15, 2, program.id, name); return true; } default: throw 'bad getProgramParameter ' + revname(name); @@ -656,50 +656,50 @@ function WebGLWorker() { } if (!(name in program.uniforms)) return null; var id = nextId++; - commandBuffer.push('getUniformLocation', -3, program.id, fullname, id); + commandBuffer.push(16, -3, program.id, fullname, id); return { what: 'location', uniform: program.uniforms[name], id: id, index: index }; }; this.getProgramInfoLog = function(shader) { return ''; // optimistic assumption of success; no proxying }; this.useProgram = function(program) { - commandBuffer.push('useProgram', 1, program ? program.id : 0); + commandBuffer.push(17, 1, program ? program.id : 0); bindings.program = program; }; this.uniform1i = function(location, data) { if (!location) return; - commandBuffer.push('uniform1i', 2, location.id, data); + commandBuffer.push(18, 2, location.id, data); }; this.uniform1f = function(location, data) { if (!location) return; - commandBuffer.push('uniform1f', 2, location.id, data); + commandBuffer.push(19, 2, location.id, data); }; this.uniform3fv = function(location, data) { if (!location) return; - commandBuffer.push('uniform3fv', 2, location.id, new Float32Array(data)); + commandBuffer.push(20, 2, location.id, new Float32Array(data)); }; this.uniform4fv = function(location, data) { if (!location) return; - commandBuffer.push('uniform4fv', 2, location.id, new Float32Array(data)); + commandBuffer.push(21, 2, location.id, new Float32Array(data)); }; this.uniformMatrix4fv = function(location, transpose, data) { if (!location) return; - commandBuffer.push('uniformMatrix4fv', 3, location.id, transpose, new Float32Array(data)); + commandBuffer.push(22, 3, location.id, transpose, new Float32Array(data)); }; this.vertexAttrib4fv = function(index, values) { - commandBuffer.push('vertexAttrib4fv', 2, index, new Float32Array(values)); + commandBuffer.push(23, 2, index, new Float32Array(values)); }; this.createBuffer = function() { var id = nextId++; - commandBuffer.push('createBuffer', -1, id); + commandBuffer.push(24, -1, id); return new WebGLBuffer(id); }; this.deleteBuffer = function(buffer) { if (!buffer) return; - commandBuffer.push('deleteBuffer', 1, buffer.id); + commandBuffer.push(25, 1, buffer.id); }; this.bindBuffer = function(target, buffer) { - commandBuffer.push('bindBuffer', 2, target, buffer ? buffer.id : 0); + commandBuffer.push(26, 2, target, buffer ? buffer.id : 0); switch (target) { case this.ARRAY_BUFFER_BINDING: { bindings.arrayBuffer = buffer; @@ -713,43 +713,43 @@ function WebGLWorker() { }; this.bufferData = function(target, something, usage) { if (typeof something !== 'number') something = new something.constructor(something); - commandBuffer.push('bufferData', 3, target, something, usage); + commandBuffer.push(27, 3, target, something, usage); }; this.bufferSubData = function(target, offset, something) { if (typeof something !== 'number') something = new something.constructor(something); - commandBuffer.push('bufferSubData', 3, target, offset, something); + commandBuffer.push(28, 3, target, offset, something); }; this.viewport = function(x, y, w, h) { - commandBuffer.push('viewport', 4, x, y, w, h); + commandBuffer.push(29, 4, x, y, w, h); }; this.vertexAttribPointer = function(index, size, type, normalized, stride, offset) { - commandBuffer.push('vertexAttribPointer', 6, index, size, type, normalized, stride, offset); + commandBuffer.push(30, 6, index, size, type, normalized, stride, offset); }; this.enableVertexAttribArray = function(index) { - commandBuffer.push('enableVertexAttribArray', 1, index); + commandBuffer.push(31, 1, index); }; this.disableVertexAttribArray = function(index) { - commandBuffer.push('disableVertexAttribArray', 1, index); + commandBuffer.push(32, 1, index); }; this.drawArrays = function(mode, first, count) { - commandBuffer.push('drawArrays', 3, mode, first, count); + commandBuffer.push(33, 3, mode, first, count); }; this.drawElements = function(mode, count, type, offset) { - commandBuffer.push('drawElements', 4, mode, count, type, offset); + commandBuffer.push(34, 4, mode, count, type, offset); }; this.getError = function() { // optimisticaly return success; client will abort on an actual error. we assume an error-free async workflow - commandBuffer.push('getError', 0); + commandBuffer.push(35, 0); return this.NO_ERROR; }; this.createTexture = function() { var id = nextId++; - commandBuffer.push('createTexture', -1, id); + commandBuffer.push(36, -1, id); return new WebGLTexture(id); }; this.deleteTexture = function(texture) { if (!texture) return; - commandBuffer.push('deleteTexture', 1, texture.id); + commandBuffer.push(37, 1, texture.id); texture.id = 0; }; this.isTexture = function(texture) { @@ -763,106 +763,106 @@ function WebGLWorker() { } } texture.binding = target; - commandBuffer.push('bindTexture', 2, target, texture ? texture.id : 0); + commandBuffer.push(38, 2, target, texture ? texture.id : 0); }; this.texParameteri = function(target, pname, param) { - commandBuffer.push('texParameteri', 3, target, pname, param); + commandBuffer.push(39, 3, target, pname, param); }; this.texImage2D = function(target, level, internalformat, width, height, border, format, type, pixels) { assert(pixels || pixels === null); // we do not support the overloads that have fewer params - commandBuffer.push('texImage2D', 9, target, level, internalformat, width, height, border, format, type, pixels ? new pixels.constructor(pixels) : pixels); + commandBuffer.push(40, 9, target, level, internalformat, width, height, border, format, type, pixels ? new pixels.constructor(pixels) : pixels); }; this.compressedTexImage2D = function(target, level, internalformat, width, height, border, pixels) { - commandBuffer.push('compressedTexImage2D', 7, target, level, internalformat, width, height, border, new pixels.constructor(pixels)); + commandBuffer.push(41, 7, target, level, internalformat, width, height, border, new pixels.constructor(pixels)); }; this.activeTexture = function(texture) { - commandBuffer.push('activeTexture', 1, texture); + commandBuffer.push(42, 1, texture); }; this.getShaderParameter = function(shader, pname) { switch (pname) { case this.SHADER_TYPE: return shader.type; case this.COMPILE_STATUS: { // optimisticaly return success; client will abort on an actual error. we assume an error-free async workflow - commandBuffer.push('getShaderParameter', 2, shader.id, pname); + commandBuffer.push(43, 2, shader.id, pname); return true; } default: throw 'unsupported getShaderParameter ' + pname; } }; this.clearDepth = function(depth) { - commandBuffer.push('clearDepth', 1, depth); + commandBuffer.push(44, 1, depth); }; this.depthFunc = function(depth) { - commandBuffer.push('depthFunc', 1, depth); + commandBuffer.push(45, 1, depth); }; this.frontFace = function(depth) { - commandBuffer.push('frontFace', 1, depth); + commandBuffer.push(46, 1, depth); }; this.cullFace = function(depth) { - commandBuffer.push('cullFace', 1, depth); + commandBuffer.push(47, 1, depth); }; this.readPixels = function(depth) { abort('readPixels is impossible, we are async GL'); }; this.pixelStorei = function(pname, param) { - commandBuffer.push('pixelStorei', 2, pname, param); + commandBuffer.push(48, 2, pname, param); }; this.depthMask = function(flag) { - commandBuffer.push('depthMask', 1, flag); + commandBuffer.push(49, 1, flag); }; this.depthRange = function(near, far) { - commandBuffer.push('depthRange', 2, near, far); + commandBuffer.push(50, 2, near, far); }; this.blendFunc = function(sfactor, dfactor) { - commandBuffer.push('blendFunc', 2, sfactor, dfactor); + commandBuffer.push(51, 2, sfactor, dfactor); }; this.scissor = function(x, y, width, height) { - commandBuffer.push('scissor', 4, x, y, width, height); + commandBuffer.push(52, 4, x, y, width, height); }; this.colorMask = function(red, green, blue, alpha) { - commandBuffer.push('colorMask', 4, red, green, blue, alpha); + commandBuffer.push(53, 4, red, green, blue, alpha); }; this.lineWidth = function(width) { - commandBuffer.push('lineWidth', 1, width); + commandBuffer.push(54, 1, width); }; this.createFramebuffer = function() { var id = nextId++; - commandBuffer.push('createFramebuffer', -1, id); + commandBuffer.push(55, -1, id); return new WebGLFramebuffer(id); }; this.deleteFramebuffer = function(framebuffer) { if (!framebuffer) return; - commandBuffer.push('deleteFramebuffer', 1, framebuffer.id); + commandBuffer.push(56, 1, framebuffer.id); }; this.bindFramebuffer = function(target, framebuffer) { - commandBuffer.push('bindFramebuffer', 2, target, framebuffer ? framebuffer.id : 0); + commandBuffer.push(57, 2, target, framebuffer ? framebuffer.id : 0); }; this.framebufferTexture2D = function(target, attachment, textarget, texture, level) { - commandBuffer.push('framebufferTexture2D', 5, target, attachment, textarget, texture ? texture.id : 0, level); + commandBuffer.push(58, 5, target, attachment, textarget, texture ? texture.id : 0, level); }; this.checkFramebufferStatus = function(target) { return this.FRAMEBUFFER_COMPLETE; // XXX totally wrong }; this.createRenderbuffer = function() { var id = nextId++; - commandBuffer.push('createRenderbuffer', -1, id); + commandBuffer.push(59, -1, id); return new WebGLRenderbuffer(id); }; this.deleteRenderbuffer = function(renderbuffer) { if (!renderbuffer) return; - commandBuffer.push('deleteRenderbuffer', 1, renderbuffer.id); + commandBuffer.push(60, 1, renderbuffer.id); }; this.bindRenderbuffer = function(target, renderbuffer) { - commandBuffer.push('bindRenderbuffer', 2, target, renderbuffer ? renderbuffer.id : 0); + commandBuffer.push(61, 2, target, renderbuffer ? renderbuffer.id : 0); }; this.renderbufferStorage = function(target, internalformat, width, height) { - commandBuffer.push('renderbufferStorage', 4, target, internalformat, width, height); + commandBuffer.push(62, 4, target, internalformat, width, height); }; this.framebufferRenderbuffer = function(target, attachment, renderbuffertarget, renderbuffer) { - commandBuffer.push('framebufferRenderbuffer', 4, target, attachment, renderbuffertarget, renderbuffer ? renderbuffer.id : 0); + commandBuffer.push(63, 4, target, attachment, renderbuffertarget, renderbuffer ? renderbuffer.id : 0); }; //this.debugPrint = function(text) { // useful to interleave debug output properly with client GL commands - // commandBuffer.push('debugPrint', 1, text); + // commandBuffer.push(64, 1, text); //}; // Setup |