# HG changeset patch # User Eli Gottlieb # Date 1279172498 14400 # Node ID e8caf178d082b9ad59ab25b55489a152ed80befb # Parent 6f0bc179771ca65d0c2727364cc3dc86989c8a28 Added in Visual Studio patch. diff -r 6f0bc179771c -r e8caf178d082 VisualC/SDL_VS2010.sln --- a/VisualC/SDL_VS2010.sln Wed Jul 14 00:49:28 2010 -0400 +++ b/VisualC/SDL_VS2010.sln Thu Jul 15 01:41:38 2010 -0400 @@ -2,9 +2,9 @@ # Visual Studio 2010 Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "tests", "tests", "{CE748C1F-3C21-4825-AA6A-F895A023F7E7}" EndProject -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "SDL", "SDL\SDL_VS2008.vcxproj", "{81CE8DAF-EBB2-4761-8E45-B71ABCCA8C68}" +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "SDL", "SDL\SDL_VS2010.vcxproj", "{81CE8DAF-EBB2-4761-8E45-B71ABCCA8C68}" EndProject -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "SDLmain", "SDLmain\SDLmain_VS2008.vcxproj", "{DA956FD3-E142-46F2-9DD5-C78BEBB56B7A}" +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "SDLmain", "SDLmain\SDLmain_VS2010.vcxproj", "{DA956FD3-E142-46F2-9DD5-C78BEBB56B7A}" EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "automated", "tests\automated\automated.vcxproj", "{DDD710DB-EC7B-4CCB-BD75-535D401A2FE0}" EndProject diff -r 6f0bc179771c -r e8caf178d082 src/video/SDL_shape.c --- a/src/video/SDL_shape.c Wed Jul 14 00:49:28 2010 -0400 +++ b/src/video/SDL_shape.c Thu Jul 15 01:41:38 2010 -0400 @@ -30,11 +30,21 @@ SDL_Window* SDL_CreateShapedWindow(const char *title,unsigned int x,unsigned int y,unsigned int w,unsigned int h,Uint32 flags) { SDL_Window *result = SDL_CreateWindow(title,x,y,w,h,SDL_WINDOW_BORDERLESS | flags & !SDL_WINDOW_FULLSCREEN & !SDL_WINDOW_SHOWN); - result->shaper = result->display->device->shape_driver.CreateShaper(result); - result->shaper->usershownflag = flags & SDL_WINDOW_SHOWN; - result->shaper->alphacutoff = 1; - result->shaper->hasshape = SDL_FALSE; - return result; + if(result != NULL) { + result->shaper = result->display->device->shape_driver.CreateShaper(result); + if(result->shaper != NULL) { + result->shaper->usershownflag = flags & SDL_WINDOW_SHOWN; + result->shaper->alphacutoff = 1; + result->shaper->hasshape = SDL_FALSE; + return result; + } + else { + SDL_DestroyWindow(result); + return NULL; + } + } + else + return NULL; } SDL_bool SDL_IsShapedWindow(const SDL_Window *window) { @@ -55,10 +65,10 @@ SDL_LockSurface(shape); for(x = 0;xw;x++) for(y = 0;yh;y++) { - pixel = shape->pixels + (y*shape->pitch) + (x*shape->format->BytesPerPixel); + pixel = (Uint8 *)(shape->pixels) + (y*shape->pitch) + (x*shape->format->BytesPerPixel); alpha = 0; SDL_GetRGBA(*(Uint32*)pixel,shape->format,&r,&g,&b,&alpha); - Uint32 bitmap_pixel = y*shape->w + x; + bitmap_pixel = y*shape->w + x; bitmap[bitmap_pixel / ppb] |= (alpha >= alphacutoff ? value : 0) << ((ppb - 1) - (bitmap_pixel % ppb)); } if(SDL_MUSTLOCK(shape))