X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=dosdemo;a=blobdiff_plain;f=src%2Fscreen.c;h=68a8c7f78a2139ba23c8c56794088f67f7b36f1b;hp=4e26db4d02801fe53599b95c3678144087410434;hb=73f97e0d9dc83cad4aa7b53d900ea28390afed4f;hpb=af69d4ef5753637bc6901febf039cdd8d74a86d4 diff --git a/src/screen.c b/src/screen.c index 4e26db4..68a8c7f 100644 --- a/src/screen.c +++ b/src/screen.c @@ -11,6 +11,11 @@ struct screen *grise_screen(void); 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]; @@ -41,6 +46,21 @@ int scr_init(void) if (!(scr[idx++] = bump_screen())) { return -1; } + 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); @@ -76,9 +96,22 @@ void scr_update(void) } } + void scr_draw(void) { - if(cur) cur->draw(); + if(cur) { + cur->draw(); + + /* print screen name */ + cs_puts(fb_pixels, 0, 0, cur->name); + } +} + +void scr_keypress(int key) +{ + if(cur && cur->keypress) { + cur->keypress(key); + } } struct screen *scr_lookup(const char *name)