OSDN Git Service

buggy function commented out now works on both versions of exmmtest
[proj16/16.git] / src / exmmtest.c
index 3c440c1..732c15d 100755 (executable)
@@ -1,5 +1,5 @@
 /* Project 16 Source Code~\r
- * Copyright (C) 2012-2017 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover\r
+ * Copyright (C) 2012-2021 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover\r
  *\r
  * This file is part of Project 16.\r
  *\r
 /*\r
        exmm test\r
 */\r
-#include <malloc.h>            // for _memavl()\r
-#include "src/lib/16_head.h"\r
-#include "src/lib/16_tail.h"\r
-#include "src/lib/16_pm.h"\r
-#include "src/lib/16_ca.h"\r
-#include "src/lib/16_mm.h"\r
-#include "src/lib/16_hc.h"\r
-//#include "src/lib/16_vl.h"\r
-#include "src/lib/16_dbg.h"\r
-\r
-#pragma hdrstop\r
-\r
-#pragma warn -pro\r
-#pragma warn -use\r
-\r
-//file load or read definition\r
-#define FILEREADLOAD\r
-#define FILEREAD\r
-//#define EXMMVERBOSE\r
-//#define BUFFDUMPPAUSE\r
-//#define EXMMVERBOSE__\r
-//     #define PRINTBBDUMP\r
-#define BUFFDUMP\r
-\r
-#define BBUFNAME bigbuffer//gvar.ca.tinf[0]\r
-#define INITBBUF static memptr BBUFNAME;\r
-#define BBUFPTR        MEMPTR BBUFNAME\r
-\r
-#ifdef __BORLANDC__\r
-#define BBUF           (memptr *)BBUFPTR//\r
-#define BBUFSTRING     (memptr *)BBUFNAME\r
-#endif\r
-#ifdef __WATCOMC__\r
-#define BBUF           BBUFNAME\r
-#define BBUFSTRING     BBUF\r
-#endif\r
+#include "src/exmmtest.h"\r
 \r
 ////////////////////////////////////////////////////////////////////////////\r
-\r
+#ifdef NOVID\r
+void VL_Startup (global_game_variables_t *gvar){ gvar=gvar; }\r
+void VL_Shutdown (global_game_variables_t *gvar){ gvar=gvar; }\r
 void VGAmodeX(sword vq, boolean cmem, global_game_variables_t *gv)\r
 {\r
        printf("VGAmodeX dummy:\n       %Fp     %Fp     %Fp\n", &vq, &cmem, gv);\r
 }\r
 \r
-//printf("*    %Fp\t", *BBUF);\r
-//printf("*         %04x\t", *BBUF);\r
-#define PRINTBB {\\r
-       printf("-------------------------------------------------------------------------------\n");\\r
-       printf("&main()=        %Fp\n", argv[0]);\\r
-       printf("buffer:\n");\\r
-       printf("        %Fp\t", BBUF);\\r
-       printf("&%Fp\n", BBUFPTR);\\r
-       printf("             %04x\t", BBUF);\\r
-       printf("&     %04x\n", BBUFPTR);\\r
-       printf("-------------------------------------------------------------------------------\n");\\r
+word\r
+VL_modexPalOverscan(byte *p, word col)\r
+{\r
+       int i;\r
+       //modexWaitBorder();\r
+//     vga_wait_for_vsync();\r
+       outp(PAL_WRITE_REG, 0);  /* start at the beginning of palette */\r
+       for(i=col; i<(3+col); i++)\r
+       {\r
+               outp(PAL_DATA_REG, p[i]);\r
+       }\r
+//     modexPalSave(p);\r
+       return col;\r
+}\r
+void   TL_VidInit(global_game_variables_t *gvar)\r
+{\r
+       gvar->video.old_mode = 3;\r
 }\r
