X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Ftest.c;h=8c30c94ea4b7b6ef0baab9daa4fb8f6502c40cc4;hb=e3b220f5349f8282bd426fdca00c64c8c7e831cd;hp=df0af6152a78a5777d4fa77f30ee57af5a009438;hpb=623ca4b01f2db170c2273d5bc9c538be78d16c4c;p=16.git diff --git a/src/test.c b/src/test.c index df0af615..8c30c94e 100755 --- a/src/test.c +++ b/src/test.c @@ -23,15 +23,18 @@ #include #include "src/lib/modex16.h" #include "src/lib/16_in.h" +#include "src/lib/scroll16.h" global_game_variables_t gvar; player_t player[MaxPlayers]; +map_view_t mv[2]; +pan_t pan; void main(int argc, char *argv[]) { int i, j; - word start, end; - word p, k; + word startclk, endclk; + word k; byte *pal, *pal2; sword bakapee; @@ -39,6 +42,28 @@ void main(int argc, char *argv[]) if(argv[1]) bakapee = atoi(argv[1]); else bakapee = 1; + + // DOSLIB: check our environment + probe_dos(); + + // DOSLIB: what CPU are we using? + // NTS: I can see from the makefile Sparky4 intends this to run on 8088 by the -0 switch in CFLAGS. + // So this code by itself shouldn't care too much what CPU it's running on. Except that other + // parts of this project (DOSLIB itself) rely on CPU detection to know what is appropriate for + // the CPU to carry out tasks. --J.C. + cpu_probe(); + + // DOSLIB: check for VGA + if (!probe_vga()) { + printf("VGA probe failed\n"); + return; + } + // hardware must be VGA or higher! + if (!(vga_state.vga_flags & VGA_IS_VGA)) { + printf("This program requires VGA or higher graphics hardware\n"); + return; + } + /* load our palette */ modexLoadPalFile("data/default.pal", &pal2); @@ -48,74 +73,119 @@ void main(int argc, char *argv[]) modexFadeOff(1, pal); modexPalBlack(); - VGAmodeX(bakapee, &gvar); - modexPalBlack(); - IN_Startup(); - IN_Default(0,&player,ctrl_Joystick); + IN_Default(0,&player,ctrl_Keyboard1); + IN_initplayer(&player, 0); + + textInit(); + VGAmodeX(bakapee, 1, &gvar); + modexPalBlack(); /* set up the page, but with 16 pixels on all borders in offscreen mem */ - gvar.video.page[0]=modexDefaultPage(&gvar.video.page[0]); - gvar.video.page[1] = modexNextPage(&gvar.video.page[0]); - gvar.video.page[0].width += 32; - gvar.video.page[0].height += 32; + modexHiganbanaPageSetup(&gvar.video); + for(i=0;i=31){ i++; j=0; goto baka; }else j++; }else if(j>=32){ k++; j=0; }else j++; break; case 1: - /* go left */ - gvar.video.page[p].dx--; + // go left + gvar.video.page[pan.pn].dx--; if(j>=32){ k++; j=0; }else j++; break; case 2: - /* go up */ - gvar.video.page[p].dy++; + // go up + gvar.video.page[pan.pn].dy++; if(j>=32){ k++; j=0; }else j++; break; case 3: - /* go down */ - gvar.video.page[p].dy--; + // go down + gvar.video.page[pan.pn].dy--; if(j>=32){ k=0; j=0; i++; }else j++; break; default: break; - } - if(IN_KeyDown(2)) p=0; - if(IN_KeyDown(3)) p=1; - modexShowPage(&gvar.video.page[p]); + }}else{ + if(i==5) goto pee; + baka: + i++; + modexClearRegion(&gvar.video.page[1], 0, gvar.video.page[0].height/2, gvar.video.page[0].width-32, 16, 45);*/ + if(IN_KeyDown(6)) + { + modexClearRegion(&gvar.video.page[1], gvar.video.page[1].sw, 16, 8, 4, 45); + } + if(IN_KeyDown(4+1)){ + modexClearRegion(&gvar.video.page[1], 16, 16, gvar.video.page[1].sw, gvar.video.page[1].sh, 128); + modexClearRegion(&gvar.video.page[1], 32, 32, gvar.video.page[1].sw-32, gvar.video.page[1].sh-32, 42); + modexClearRegion(&gvar.video.page[1], 48, 48, gvar.video.page[1].sw-64, gvar.video.page[1].sh-64, 128); + } + //} + if(IN_KeyDown(2)) pan.pn=0; + if(IN_KeyDown(3)) pan.pn=1; + if(IN_KeyDown(25)){ + modexpdump(&gvar.video.page[pan.pn]); + }//p + modexShowPage(&gvar.video.page[pan.pn]); } - end = *clockw; + endclk = *clockw; /* fade back to text mode */ modexFadeOff(1, pal2); modexPalBlack(); - VGAmodeX(0, &gvar); - IN_Shutdown(); + VGAmodeX(0, 1, &gvar); printf("Project 16 test.exe. This is just a test file!\n"); printf("version %s\n", VERSION); + printf("video memory remaining: %ld\n", gvar.video.vmem_remain); + printf("page "); + for(i=0; i