]> 4ch.mooo.com Git - 16.git/blobdiff - src/test.c
add printf-like _DEBUGF() function for debugging, too
[16.git] / src / test.c
index 397971ba6063f0d235a0dce512565e6ae2f3b7e5..bb3792ae16919090c0b3f6f6b1176b6494e7c4d3 100755 (executable)
 #include <stdio.h>\r
 #include "src/lib/modex16.h"\r
 #include "src/lib/16_in.h"\r
+#include "src/lib/scroll16.h"\r
 \r
 global_game_variables_t gvar;\r
 player_t player[MaxPlayers];\r
+map_view_t mv[4];\r
+pan_t pan;\r
 \r
 void main(int argc, char *argv[])\r
 {\r
        int i, j;\r
-       word start, end;\r
-       word p, k;\r
+       word startclk, endclk;\r
+       word k;\r
        byte *pal, *pal2;\r
        sword bakapee;\r
 \r
@@ -61,6 +64,14 @@ void main(int argc, char *argv[])
                return;\r
        }\r
 \r
+       if (_DEBUG_INIT() == 0) {\r
+#ifdef DEBUGSERIAL\r
+               printf("WARNING: Failed to initialize DEBUG output\n");\r
+#endif\r
+       }\r
+       _DEBUG("Serial debug output started\n"); // NTS: All serial output must end messages with newline, or DOSBox-X will not emit text to log\r
+       _DEBUGF("Serial debug output printf test %u %u %u\n",1U,2U,3U);\r
+\r
        /* load our palette */\r
        modexLoadPalFile("data/default.pal", &pal2);\r
 \r
@@ -71,7 +82,8 @@ void main(int argc, char *argv[])
        modexPalBlack();\r
 \r
        IN_Startup();\r
-       IN_Default(0,&player,ctrl_Joystick);\r
+       IN_Default(0,&player,ctrl_Keyboard1);\r
+       IN_initplayer(&player, 0);\r
 \r
        textInit();\r
        VGAmodeX(bakapee, 1, &gvar);\r
@@ -79,61 +91,97 @@ void main(int argc, char *argv[])
 \r
        /* set up the page, but with 16 pixels on all borders in offscreen mem */\r
        modexHiganbanaPageSetup(&gvar.video);\r
-//     gvar.video.page[0]=modexDefaultPage(&gvar.video.page[0]);\r
-//     gvar.video.page[1] = modexNextPage(&gvar.video.page[0]);\r
-//     gvar.video.page[0].width += 32;\r
-//     gvar.video.page[0].height += 32;\r
+       for(i=0;i<gvar.video.num_of_pages;i++)\r
+       {\r
+               mv[i].page = &gvar.video.page[i];\r
+               mv[i].video = &gvar.video;\r
+               mv[i].pan       = &pan;\r
+               mv[i].tx        = 0;\r
+               mv[i].ty        = 0;\r
+       }\r
+//     gvar.video.page[0]=modexDefaultPage(&gvar.video.page[0]);\r
+//     gvar.video.page[1] = modexNextPage(&gvar.video.page[0]);\r
 \r
 \r
        /* fill the page with one color, but with a black border */\r
+       modexClearRegion(&gvar.video.page[1], 0, 0, gvar.video.page[1].width, gvar.video.page[1].height, 15);\r
+       modexClearRegion(&gvar.video.page[1], 16, 16, gvar.video.page[1].sw, gvar.video.page[1].sh, 128);\r
+       modexClearRegion(&gvar.video.page[1], 32, 32, gvar.video.page[1].sw-32, gvar.video.page[1].sh-32, 42);\r
+       modexClearRegion(&gvar.video.page[1], 48, 48, gvar.video.page[1].sw-64, gvar.video.page[1].sh-64, 128);\r
        modexShowPage(&gvar.video.page[1]);\r
-       //modexClearRegion(&gvar.video.page[0], 0, 0, gvar.video.page[0].width, gvar.video.page[0].height, 0);\r
+       modexClearRegion(&gvar.video.page[0], 0, 0, gvar.video.page[0].width, gvar.video.page[0].height, 15);\r
        modexClearRegion(&gvar.video.page[0], 16, 16, gvar.video.page[0].sw, gvar.video.page[0].sh, 128);\r
        modexClearRegion(&gvar.video.page[0], 32, 32, gvar.video.page[0].sw-32, gvar.video.page[0].sh-32, 42);\r
        modexClearRegion(&gvar.video.page[0], 48, 48, gvar.video.page[0].sw-64, gvar.video.page[0].sh-64, 128);\r
        modexShowPage(&gvar.video.page[0]);\r
        modexCopyPageRegion(&gvar.video.page[1], &gvar.video.page[0], 0, 0, 0, 0, gvar.video.page[0].width, gvar.video.page[0].height);\r