-       //printf("&main()=      %Fp\n", *argv[0]);\r
-       //printf("bigbuffer=    %Fp\n", bigbuffer);\r
-       //printf("&bigbuffer=   %Fp\n", &bigbuffer);\r
-       //printf("bigbuffer=    %04x\n", bigbuffer);\r
-       //printf("&bigbuffer=   %04x\n", &bigbuffer);\r
+\r
+void VL_print(const byte *str, nibble pagenum, global_game_variables_t *gvar){ printf("%s\n", str); }\r
+\r
+#ifdef __WATCOMC__\r
+void VL_ShowPage(page_t *page, boolean vsync, boolean sr){}\r
+void modexClearRegion(page_t *page, int x, int y, int w, int h, byte color){}\r
+void modexprint(page_t *page, sword x, sword y, word t, boolean tlsw, word color, word bgcolor, boolean vidsw, const byte *str){ printf("%s\n", str); }\r
+void modexpdump(nibble pagenum, global_game_variables_t *gvar){}\r
+#endif\r
+#endif\r
+\r
 #ifdef __WATCOMC__\r
 void segatesuto()\r
 {\r
@@ -101,83 +80,87 @@ void segatesuto()
 //\r
 //     }\r
 //     printf("]\n");\r
-//     printf("press any key to continue!\n");\r
-//     getch();\r
+//     KEYP\r
 }\r
 #endif\r
 \r
