diff --git a/contrib/sdk/sources/SDL-1.2.2_newlib/test/Makefile b/contrib/sdk/sources/SDL-1.2.2_newlib/test/Makefile new file mode 100755 index 0000000000..b505afb4c1 --- /dev/null +++ b/contrib/sdk/sources/SDL-1.2.2_newlib/test/Makefile @@ -0,0 +1,27 @@ +CC = kos32-gcc +LD = kos32-ld + +SDK_DIR = ../../../ +LDFLAGS = -nostdlib -static --image-base 0 -T $(SDK_DIR)/sources/newlib/app.lds + +CFLAGS = -c -fno-ident -O2 -fomit-frame-pointer -fno-ident -U__WIN32__ -U_Win32 -U_WIN32 -U__MINGW32__ -UWIN32 + +INCLUDES = -I $(SDK_DIR)/sources/newlib/libc/include -I ../include/ +LIBPATH = -L $(SDK_DIR)/lib -L /home/autobuild/tools/win32/mingw32/lib + +default: fire + +fire: $(OBJECTS) Makefile + $(CC) $(CFLAGS) $(INCLUDES) -o sdltest.o sdltest.c + $(CC) $(CFLAGS) $(INCLUDES) -o testbitmap.o testbitmap.c + $(LD) $(LDFLAGS) $(LIBPATH) --subsystem native -o sdltest sdltest.o -lgcc -lSDL -lc.dll -lc -lsound + $(LD) $(LDFLAGS) $(LIBPATH) --subsystem native -o testbitmap testbitmap.o -lgcc -lSDL -lc.dll -lc -lsound + kos32-strip -s sdltest -o sdltest + kos32-strip -s testbitmap -o testbitmap + objcopy testbitmap -O binary + objcopy sdltest -O binary + rm testbitmap.o + rm sdltest.o +clean: + rm testbitmap + rm sdltest diff --git a/contrib/sdk/sources/SDL-1.2.2_newlib/test/picture.xbm b/contrib/sdk/sources/SDL-1.2.2_newlib/test/picture.xbm new file mode 100755 index 0000000000..c873a60a18 --- /dev/null +++ b/contrib/sdk/sources/SDL-1.2.2_newlib/test/picture.xbm @@ -0,0 +1,14 @@ +#define picture_width 32 +#define picture_height 32 +static char picture_bits[] = { + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x18, 0x80, 0x01, 0x18, + 0x64, 0x6f, 0xf6, 0x26, 0x0a, 0x00, 0x00, 0x50, 0xf2, 0xff, 0xff, 0x4f, + 0x14, 0x04, 0x00, 0x28, 0x14, 0x0e, 0x00, 0x28, 0x10, 0x32, 0x00, 0x08, + 0x94, 0x03, 0x00, 0x08, 0xf4, 0x04, 0x00, 0x08, 0xb0, 0x08, 0x00, 0x08, + 0x34, 0x01, 0x00, 0x28, 0x34, 0x01, 0x00, 0x28, 0x12, 0x00, 0x40, 0x48, + 0x12, 0x20, 0xa6, 0x48, 0x14, 0x50, 0x11, 0x29, 0x14, 0x50, 0x48, 0x2a, + 0x10, 0x27, 0xac, 0x0e, 0xd4, 0x71, 0xe8, 0x0a, 0x74, 0x20, 0xa8, 0x0a, + 0x14, 0x20, 0x00, 0x08, 0x10, 0x50, 0x00, 0x08, 0x14, 0x00, 0x00, 0x28, + 0x14, 0x00, 0x00, 0x28, 0xf2, 0xff, 0xff, 0x4f, 0x0a, 0x00, 0x00, 0x50, + 0x64, 0x6f, 0xf6, 0x26, 0x18, 0x80, 0x01, 0x18, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; diff --git a/contrib/sdk/sources/SDL-1.2.2_newlib/test/sdltest.c b/contrib/sdk/sources/SDL-1.2.2_newlib/test/sdltest.c new file mode 100755 index 0000000000..ed6079e258 --- /dev/null +++ b/contrib/sdk/sources/SDL-1.2.2_newlib/test/sdltest.c @@ -0,0 +1,28 @@ +#include "SDL.h" +#include + +SDL_Surface* screen; +static int done = 0; + +int main() +{ + SDL_Event event; + if(SDL_Init(SDL_INIT_VIDEO) < 0) exit(0); + atexit(SDL_Quit); + screen = SDL_SetVideoMode(320, 200, 8, SDL_SWSURFACE); + while(!done) + { + while(SDL_PollEvent(&event)) + { + switch(event.type) + { + case SDL_KEYDOWN: + case SDL_QUIT: + done=1; + break; + default: + break; + } + } + } +} diff --git a/contrib/sdk/sources/SDL-1.2.2_newlib/test/testbitmap.c b/contrib/sdk/sources/SDL-1.2.2_newlib/test/testbitmap.c new file mode 100755 index 0000000000..d2124dd744 --- /dev/null +++ b/contrib/sdk/sources/SDL-1.2.2_newlib/test/testbitmap.c @@ -0,0 +1,125 @@ + +/* Simple program: Test bitmap blits */ + +#include +#include +#include + +#include "SDL.h" +#include "picture.xbm" + +SDL_Surface *LoadXBM(SDL_Surface *screen, int w, int h, Uint8 *bits) +{ + SDL_Surface *bitmap; + Uint8 *line; + + /* Allocate the bitmap */ + bitmap = SDL_CreateRGBSurface(SDL_SWSURFACE, w, h, 1, 0, 0, 0, 0); + if ( bitmap == NULL ) { + fprintf(stderr, "Couldn't allocate bitmap: %s\n", + SDL_GetError()); + return(NULL); + } + + /* Copy the pixels */ + line = (Uint8 *)bitmap->pixels; + w = (w+7)/8; + while ( h-- ) { + memcpy(line, bits, w); + /* X11 Bitmap images have the bits reversed */ + { int i, j; Uint8 *buf, byte; + for ( buf=line, i=0; i=0; --j ) { + *buf |= (byte&0x01)<>= 1; + } + } + } + line += bitmap->pitch; + bits += w; + } + return(bitmap); +} + +int main(int argc, char *argv[]) +{ + SDL_Surface *screen; + SDL_Surface *bitmap; + Uint8 video_bpp; + Uint32 videoflags; + Uint8 *buffer; + int i, done; + SDL_Event event; + + /* Initialize SDL */ + if ( SDL_Init(SDL_INIT_VIDEO) < 0 ) { + fprintf(stderr, "Couldn't initialize SDL: %s\n",SDL_GetError()); + exit(1); + } + atexit(SDL_Quit); + + video_bpp = 0; + videoflags = SDL_SWSURFACE; + /* Set 640x480 video mode */ + if ( (screen=SDL_SetVideoMode(640,480,video_bpp,videoflags)) == NULL ) { + fprintf(stderr, "Couldn't set 640x480x%d video mode: %s\n", + video_bpp, SDL_GetError()); + exit(2); + } + + /* Set the surface pixels and refresh! */ + if ( SDL_LockSurface(screen) < 0 ) { + fprintf(stderr, "Couldn't lock the display surface: %s\n", + SDL_GetError()); + exit(2); + } + buffer=(Uint8 *)screen->pixels; + for ( i=0; ih; ++i ) { + memset(buffer,(i*255)/screen->h, screen->pitch); + buffer += screen->pitch; + } + SDL_UnlockSurface(screen); + SDL_UpdateRect(screen, 0, 0, 0, 0); + + /* Load the bitmap */ + bitmap = LoadXBM(screen, picture_width, picture_height, + (Uint8 *)picture_bits); + if ( bitmap == NULL ) { + exit(1); + } + + /* Wait for a keystroke */ + done = 0; + while ( !done ) { + /* Check for events */ + while ( SDL_PollEvent(&event) ) { + switch (event.type) { + case SDL_MOUSEBUTTONDOWN: { + SDL_Rect dst; + + dst.x = event.button.x - bitmap->w/2; + dst.y = event.button.y - bitmap->h/2; + dst.w = bitmap->w; + dst.h = bitmap->h; + SDL_BlitSurface(bitmap, NULL, + screen, &dst); + SDL_UpdateRects(screen,1,&dst); + } + break; + case SDL_KEYDOWN: + /* Any key press quits the app... */ + done = 1; + break; + case SDL_QUIT: + done = 1; + break; + default: + break; + } + } + } + SDL_FreeSurface(bitmap); + return(0); +}