diff options
author | Alon Zakai <alonzakai@gmail.com> | 2013-07-26 15:21:18 -0700 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2013-07-26 15:21:18 -0700 |
commit | 0914aca645370e8ff46324d304b8a2acb64567ec (patch) | |
tree | 2933178476562cc662e29daf15b3dbd38bd2fc9a /src/library_sdl.js | |
parent | 9987b9a039052cb84f33127e5b2c3df58f349d7c (diff) | |
parent | 36aa6eb6c7fd6acfb04a9f7467b8ca1974a07dcd (diff) |
Merge pull request #1393 from fhd/sdl-surface-refcount
Implement SDL_Surface refcounting
Diffstat (limited to 'src/library_sdl.js')
-rw-r--r-- | src/library_sdl.js | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/library_sdl.js b/src/library_sdl.js index 7078aa9d..4477e457 100644 --- a/src/library_sdl.js +++ b/src/library_sdl.js @@ -276,6 +276,8 @@ var LibrarySDL = { {{{ makeSetValue('surf+Runtime.QUANTUM_SIZE*5', '0', 'buffer', 'void*') }}} // SDL_Surface.pixels {{{ makeSetValue('surf+Runtime.QUANTUM_SIZE*6', '0', '0', 'i32*') }}} // SDL_Surface.offset + {{{ makeSetValue('surf+Runtime.QUANTUM_SIZE*14', '0', '1', 'i32') }}} + {{{ makeSetValue('pixelFormat + SDL.structs.PixelFormat.format', '0', '-2042224636', 'i32') }}} // SDL_PIXELFORMAT_RGBA8888 {{{ makeSetValue('pixelFormat + SDL.structs.PixelFormat.palette', '0', '0', 'i32') }}} // TODO {{{ makeSetValue('pixelFormat + SDL.structs.PixelFormat.BitsPerPixel', '0', 'bpp * 8', 'i8') }}} @@ -362,6 +364,13 @@ var LibrarySDL = { }, freeSurface: function(surf) { + var refcountPointer = surf + Runtime.QUANTUM_SIZE * 14; + var refcount = {{{ makeGetValue('refcountPointer', '0', 'i32') }}}; + if (refcount > 1) { + {{{ makeSetValue('refcountPointer', '0', 'refcount - 1', 'i32') }}}; + return; + } + var info = SDL.surfaces[surf]; if (!info.usePageCanvas && info.canvas) SDL.canvasPool.push(info.canvas); _free(info.buffer); |