+#ifdef SCROLLLOAD\r
+#define FILENAME_1     "data/spri/chikyuu.vrs"\r
+#define FILENAME_2     "data/test.map"\r
+#else\r
+#define FILENAME_1     "data/spri/chikyuu.sht"\r
+#define FILENAME_2     "data/test.map"\r
+#endif\r
+\r
+//===========================================================================//\r
+\r
+//=======================================//\r
+\r
+//     main\r
+\r
+//=======================================//\r
 void\r
 main(int argc, char *argv[])\r
 {\r
-       byte w;\r
        static global_game_variables_t gvar;\r
-#ifdef INITBBUF\r
+                                                               #ifdef INITBBUF\r
        INITBBUF\r
-#endif\r
-//#ifdef __WATCOMC__\r
-//     __segment sega;\r
-//#endif\r
-       //static byte bakapee[64];\r
-       char *bakapee1, *bakapee2;\r
-       word baka;\r
+                                                               #endif\r
 \r
-#ifdef __BORLANDC__\r
-       argc=argc;\r
-#endif\r
-       //file name //\r
-       bakapee1 = malloc(24);\r
-       bakapee2 = malloc(24);\r
-       //file name //\r
+       char bakapee1[64] = FILENAME_1;\r
+       char bakapee2[64] = FILENAME_2;\r
+\r
+               #ifdef __BORLANDC__\r
+                       argc=argc;\r
+               #endif\r
 \r
+                                                               #ifdef PRINTBBDUMP\r
+                                                               //0000PRINTBB; KEYP\r
+                                                               #endif\r
 #ifdef __16_PM__\r
 #ifdef __DEBUG_PM__\r
        dbg_debugpm=1;  //debug pm\r
 #endif\r
 #endif\r
-\r
 #ifdef __DEBUG_CA__\r
        dbg_debugca=1;\r
 #endif\r
-#ifdef PRINTBBDUMP\r
-//0000PRINTBB; printf("press any key to continue!\n"); getch();\r
-#endif\r
-       if(argv[1]){ bakapee1 = argv[1];\r
-       if(argv[2]) bakapee2 = argv[2]; }\r
-       else{\r
-       //{ printf("filename!: "); scanf("%[^\n]", &bakapee); }\r
-               bakapee1 = "data/koishi~.pcx";\r
-               bakapee2 = "data/test.map";\r
-       }\r
-       //printf("main()=%Fp    start MM\n", *argv[0]);\r
-       MM_Startup(&gvar); //printf("ok\n");\r
-#ifdef __16_PM__\r
-#ifdef __DEBUG_PM__\r
-       if(dbg_debugpm>0)\r
-       {\r
-#endif\r
-               PM_Startup(&gvar); PM_CheckMainMem(&gvar); PM_UnlockMainMem(&gvar);\r
-//0000         printf("PM Started\n"); printf("press any key to continue!\n"); getch();\r
-#ifdef __DEBUG_PM__\r
-       }\r
-#endif\r
-#endif\r
-\r
-#ifdef __DEBUG_MM__\r
-       dbg_debugmm=0;\r
-#endif\r
-       CA_Startup(&gvar);\r
-//     printf("                done!\n");\r
-#ifdef PRINTBBDUMP\r
-//0000\r
-PRINTBB; printf("\n\npress any key to continue!\n"); getch();\r
-#endif\r
 #ifdef __DEBUG_MM__\r
        dbg_debugmm=1;\r
 #endif\r
 \r
+       if(argv[1]){ strcpy(bakapee1, argv[1]);//bakapee1[] = *argv[1];\r
+       if(argv[2]) strcpy(bakapee2, argv[2]); }//bakapee2[] = argv[2]; }\r
+\r
+       printf("bakapee1[%s]\n", bakapee1);\r
+       printf("bakapee2[%s]\n", bakapee2);\r
+                                                               #ifdef EXMMVERBOSE__\r
+       printf("coreleft():             %u\n", coreleft());\r
+       printf("farcoreleft():          %ld\n", farcoreleft());\r
+                                                               #endif\r
+       printf("stackavail()=%u\n", stackavail());\r
+       KEYP\r
+\r
+                                                               #ifndef NOVID\r
+       Startup16(&gvar);\r
+       // save the palette\r
+       modexPalSave(&gvar.video.dpal); //modexFadeOff(4, &gvar.video.dpal); //modexPalBlack();\r
+                                                               #else //NOVID\r
+       StartupCAMMPM(&gvar);\r
+                                                               #endif //elsed NOVID\r
+                                                               #ifdef PRINTBBDUMP\r
+                                                               //0000\r
+PRINTBB; KEYP\r
+                                                               #endif\r
+\r
+       IN_Default(0,&gvar.player[0],ctrl_Keyboard1, &gvar);\r
+       IN_SetControlType(&gvar.player[0],ctrl_Keyboard1);\r
+\r
+       {\r
+       byte w; word baka;\r
        w=0;\r
-#ifdef FILEREADLOAD\r
-#ifdef FILEREAD\r
+                                                               #ifdef FILEREADLOAD\r
+                                                               #ifdef FILEREAD\r
        for(;w<2;w++)\r
        {\r
        //      printf("size of big buffer~=%u\n", _bmsize(segu, BBUF));\r
@@ -187,100 +170,170 @@ PRINTBB; printf("\n\npress any key to continue!\n"); getch();
                        if(CA_ReadFile(bakapee2, BBUFPTR, &gvar)) baka=1; else baka=0;\r
                        printf("====================================read end===================================\n");\r
                }\r
-#endif\r
+                                                               #endif //FILEREAD\r
                if(w==0)\r
                {\r
                        printf("======================================load=====================================\n");\r
                        if(CA_LoadFile(bakapee1, BBUFPTR, &gvar)) baka=1; else baka=0;\r
                        printf("====================================load end===================================\n");\r
                }\r
-//#ifdef __WATCOMC__\r
-//     printf("\nsize of big buffer~=%u\n", _bmsize(sega, BBUF));\r
-//#endif\r
-#ifdef BUFFDUMP\r
-               printf("contents of the buffer\n[\n%s\n]\n", BBUFSTRING);\r
-#endif// #else\r
-#ifdef PRINTBBDUMP\r
-               PRINTBB;\r
+                                                               #ifdef BUFFDUMP\r
+               {\r
+                       size_t file_s;\r
+                       FILE *fh;\r
+\r
+                       if(!w)  fh = fopen(bakapee1, "r");\r
+                       else    fh = fopen(bakapee2, "r");\r
+                       file_s = filesize(fh);\r
+                       fclose(fh);\r
+               printf("contents of the buffer\n[\n%.*s\n]\n", file_s, BBUFSTRING);\r
+#if 0\r
+//0000\r
+//                     mmblocktype far *scan;\r
+//                     scan = gvar.mm.mmhead;\r
+//                     while (scan->useptr != &BBUFNAME && scan)\r
+//                     {\r
+//                             scan = scan->next;\r
+//                     }\r
+//                     printf("\n      %Fp     %Fp\n", scan->useptr, &BBUFNAME);\r
+                       printf("\nstrlen of buffer = %zu\n", strlen(BBUFSTRING));\r
+                       printf("length of buffer = %zu\n", file_s);\r
+//                     printf("length of buffer = %lu\n", scan->length);\r
 #endif\r
-//endif // BUFFDUMP\r
+               }\r
+                                                               #endif\r
+                                                               #ifdef PRINTBBDUMP\r
+               PRINTBB;\r
+                                                               #endif\r
 \r
                //printf("dark purple = purgable\n");\r
                //printf("medium blue = non purgable\n");\r
                //printf("red = locked\n");\r
-       //      printf("press any key to continue!\n");\r
+       //      KEYP\r
        //      DebugMemory_(&gvar, 1);\r
                if(baka) printf("\nyay!\n");\r
                else printf("\npoo!\n");\r
-#ifdef BUFFDUMPPAUSE\r
-               printf("press any key to continue!\n"); getch();\r
-#endif\r
-#ifdef FILEREAD\r
+                                                               #ifdef BUFFDUMPPAUSE\r
+               KEYP\r
+                                                               #endif\r
+                                                               #ifdef FILEREAD\r
+       }\r
+                                                               #endif\r
+                                                               #endif  //filereadload\r
        }\r
