X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=dosdemo;a=blobdiff_plain;f=src%2Fscreen.c;h=b39778d52d7331ff64ed0bbbb8914230a79ba2f5;hp=9aae07315ba42a0226de00ae8b9eafe2382d4c45;hb=fcac764d752234a03df536dd408235170394f6ad;hpb=4d71594c8a11f19d25ca4e94b11608322e02ceec diff --git a/src/screen.c b/src/screen.c index 9aae073..b39778d 100644 --- a/src/screen.c +++ b/src/screen.c @@ -12,6 +12,10 @@ struct screen *polytest_screen(void); struct screen *plasma_screen(void); struct screen *bump_screen(void); struct screen *thunder_screen(void); +struct screen *metaballs_screen(void); +struct screen *greets_screen(void); +struct screen *infcubes_screen(void); +struct screen *hairball_screen(void); #define NUM_SCR 32 static struct screen *scr[NUM_SCR]; @@ -45,6 +49,18 @@ int scr_init(void) if (!(scr[idx++] = thunder_screen())) { return -1; } + if(!(scr[idx++] = metaballs_screen())) { + return -1; + } + if(!(scr[idx++] = greets_screen())) { + return -1; + } + if(!(scr[idx++] = infcubes_screen())) { + return -1; + } + if(!(scr[idx++] = hairball_screen())) { + return -1; + } num_screens = idx; assert(num_screens <= NUM_SCR); @@ -85,6 +101,13 @@ void scr_draw(void) if(cur) cur->draw(); } +void scr_keypress(int key) +{ + if(cur && cur->keypress) { + cur->keypress(key); + } +} + struct screen *scr_lookup(const char *name) { int i;