+       modexClearRegion(&gvar.video.page[2], 0, 0, gvar.video.page[2].sw, gvar.video.page[2].sh, 47);\r
+       modexClearRegion(&gvar.video.page[3], 0, 0, gvar.video.page[3].sw, gvar.video.page[3].sh, 45);\r
 \r
        /* fade in */\r
        modexFadeOn(1, pal2);\r
 \r
-       i=0,k=0,j=0,p=0;\r
-       start = *clockw;\r
-       while(!IN_KeyDown(sc_Escape) && i<5)\r
+       i=0,k=0,j=0,pan.pn=1;\r
+       startclk = *clockw;\r
+       while(!IN_KeyDown(sc_Escape))\r
        {\r
                IN_ReadControl(0,&player);\r
+               panpagemanual(mv, player, 0);\r
+\r
+               /*if(i<5){\r
                switch (k)\r
                {\r
                        case 0:\r
-                               /* go right */\r
-                               gvar.video.page[p].dx++;\r
+                               pee:\r
+                               // go right\r
+                               gvar.video.page[pan.pn].dx++;\r
+                               if(i==5){ if(j>=31){ i++; j=0; goto baka; }else j++; }else\r
                                if(j>=32){ k++; j=0; }else j++;\r
                        break;\r
                        case 1:\r
-                               /* go left */\r
-                               gvar.video.page[p].dx--;\r
+                               // go left\r
+                               gvar.video.page[pan.pn].dx--;\r
                                if(j>=32){ k++; j=0; }else j++;\r
                        break;\r
                        case 2:\r
-                               /* go up */\r
-                               gvar.video.page[p].dy++;\r
+                               // go up\r
+                               gvar.video.page[pan.pn].dy++;\r
                                if(j>=32){ k++; j=0; }else j++;\r
                        break;\r
                        case 3:\r
-                               /* go down */\r
-                               gvar.video.page[p].dy--;\r
+                               // go down\r
+                               gvar.video.page[pan.pn].dy--;\r
                                if(j>=32){ k=0; j=0; i++; }else j++;\r
                        break;\r
                        default:\r
 \r
                        break;\r
-               }\r
-               if(IN_KeyDown(2)) p=0;\r
-               if(IN_KeyDown(3)) p=1;\r
-               modexShowPage(&gvar.video.page[p]);\r
+               }}else{\r
+                       if(i==5) goto pee;\r
+                       baka:\r
+                       i++;\r
+                       modexClearRegion(&gvar.video.page[1], 0, gvar.video.page[0].height/2, gvar.video.page[0].width-32, 16, 45);*/\r
+//                     if(IN_KeyDown(6))\r
+//                     {\r
+//                             modexClearRegion(&gvar.video.page[1],  gvar.video.page[1].sw, 16, 8, 4, 45);\r
+//                     }\r
+//                     if(IN_KeyDown(4+1)){\r
+//                             modexClearRegion(&gvar.video.page[1], 16, 16, gvar.video.page[1].sw, gvar.video.page[1].sh, 128);\r
+//                             modexClearRegion(&gvar.video.page[1], 32, 32, gvar.video.page[1].sw-32, gvar.video.page[1].sh-32, 42);\r
+//                             modexClearRegion(&gvar.video.page[1], 48, 48, gvar.video.page[1].sw-64, gvar.video.page[1].sh-64, 128);\r
+//                     }\r
+               //}\r
+               if(IN_KeyDown(1+1)) pan.pn=0;\r
+               if(IN_KeyDown(2+1)) pan.pn=1;\r
+               if(IN_KeyDown(3+1)) pan.pn=2;\r
+               if(IN_KeyDown(4+1)) pan.pn=3;\r
+               if(IN_KeyDown(25)){\r
+                       modexpdump(&gvar.video.page[pan.pn]);\r
+               }//p\r
+               modexShowPage(&gvar.video.page[pan.pn]);\r
        }\r
 \r
-       end = *clockw;\r
+       endclk = *clockw;\r
 \r
        /* fade back to text mode */\r
        modexFadeOff(1, pal2);\r
@@ -141,13 +189,8 @@ void main(int argc, char *argv[])
        VGAmodeX(0, 1, &gvar);\r
        printf("Project 16 test.exe. This is just a test file!\n");\r
        printf("version %s\n", VERSION);\r
-       printf("video memory remaining: %ld\n", gvar.video.vmem_remain);\r
-       printf("page ");\r
-       for(i=0; i<gvar.video.num_of_pages;i++)\r
-       {\r
-               printf("        [%u]=", i);\r
-               printf("(%Fp)\n", (gvar.video.page[i].data));\r
-       }\r
+       modexprintmeminfo(&gvar.video);\r
+       printf("tx=%d   ", mv[pan.pn].tx); printf("ty=%d        ", mv[pan.pn].ty); printf("player.d=%d\n", player[0].d);\r
        IN_Shutdown();\r
        modexPalBlack();\r
        modexFadeOn(1, pal);\r