-#endif\r
-#ifndef BUFFDUMPPAUSE\r
-       printf("press any key to continue!\n"); getch();\r
-#endif\r
-#endif //filereadload\r
-\r
 \r
-/*#ifdef __WATCOMC__\r
-       IN_Startup(&gvar);\r
-       ShapeTest_(&gvar);\r
-       IN_Shutdown(&gvar);\r
-#endif*/\r
+                                                       #ifdef SCROLLLOAD\r
+       CA_loadmap(bakapee2, &gvar.map, &gvar); //BREAKS!\r
+//     newloadmap(bakapee2, &gvar.map);\r
+       VRS_LoadVRS(bakapee1, &gvar.player[0].enti, &gvar);\r
+//     HC_heapdump(&gvar);\r
+       KEYP\r
+                                                       #endif  //scrollload\r
 \r
+#ifndef NOVID\r
+       VGAmodeX(8, 0, &gvar); VL_LoadPalFileCore(&gvar.video.palette, &gvar);\r
+       VL_ClearVideo (0);\r
+       modexHiganbanaPageSetup(&gvar);\r
+       gvar.video.page[0].dx = gvar.video.page[0].dy = 0;\r
+//     VL_modexPalScramble(&gvar.video.palette);\r
+       {\r
+               unsigned temp;\r
+               temp = BDOFSCONV gvar.video.BOFS;\r
+               gvar.video.BOFS = gvar.video.DOFS;\r
+               MU_IntroScreen(&gvar);\r
+               gvar.video.BOFS = (byte __far *)temp;\r
+       }\r
+//     ShapeTest_(&gvar);\r
+#endif\r
+//0000++++     MM_ShowMemory(&gvar);\r
+#if 0\r
+       {\r
+       boolean                 done;\r
+       ScanCode                scan;\r
+       for (done = false;!done;)\r
+       {\r
+               while (!(scan = gvar.in.inst->LastScan))\r
+               {}\r
+       //                      SD_Poll();\r
 \r
+               IN_ClearKey(scan);\r
+               switch (scan)\r
+               {\r
+//                     case sc_Space:\r
+//                             MM_ShowMemory(&gvar);\r
+//                     break;\r
+//#ifdef __WATCOMC__\r
+                       case sc_O:\r
+                               VL_modexPalScramble(&gvar.video.palette); modexpdump(&gvar.video.page);\r
+                       break;\r
+                       case sc_P:\r
+                               modexpdump(&gvar.video.page[0]);\r
+                       break;\r
+                       case sc_V:\r
+                               VL_PatternDraw(&gvar.video, 0, 1, 1);\r
+                       break;\r
+//#endif\r
+                       default:\r
+                       case sc_Escape:\r
+                               done = true;\r
+                       break;\r
+               }\r
+       }\r
+}\r
+#endif\r
+#ifndef NOVID\r
+       if(gvar.video.VL_Started)\r
+               VL_Shutdown (&gvar);//VGAmodeX(0, 0, gvar);\r
+       modexFadeOn(4, gvar.video.dpal);\r
+#endif\r
        DebugMemory_(&gvar, 1);\r
        MM_DumpData(&gvar);\r
+       KEYP\r
        MM_Report_(&gvar);\r
        //printf("bakapee1=%s\n", bakapee1);\r
        //printf("bakapee2=%s\n", bakapee2);\r
        MM_FreePtr(BBUFPTR, &gvar);\r
-#ifdef __16_PM__\r
-#ifdef __DEBUG_PM__\r
-       if(dbg_debugpm>0)\r
-#endif\r
-               PM_Shutdown(&gvar);\r
-#endif\r
-       CA_Shutdown(&gvar);\r
-       MM_Shutdown(&gvar);\r
-       free(bakapee1); free(bakapee2);\r
+                                                               #ifndef NOVID\r
+       Shutdown16(&gvar);\r
+                                                               #else //novid\r
+       ShutdownCAMMPM(&gvar);\r
+                                                               #endif //NOVID\r
+       IN_Shutdown(&gvar);\r
        printf("========================================\n");\r
