diff options
author | Ehsan Akhgari <ehsan.akhgari@gmail.com> | 2012-05-15 17:12:26 -0400 |
---|---|---|
committer | Ehsan Akhgari <ehsan.akhgari@gmail.com> | 2012-05-15 19:52:55 -0400 |
commit | af56b35e0f169d8089b0b24b0247db00b68d03ce (patch) | |
tree | 075689ae12a8375d4c0199f35b7a36951da25e7c | |
parent | ddf835588b1bb972d66ef34c3811b3e7459ee174 (diff) |
Fix IMG_Load to work with absolute paths
-rw-r--r-- | src/library_sdl.js | 4 | ||||
-rw-r--r-- | tests/sdl_image.c | 26 |
2 files changed, 22 insertions, 8 deletions
diff --git a/src/library_sdl.js b/src/library_sdl.js index d6e205ee..472228c1 100644 --- a/src/library_sdl.js +++ b/src/library_sdl.js @@ -756,6 +756,10 @@ var LibrarySDL = { IMG_Load__deps: ['SDL_LockSurface'], IMG_Load: function(filename) { filename = FS.standardizePath(Pointer_stringify(filename)); + if (filename[0] == '/') { + // Convert the path to relative + filename = filename.substr(1); + } var raw = preloadedImages[filename]; if (!raw) { Runtime.warnOnce('Cannot find preloaded image ' + filename); diff --git a/tests/sdl_image.c b/tests/sdl_image.c index d934f863..9d8c36f2 100644 --- a/tests/sdl_image.c +++ b/tests/sdl_image.c @@ -4,30 +4,40 @@ #include <assert.h> #include <emscripten.h> -int main() { - SDL_Init(SDL_INIT_VIDEO); - SDL_Surface *screen = SDL_SetVideoMode(600, 450, 32, SDL_SWSURFACE); - - SDL_Surface *image = IMG_Load("screenshot.jpg"); +int testImage(SDL_Surface* screen, const char* fileName) { + SDL_Surface *image = IMG_Load(fileName); if (!image) { printf("IMG_Load: %s\n", IMG_GetError()); - return 1; + return 0; } assert(image->format->BitsPerPixel == 32); assert(image->format->BytesPerPixel == 4); assert(image->pitch == 4*image->w); + int result = image->w; SDL_BlitSurface (image, NULL, screen, NULL); SDL_FreeSurface (image); - SDL_Flip(screen); + return result; +} + +int main() { + SDL_Init(SDL_INIT_VIDEO); + SDL_Surface *screen = SDL_SetVideoMode(600, 450, 32, SDL_SWSURFACE); + + int result = 0; + result = testImage(screen, "screenshot.jpg"); // relative path + assert(result != 0); + result |= testImage(screen, "/screenshot.jpg"); // absolute path + assert(result != 0); + + SDL_Flip(screen); printf("you should see an image.\n"); SDL_Quit(); - int result = image->w; REPORT_RESULT(); return 0; |