aboutsummaryrefslogtreecommitdiff
path: root/src/library_sdl.js
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2013-07-26 15:21:18 -0700
committerAlon Zakai <alonzakai@gmail.com>2013-07-26 15:21:18 -0700
commit0914aca645370e8ff46324d304b8a2acb64567ec (patch)
tree2933178476562cc662e29daf15b3dbd38bd2fc9a /src/library_sdl.js
parent9987b9a039052cb84f33127e5b2c3df58f349d7c (diff)
parent36aa6eb6c7fd6acfb04a9f7467b8ca1974a07dcd (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.js9
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);