aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2014-01-03 15:42:42 -0800
committerAlon Zakai <alonzakai@gmail.com>2014-01-03 15:42:42 -0800
commitc00a68fd1f70cb5b8a3e5faccc37965b59c40972 (patch)
treed08c37c77c58096c68aafe1551aa44d84fcbc495
parenta8e26049c1a72fa6b19dac45fa2b44616f94241a (diff)
parent2268e7b0b65b532f4bc762b394e8d1c4a590fefc (diff)
Merge pull request #1971 from jvilk/sdl_fixes
[SDL] Fixing SDL_UnlockSurface in IE10/IE11
-rw-r--r--src/library_sdl.js26
-rw-r--r--tests/sdl_canvas.c2
2 files changed, 22 insertions, 6 deletions
diff --git a/src/library_sdl.js b/src/library_sdl.js
index 1c1e8107..78f6a628 100644
--- a/src/library_sdl.js
+++ b/src/library_sdl.js
@@ -1056,14 +1056,28 @@ var LibrarySDL = {
var buffer = surfData.buffer;
#if USE_TYPED_ARRAYS == 2
assert(buffer % 4 == 0, 'Invalid buffer offset: ' + buffer);
- var src = buffer >> 2;
+ var src;
var dst = 0;
var isScreen = surf == SDL.screen;
- var data32 = new Uint32Array(data.buffer);
- var num = data32.length;
- while (dst < num) {
- // HEAP32[src++] is an optimization. Instead, we could do {{{ makeGetValue('buffer', 'dst', 'i32') }}};
- data32[dst++] = HEAP32[src++] | (isScreen ? 0xff000000 : 0);
+ var num;
+ if (typeof CanvasPixelArray !== 'undefined' && data instanceof CanvasPixelArray) {
+ // IE10/IE11: Canvases are backed by the deprecated CanvasPixelArray,
+ // not UInt8ClampedArray. These don't have buffers, so we need to revert
+ // to copying a byte at a time. We do the undefined check because modern
+ // browsers do not define CanvasPixelArray anymore.
+ src = buffer;
+ num = data.length;
+ while (dst < num) {
+ data[dst++] = HEAP8[src++];
+ }
+ } else {
+ var data32 = new Uint32Array(data.buffer);
+ src = buffer >> 2;
+ num = data32.length;
+ while (dst < num) {
+ // HEAP32[src++] is an optimization. Instead, we could do {{{ makeGetValue('buffer', 'dst', 'i32') }}};
+ data32[dst++] = HEAP32[src++] | (isScreen ? 0xff000000 : 0);
+ }
}
#else
var num = surfData.image.data.length;
diff --git a/tests/sdl_canvas.c b/tests/sdl_canvas.c
index 6bd659b8..cab48985 100644
--- a/tests/sdl_canvas.c
+++ b/tests/sdl_canvas.c
@@ -62,6 +62,8 @@ int main(int argc, char **argv) {
printf("you should see two lines of text in different colors and a blue rectangle\n");
+ SDL_UnlockSurface(screen);
+
SDL_Quit();
printf("done.\n");