X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;ds=inline;f=src%2Ftest.c;h=ab283fa614ba28b14452256706eecfc767a1541f;hb=e7fa17ebf9e8c8ce5d08d2fe5da684df58f45910;hp=ffb449c1f23137df368134f5854c811503e262bf;hpb=dee7084dead7149e3576793a69f5dbc6be55a914;p=16.git diff --git a/src/test.c b/src/test.c index ffb449c1..ab283fa6 100755 --- a/src/test.c +++ b/src/test.c @@ -1,5 +1,5 @@ /* Project 16 Source Code~ - * Copyright (C) 2012-2015 sparky4 & pngwen & andrius4669 + * Copyright (C) 2012-2016 sparky4 & pngwen & andrius4669 & joncampbell123 * * This file is part of Project 16. * @@ -23,14 +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, k; - word start, end; + int i, j; + word startclk, endclk; + word k; byte *pal, *pal2; sword bakapee; @@ -38,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); @@ -47,72 +73,120 @@ 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[0].dx--; - modexShowPage(&gvar.video.page[0]); + // go left + gvar.video.page[pan.pn].dx--; if(j>=32){ k++; j=0; }else j++; break; case 2: - /* go up */ - gvar.video.page[0].dy++; - modexShowPage(&gvar.video.page[0]); + // go up + gvar.video.page[pan.pn].dy++; if(j>=32){ k++; j=0; }else j++; break; case 3: - /* go down */ - gvar.video.page[0].dy--; - modexShowPage(&gvar.video.page[0]); + // go down + gvar.video.page[pan.pn].dy--; if(j>=32){ k=0; j=0; i++; }else j++; break; default: break; - } + }}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); + 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