/* Project 16 Source Code~\r
- * Copyright (C) 2012-2016 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover\r
+ * Copyright (C) 2012-2019 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover\r
*\r
* This file is part of Project 16.\r
*\r
/*\r
exmm test\r
*/\r
-#include "src/lib/16_head.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_lib.h"\r
-//#include "src/lib/modex16.h"\r
-#pragma hdrstop\r
+#include "src/exmmtest.h"\r
\r
-#pragma warn -pro\r
-#pragma warn -use\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
+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
\r
-//file load or read definition\r
-#define FILEREAD\r
-//#define EXMMVERBOSE\r
+void VL_print(const byte *str, nibble pagenum, global_game_variables_t *gvar){ printf("%s\n", str); }\r
\r
-#define PRINTBB { printf("&main()= %Fp\n", argv[0]);printf("bigbuffer= %Fp\n", bigbuffer);printf("&bigbuffer= %Fp\n", &bigbuffer);printf("bigbuffer= %04x\n", bigbuffer);printf("&bigbuffer= %04x\n", &bigbuffer); }\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
// }\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=1;\r
- global_game_variables_t gvar;\r
-#ifdef __WATCOMC__\r
- __segment sega;\r
+ static global_game_variables_t gvar;\r
+ #ifdef INITBBUF\r
+ INITBBUF\r
+ #endif\r
+\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
+#ifdef __DEBUG_CA__\r
+ dbg_debugca=1;\r
+#endif\r
+#ifdef __DEBUG_MM__\r
+ dbg_debugmm=1;\r
#endif\r
- memptr bigbuffer;\r
\r
- //static byte bakapee[64];\r
- char *bakapee1, *bakapee2;\r
- word baka;\r
+ if(argv[1]){ strcpy(bakapee1, argv[1]);//bakapee1[] = *argv[1];\r
+ if(argv[2]) strcpy(bakapee2, argv[2]); }//bakapee2[] = argv[2]; }\r
\r
-#ifdef __BORLANDC__\r
- argc=argc;\r
-#endif\r
- //file name //\r
- bakapee1 = malloc(64);\r
- bakapee2 = malloc(64);\r
- //file name //\r
-\r
- gvar.mm.mmstarted=0;\r
- debugpm=1;\r
-\r
- //PRINTBB\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);\r
- if(debugpm>0)\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
+ for(;w<2;w++)\r
{\r
- PM_Startup(&gvar);\r
- //PM_CheckMainMem(&gvar);\r
- PM_UnlockMainMem(&gvar);\r
+ // printf("size of big buffer~=%u\n", _bmsize(segu, BBUF));\r
+ if(w>0)\r
+ {\r
+ printf("======================================read=====================================\n");\r
+ if(CA_ReadFile(bakapee2, BBUFPTR, &gvar)) baka=1; else baka=0;\r
+ printf("====================================read end===================================\n");\r
+ }\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 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
+ }\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
+ // KEYP\r
+ // DebugMemory_(&gvar, 1);\r
+ if(baka) printf("\nyay!\n");\r
+ else printf("\npoo!\n");\r
+ #ifdef BUFFDUMPPAUSE\r
+ KEYP\r
+ #endif\r
+ #ifdef FILEREAD\r
}\r
- CA_Startup(&gvar);\r
-// printf(" done!\n");\r
- PRINTBB;\r
-// printf("press any key to continue!\n");\r
-// getch();\r
-#ifdef FILEREAD\r
-for(w=0;w<2;w++)\r
-{\r
-// bakapeehandle = open(bakapee,O_RDONLY | O_BINARY, S_IREAD);\r
-// printf("size of big buffer~=%u\n", _bmsize(segu, bigbuffer));\r
-// if(CA_FarRead(bakapeehandle,(void far *)&bigbuffer,sizeof(bigbuffer),&gvar.mm))\r
- if(w>0)\r
+ #endif\r
+ #endif //filereadload\r
+ }\r
+\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
- printf(" read\n");\r
- if(CA_ReadFile(bakapee2, &bigbuffer, &gvar)) baka=1; else baka=0;\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
- if(w==0)\r
+ MM_ShowMemory(&gvar);\r
+#if 0\r
+ {\r
+ boolean done;\r
+ ScanCode scan;\r
+ for (done = false;!done;)\r
{\r
- printf(" load\n");\r
- if(CA_LoadFile(bakapee1, &bigbuffer, &gvar)) baka=1; else baka=0;\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
-// close(bakapeehandle);\r
- //hmm functions in cache system use the buffered stuff\r
-#ifdef __WATCOMC__\r
- printf("\nsize of big buffer~=%u\n", _bmsize(sega, bigbuffer));\r
+}\r
#endif\r
-\r
- printf("contents of the buffer\n[\n%s\n]\n", bigbuffer);\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
- getch();\r
- MM_ShowMemory(&gvar);\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
- if(baka) printf("\nyay!\n");\r
- else printf("\npoo!\n");\r
- printf("press any key to continue!\n");\r
- getch();\r
-#ifdef FILEREAD\r
-}\r
-#endif\r
- printf("bakapee1=%s\n", bakapee1);\r
- printf("bakapee2=%s\n", bakapee2);\r
- MM_FreePtr(&bigbuffer, &gvar);\r
- if(debugpm>0)\r
- PM_Shutdown(&gvar);\r
- CA_Shutdown(&gvar);\r
- MM_Shutdown(&gvar);\r
- free(bakapee1); free(bakapee2);\r
+ //printf("bakapee1=%s\n", bakapee1);\r
+ //printf("bakapee2=%s\n", bakapee2);\r
+ MM_FreePtr(BBUFPTR, &gvar);\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 ", bigbuffer);\r
- //printf("bigbr= %04x", bigbuffer);\r
+ #ifdef EXMMVERBOSE\r
+ printf("bigb= %Fp ", BBUF);\r
+ //printf("bigbr= %04x", BBUF);\r
//printf("\n");\r
- printf("&bigb=%Fp ", &bigbuffer);\r
- //printf("&bigb=%04x", &bigbuffer);\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", 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
+// segatesuto();\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
-//this is far printf("Total free: %lu\n", (dword)(GetFreeSize()));\r
- printf("Total near free: %lu\n", (dword)(GetNearFreeSize()));\r
- printf("Total far free: %lu\n", (dword)(GetFarFreeSize()));\r
- heapdump(&gvar);\r
- segatesuto();\r
+ printf("exmmtest");\r
+#endif\r
+#ifdef __BORLANDC__\r
+ printf("bcexmm");\r
#endif\r
- printf("Project 16 emmtest.exe. This is just a test file!\n");\r
+ printf(".exe. This is just a test file!\n");\r
printf("version %s\n", VERSION);\r
- //printf("core left: %lu\n", (dword)_coreleft());\r
- //printf("far core left: %lu\n", (dword)_farcoreleft());\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
+#endif\r
+#ifdef __DEBUG_PM__\r
+ printf("debugpm: %u", dbg_debugpm);\r
+#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