OSDN Git Service

fixed bcexmm.exe but will work on it later
[proj16/16.git] / src / exmmtest.c
1 /* Project 16 Source Code~\r
2  * Copyright (C) 2012-2021 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover\r
3  *\r
4  * This file is part of Project 16.\r
5  *\r
6  * Project 16 is free software; you can redistribute it and/or modify\r
7  * it under the terms of the GNU General Public License as published by\r
8  * the Free Software Foundation; either version 3 of the License, or\r
9  * (at your option) any later version.\r
10  *\r
11  * Project 16 is distributed in the hope that it will be useful,\r
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
14  * GNU General Public License for more details.\r
15  *\r
16  * You should have received a copy of the GNU General Public License\r
17  * along with this program.  If not, see <http://www.gnu.org/licenses/>, or\r
18  * write to the Free Software Foundation, Inc., 51 Franklin Street,\r
19  * Fifth Floor, Boston, MA 02110-1301 USA.\r
20  *\r
21  */\r
22 /*\r
23         exmm test\r
24 */\r
25 #include "src/exmmtest.h"\r
26 \r
27 ////////////////////////////////////////////////////////////////////////////\r
28 #ifdef NOVID\r
29 void VL_Startup (global_game_variables_t *gvar){ gvar=gvar; }\r
30 void VL_Shutdown (global_game_variables_t *gvar){ gvar=gvar; }\r
31 void VGAmodeX(sword vq, boolean cmem, global_game_variables_t *gv)\r
32 {\r
33         printf("VGAmodeX dummy:\n       %Fp     %Fp     %Fp\n", &vq, &cmem, gv);\r
34 }\r
35 \r
36 word\r
37 VL_modexPalOverscan(byte *p, word col)\r
38 {\r
39         int i;\r
40         //modexWaitBorder();\r
41 //      vga_wait_for_vsync();\r
42         outp(PAL_WRITE_REG, 0);  /* start at the beginning of palette */\r
43         for(i=col; i<(3+col); i++)\r
44         {\r
45                 outp(PAL_DATA_REG, p[i]);\r
46         }\r
47 //      modexPalSave(p);\r
48         return col;\r
49 }\r
50 void    TL_VidInit(global_game_variables_t *gvar)\r
51 {\r
52         gvar->video.old_mode = 3;\r
53 }\r
54 \r
55 void VL_print(const byte *str, nibble pagenum, global_game_variables_t *gvar){ printf("%s\n", str); }\r
56 \r
57 #ifdef __WATCOMC__\r
58 void VL_ShowPage(page_t *page, boolean vsync, boolean sr){}\r
59 void modexClearRegion(page_t *page, int x, int y, int w, int h, byte color){}\r
60 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
61 void modexpdump(nibble pagenum, global_game_variables_t *gvar){}\r
62 #endif\r
63 #endif\r
64 \r
65 #ifdef __WATCOMC__\r
66 void segatesuto()\r
67 {\r
68         __segment screen;\r
69         char __based( void ) * scrptr;\r
70 \r
71         screen = 0xB800;\r
72         scrptr = 0;\r
73         printf( "Top left character is '%c'.\n", *(screen:>scrptr) );\r
74 //      printf("Next string is: [");\r
75 //      while(*scrptr<16)\r
76 //      {\r
77 //              printf("%c", *(screen:>scrptr));\r
78 //              //printf("\b");\r
79 //              scrptr++;\r
80 //\r
81 //      }\r
82 //      printf("]\n");\r
83 //      KEYP\r
84 }\r
85 #endif\r
86 \r
87 #ifdef SCROLLLOAD\r
88 #define FILENAME_1      "data/spri/chikyuu.vrs"\r
89 #define FILENAME_2      "data/test.map"\r
90 #else\r
91 #define FILENAME_1      "data/spri/chikyuu.sht"\r
92 #define FILENAME_2      "data/test.map"\r
93 #endif\r
94 \r
95 //===========================================================================//\r
96 \r
97 //=======================================//\r
98 \r
99 //      main\r
100 \r
101 //=======================================//\r
102 void\r
103 main(int argc, char *argv[])\r
104 {\r
105         static global_game_variables_t gvar;\r
106                                                                 #ifdef INITBBUF\r
107         INITBBUF\r
108                                                                 #endif\r
109 \r
110         char bakapee1[64] = FILENAME_1;\r
111         char bakapee2[64] = FILENAME_2;\r
112 \r
113                 #ifdef __BORLANDC__\r
114                         argc=argc;\r
115                 #endif\r
116 \r
117                                                                 #ifdef PRINTBBDUMP\r
118                                                                 //0000PRINTBB; KEYP\r
119                                                                 #endif\r
120 #ifdef __16_PM__\r
121 #ifdef __DEBUG_PM__\r
122         dbg_debugpm=1;  //debug pm\r
123 #endif\r
124 #endif\r
125 #ifdef __DEBUG_CA__\r
126         dbg_debugca=1;\r
127 #endif\r
128 #ifdef __DEBUG_MM__\r
129         dbg_debugmm=1;\r
130 #endif\r
131 \r
132         if(argv[1]){ strcpy(bakapee1, argv[1]);//bakapee1[] = *argv[1];\r
133         if(argv[2]) strcpy(bakapee2, argv[2]); }//bakapee2[] = argv[2]; }\r
134 \r
135         printf("bakapee1[%s]\n", bakapee1);\r
136         printf("bakapee2[%s]\n", bakapee2);\r
137                                                                 #ifdef EXMMVERBOSE__\r
138         printf("coreleft():             %u\n", coreleft());\r
139         printf("farcoreleft():          %ld\n", farcoreleft());\r
140                                                                 #endif\r
141         printf("stackavail()=%u\n", stackavail());\r
142         KEYP\r
143 \r
144                                                                 #ifndef NOVID\r
145         Startup16(&gvar);\r
146         // save the palette\r
147         modexPalSave(&gvar.video.dpal); //modexFadeOff(4, &gvar.video.dpal); //modexPalBlack();\r
148                                                                 #else //NOVID\r
149         StartupCAMMPM(&gvar);\r
150                                                                 #endif //elsed NOVID\r
151                                                                 #ifdef PRINTBBDUMP\r
152                                                                 //0000\r
153 PRINTBB; KEYP\r
154                                                                 #endif\r
155 \r
156         IN_Default(0,&gvar.player[0],ctrl_Keyboard1, &gvar);\r
157         IN_SetControlType(&gvar.player[0],ctrl_Keyboard1);\r
158 \r
159         {\r
160         byte w; word baka;\r
161         w=0;\r
162                                                                 #ifdef FILEREADLOAD\r
163                                                                 #ifdef FILEREAD\r
164         for(;w<2;w++)\r
165         {\r
166         //      printf("size of big buffer~=%u\n", _bmsize(segu, BBUF));\r
167                 if(w>0)\r
168                 {\r
169                         printf("======================================read=====================================\n");\r
170                         if(CA_ReadFile(bakapee2, BBUFPTR, &gvar)) baka=1; else baka=0;\r
171                         printf("====================================read end===================================\n");\r
172                 }\r
173                                                                 #endif //FILEREAD\r
174                 if(w==0)\r
175                 {\r
176                         printf("======================================load=====================================\n");\r
177                         if(CA_LoadFile(bakapee1, BBUFPTR, &gvar)) baka=1; else baka=0;\r
178                         printf("====================================load end===================================\n");\r
179                 }\r
180                                                                 #ifdef BUFFDUMP\r
181                 {\r
182                         size_t file_s;\r
183                         FILE *fh;\r
184 \r
185                         if(!w)  fh = fopen(bakapee1, "r");\r
186                         else    fh = fopen(bakapee2, "r");\r
187                         file_s = filesize(fh);\r
188                         fclose(fh);\r
189                 printf("contents of the buffer\n[\n%.*s\n]\n", file_s, BBUFSTRING);\r
190 #if 0\r
191 //0000\r
192 //                      mmblocktype far *scan;\r
193 //                      scan = gvar.mm.mmhead;\r
194 //                      while (scan->useptr != &BBUFNAME && scan)\r
195 //                      {\r
196 //                              scan = scan->next;\r
197 //                      }\r
198 //                      printf("\n      %Fp     %Fp\n", scan->useptr, &BBUFNAME);\r
199                         printf("\nstrlen of buffer = %zu\n", strlen(BBUFSTRING));\r
200                         printf("length of buffer = %zu\n", file_s);\r
201 //                      printf("length of buffer = %lu\n", scan->length);\r
202 #endif\r
203                 }\r
204                                                                 #endif\r
205                                                                 #ifdef PRINTBBDUMP\r
206                 PRINTBB;\r
207                                                                 #endif\r
208 \r
209                 //printf("dark purple = purgable\n");\r
210                 //printf("medium blue = non purgable\n");\r
211                 //printf("red = locked\n");\r
212         //      KEYP\r
213         //      DebugMemory_(&gvar, 1);\r
214                 if(baka) printf("\nyay!\n");\r
215                 else printf("\npoo!\n");\r
216                                                                 #ifdef BUFFDUMPPAUSE\r
217                 KEYP\r
218                                                                 #endif\r
219                                                                 #ifdef FILEREAD\r
220         }\r
221                                                                 #endif\r
222                                                                 #endif  //filereadload\r
223         }\r
224 \r
225                                                         #ifdef SCROLLLOAD\r
226         CA_loadmap(bakapee2, &gvar.map, &gvar); //BREAKS!\r
227 //      newloadmap(bakapee2, &gvar.map);\r
228         VRS_LoadVRS(bakapee1, &gvar.player[0].enti, &gvar);\r
229 //      HC_heapdump(&gvar);\r
230         KEYP\r
231                                                         #endif  //scrollload\r
232 \r
233 #ifndef NOVID\r
234         VGAmodeX(8, 0, &gvar); VL_LoadPalFileCore(&gvar.video.palette, &gvar);\r
235         VL_ClearVideo (0);\r
236         modexHiganbanaPageSetup(&gvar);\r
237         gvar.video.page[0].dx = gvar.video.page[0].dy = 0;\r
238 //      VL_modexPalScramble(&gvar.video.palette);\r
239         {\r
240                 unsigned temp;\r
241                 temp = BDOFSCONV gvar.video.BOFS;\r
242                 gvar.video.BOFS = gvar.video.DOFS;\r
243                 MU_IntroScreen(&gvar);\r
244                 gvar.video.BOFS = (byte __far *)temp;\r
245         }\r
246 //      ShapeTest_(&gvar);\r
247 #endif\r
248 //0000++++\r
249         MM_ShowMemory(&gvar);\r
250 #if 0\r
251         {\r
252         boolean                 done;\r
253         ScanCode                scan;\r
254         for (done = false;!done;)\r
255         {\r
256                 while (!(scan = gvar.in.inst->LastScan))\r
257                 {}\r
258         //                      SD_Poll();\r
259 \r
260                 IN_ClearKey(scan);\r
261                 switch (scan)\r
262                 {\r
263 //                      case sc_Space:\r
264 //                              MM_ShowMemory(&gvar);\r
265 //                      break;\r
266 //#ifdef __WATCOMC__\r
267                         case sc_O:\r
268                                 VL_modexPalScramble(&gvar.video.palette); modexpdump(&gvar.video.page);\r
269                         break;\r
270                         case sc_P:\r
271                                 modexpdump(&gvar.video.page[0]);\r
272                         break;\r
273                         case sc_V:\r
274                                 VL_PatternDraw(&gvar.video, 0, 1, 1);\r
275                         break;\r
276 //#endif\r
277                         default:\r
278                         case sc_Escape:\r
279                                 done = true;\r
280                         break;\r
281                 }\r
282         }\r
283 }\r
284 #endif\r
285 #ifndef NOVID\r
286         if(gvar.video.VL_Started)\r
287                 VL_Shutdown (&gvar);//VGAmodeX(0, 0, gvar);\r
288         modexFadeOn(4, gvar.video.dpal);\r
289 #endif\r
290         DebugMemory_(&gvar, 1);\r
291         MM_DumpData(&gvar);\r
292         KEYP\r
293         MM_Report_(&gvar);\r
294         //printf("bakapee1=%s\n", bakapee1);\r
295         //printf("bakapee2=%s\n", bakapee2);\r
296         MM_FreePtr(BBUFPTR, &gvar);\r
297                                                                 #ifndef NOVID\r
298         Shutdown16(&gvar);\r
299                                                                 #else //novid\r
300         ShutdownCAMMPM(&gvar);\r
301                                                                 #endif //NOVID\r
302         IN_Shutdown(&gvar);\r
303         printf("========================================\n");\r
304         printf("near=   %Fp ",  gvar.mm.nearheap);\r
305         printf("far=    %Fp",                   gvar.mm.farheap);\r
306         printf("\n");\r
307         printf("&near=  %Fp ",  &(gvar.mm.nearheap));\r
308         printf("&far=   %Fp",           &(gvar.mm.farheap));\r
309         printf("\n");\r
310                                                                 #ifdef EXMMVERBOSE\r
311         printf("bigb=   %Fp ",  BBUF);\r
312         //printf("bigbr=        %04x",  BBUF);\r
313         //printf("\n");\r
314         printf("&bigb=%Fp ",            BBUFPTR);\r
315         //printf("&bigb=%04x",          BBUFPTR);\r
316         printf("\n");\r
317                                                                 #endif\r
318         printf("========================================\n");\r
319 \r
320                                                                 #ifdef EXMMVERBOSE__\r
321         printf("coreleft():             %u\n", coreleft());\r
322         printf("farcoreleft():          %ld\n", farcoreleft());\r
323                                                                 #endif\r
324 #ifdef __WATCOMC__\r
325 //this is far   printf("Total free:                     %lu\n", (dword)(HC_GetFreeSize()));\r
326 //super buggy   printf("HC_coreleft():                  %u\n", HC_coreleft());\r
327 //      printf("HC_farcoreleft():                       %lu\n", (dword)HC_farcoreleft());\r
328         //printf("HC_GetNearFreeSize():         %u\n", HC_GetNearFreeSize());\r
329         //printf("HC_GetFarFreeSize():                  %lu\n", (dword)HC_GetFarFreeSize());\r
330 //      segatesuto();\r
331 #endif\r
332 #ifdef __BORLANDC__\r
333 //      printf("HC_coreleft:                    %lu\n", (dword)HC_coreleft());\r
334 //      printf("HC_farcoreleft:                 %lu\n", (dword)HC_farcoreleft());\r
335 //      printf("HC_Newfarcoreleft():            %lu\n", (dword)HC_Newfarcoreleft());\r
336 #endif\r
337         HC_heapdump(&gvar);\r
338         printf("Project 16 ");\r
339 #ifdef __WATCOMC__\r
340         printf("exmmtest");\r
341 #endif\r
342 #ifdef __BORLANDC__\r
343         printf("bcexmm");\r
344 #endif\r
345         printf(".exe. This is just a test file!\n");\r
346         printf("version %s\n", VERSION);\r
347 \r
348 //end of program\r
349 \r
350 \r
351 #if defined(__DEBUG__) && ( defined(__DEBUG_PM__) || defined(__DEBUG_MM__) )\r
352 #ifdef __DEBUG_MM__\r
353         printf("debugmm: %u\t", dbg_debugmm);\r
354 #endif\r
355 #ifdef __DEBUG_PM__\r
356         printf("debugpm: %u", dbg_debugpm);\r
357 #endif\r
358         printf("\n");\r
359 #endif\r
360 //      printf("curr_mode=%u\n", gvar.video.curr_mode);\r
361 //      VL_PrintmodexmemInfo(&gvar.video);\r
362         //printf("old_mode=%u   VL_Started=%u", gvar.video.old_mode, gvar.video.VL_Started);\r
363         //printf("based core left:                      %lu\n", (dword)_basedcoreleft());\r
364         //printf("huge core left:                       %lu\n", (dword)_hugecoreleft());\r
365 }\r