-       printf("near=   %Fp ", gvar.mm.nearheap);\r
-       printf("far=    %Fp", gvar.mm.farheap);\r
+       printf("near=   %Fp ",  gvar.mm.nearheap);\r
+       printf("far=    %Fp",                   gvar.mm.farheap);\r
        printf("\n");\r
-       printf("&near=  %Fp ", &(gvar.mm.nearheap));\r
-       printf("&far=   %Fp", &(gvar.mm.farheap));\r
+       printf("&near=  %Fp ",  &(gvar.mm.nearheap));\r
+       printf("&far=   %Fp",           &(gvar.mm.farheap));\r
        printf("\n");\r
-#ifdef EXMMVERBOSE\r
-       printf("bigb=   %Fp ", BBUF);\r
-       //printf("bigbr=        %04x", BBUF);\r
+                                                               #ifdef EXMMVERBOSE\r
+       printf("bigb=   %Fp ",  BBUF);\r
+       //printf("bigbr=        %04x",  BBUF);\r
        //printf("\n");\r
-       printf("&bigb=%Fp ", BBUFPTR);\r
-       //printf("&bigb=%04x", BBUFPTR);\r
+       printf("&bigb=%Fp ",            BBUFPTR);\r
+       //printf("&bigb=%04x",          BBUFPTR);\r
        printf("\n");\r
-#endif\r
+                                                               #endif\r
        printf("========================================\n");\r
 \r
-#ifdef EXMMVERBOSE__\r
-       printf("coreleft():                     %u\n", _memavl());\r
-       printf("farcoreleft():                  %lu\n", (dword)HC_farcoreleft());\r
-#endif\r
+                                                               #ifdef EXMMVERBOSE__\r
+       printf("coreleft():             %u\n", coreleft());\r
+       printf("farcoreleft():          %ld\n", farcoreleft());\r
+                                                               #endif\r
 #ifdef __WATCOMC__\r
 //this is far  printf("Total free:                     %lu\n", (dword)(HC_GetFreeSize()));\r
 //super buggy  printf("HC_coreleft():                  %u\n", HC_coreleft());\r
 //     printf("HC_farcoreleft():                       %lu\n", (dword)HC_farcoreleft());\r
        //printf("HC_GetNearFreeSize():         %u\n", HC_GetNearFreeSize());\r
        //printf("HC_GetFarFreeSize():                  %lu\n", (dword)HC_GetFarFreeSize());\r
-       HC_heapdump(&gvar);\r
 //     segatesuto();\r
 #endif\r
-/*#ifdef __BORLANDC__\r
-       //printf("core left:                    %lu\n", (dword)HC_coreleft());\r
-       //printf("far core left:                        %lu\n", (dword)HC_farcoreleft());\r
-//     printf("\nfarcoreleft():                        %lu\n", farcoreleft());\r
-#endif*/\r
+#ifdef __BORLANDC__\r
+//     printf("HC_coreleft:                    %lu\n", (dword)HC_coreleft());\r
+//     printf("HC_farcoreleft:                 %lu\n", (dword)HC_farcoreleft());\r
+//     printf("HC_Newfarcoreleft():            %lu\n", (dword)HC_Newfarcoreleft());\r
+#endif\r
+       HC_heapdump(&gvar);\r
        printf("Project 16 ");\r
 #ifdef __WATCOMC__\r
        printf("exmmtest");\r
@@ -290,6 +343,10 @@ PRINTBB; printf("\n\npress any key to continue!\n"); getch();
 #endif\r
        printf(".exe. This is just a test file!\n");\r
        printf("version %s\n", VERSION);\r
+\r
+//end of program\r
+\r
+\r
 #if defined(__DEBUG__) && ( defined(__DEBUG_PM__) || defined(__DEBUG_MM__) )\r
 #ifdef __DEBUG_MM__\r
        printf("debugmm: %u\t", dbg_debugmm);\r
@@ -299,6 +356,9 @@ PRINTBB; printf("\n\npress any key to continue!\n"); getch();
 #endif\r
        printf("\n");\r
 #endif\r
+//     printf("curr_mode=%u\n", gvar.video.curr_mode);\r
+//     VL_PrintmodexmemInfo(&gvar.video);\r
+       //printf("old_mode=%u   VL_Started=%u", gvar.video.old_mode, gvar.video.VL_Started);\r
        //printf("based core left:                      %lu\n", (dword)_basedcoreleft());\r
        //printf("huge core left:                       %lu\n", (dword)_hugecoreleft());\r
 }\r