OSDN Git Service

the original file combo on the exmmtest.exe seems to crash the XT. it never crashes...
[proj16/16.git] / src / exmmtest.c
1 /* Project 16 Source Code~\r
2  * Copyright (C) 2012-2017 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 #ifdef __WATCOMC__\r
56 void VL_ShowPage(page_t *page, boolean vsync, boolean sr){}\r
57 void modexClearRegion(page_t *page, int x, int y, int w, int h, byte color){}\r
58 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
59 void VL_print(const byte *str, nibble pagenum, global_game_variables_t *gvar){ printf("%s\n", str); }\r
60 void modexpdump(nibble pagenum, global_game_variables_t *gvar){}\r
61 #endif\r
62 #endif\r
63 \r
64 #ifdef __WATCOMC__\r
65 void segatesuto()\r
66 {\r
67         __segment screen;\r
68         char __based( void ) * scrptr;\r
69 \r
70         screen = 0xB800;\r
71         scrptr = 0;\r
72         printf( "Top left character is '%c'.\n", *(screen:>scrptr) );\r
73 //      printf("Next string is: [");\r
74 //      while(*scrptr<16)\r
75 //      {\r
76 //              printf("%c", *(screen:>scrptr));\r
77 //              //printf("\b");\r
78 //              scrptr++;\r
79 //\r
80 //      }\r
81 //      printf("]\n");\r
82 //      KEYP\r
83 }\r
84 #endif\r
85 \r
86 #ifdef SCROLLLOAD\r
87 #define FILENAME_1      "data/spri/chikyuu.vrs"\r
88 #define FILENAME_2      "data/test.map"\r
89 #else\r
90 #define FILENAME_1      "data/spri/chikyuu.sht"\r
91 #define FILENAME_2      "data/test.map"\r
92 #endif\r
93 \r
94 //===========================================================================//\r
95 \r
96 //=======================================//\r
97 \r
98 //      main\r
99 \r
100 //=======================================//\r
101 void\r
102 main(int argc, char *argv[])\r
103 {\r
104         static global_game_variables_t gvar;\r
105                                                                 #ifdef INITBBUF\r
106         INITBBUF\r
107                                                                 #endif\r
108 \r
109         char bakapee1[64] = FILENAME_1;\r
110         char bakapee2[64] = FILENAME_2;\r
111 \r
112                 #ifdef __BORLANDC__\r
113                         argc=argc;\r
114                 #endif\r
115 \r
116                                                                 #ifdef PRINTBBDUMP\r
117                                                                 //0000PRINTBB; KEYP\r
118                                                                 #endif\r
119 #ifdef __16_PM__\r
120 #ifdef __DEBUG_PM__\r
121         dbg_debugpm=1;  //debug pm\r
122 #endif\r
123 #endif\r
124 #ifdef __DEBUG_CA__\r
125         dbg_debugca=1;\r
126 #endif\r
127 #ifdef __DEBUG_MM__\r
128         dbg_debugmm=1;\r
129 #endif\r
130 \r
131         if(argv[1]){ strcpy(bakapee1, argv[1]);//bakapee1[] = *argv[1];\r
132         if(argv[2]) strcpy(bakapee2, argv[2]); }//bakapee2[] = argv[2]; }\r
133 \r
134         printf("bakapee1[%s]\n", bakapee1);\r
135         printf("bakapee2[%s]\n", bakapee2);\r
136                                                                 #ifdef EXMMVERBOSE__\r
137         printf("coreleft():             %u\n", coreleft());\r
138         printf("farcoreleft():          %ld\n", farcoreleft());\r
139                                                                 #endif\r
140         printf("stackavail()=%u\n", stackavail());\r
141         KEYP\r
142 \r
143                                                                 #ifndef NOVID\r
144         Startup16(&gvar);\r
145         // save the palette\r
146         modexPalSave(&gvar.video.dpal); //modexFadeOff(4, &gvar.video.dpal); //modexPalBlack();\r
147                                                                 #else //NOVID\r
148         StartupCAMMPM(&gvar);\r
149                                                                 #endif //elsed NOVID\r
150                                                                 #ifdef PRINTBBDUMP\r
151                                                                 //0000\r
152 PRINTBB; KEYP\r
153                                                                 #endif\r
154 \r
155         IN_Default(0,&gvar.player[0],ctrl_Keyboard1, &gvar);\r
156         IN_SetControlType(&gvar.player[0],ctrl_Keyboard1);\r
157 \r
158         {\r
159         byte w; word baka;\r
160         w=0;\r
161                                                                 #ifdef FILEREADLOAD\r
162                                                                 #ifdef FILEREAD\r
163         for(;w<2;w++)\r
164         {\r
165         //      printf("size of big buffer~=%u\n", _bmsize(segu, BBUF));\r
166                 if(w>0)\r
167                 {\r
168                         printf("======================================read=====================================\n");\r
169                         if(CA_ReadFile(bakapee2, BBUFPTR, &gvar)) baka=1; else baka=0;\r
170                         printf("====================================read end===================================\n");\r
171                 }\r
172                                                                 #endif //FILEREAD\r
173                 if(w==0)\r
174                 {\r
175                         printf("======================================load=====================================\n");\r
176                         if(CA_LoadFile(bakapee1, BBUFPTR, &gvar)) baka=1; else baka=0;\r
177                         printf("====================================load end===================================\n");\r
178                 }\r
179                                                                 #ifdef BUFFDUMP\r
180                 {\r
181                         size_t file_s;\r
182                         FILE *fh;\r
183 \r
184                         if(!w)  fh = fopen(bakapee1, "r");\r
185                         else    fh = fopen(bakapee2, "r");\r
186                         file_s = filesize(fh);\r
187                         fclose(fh);\r
188                 printf("contents of the buffer\n[\n%.*s\n]\n", file_s, BBUFSTRING);\r
189 #if 0\r
190 //0000\r
191 //                      mmblocktype far *scan;\r
192 //                      scan = gvar.mm.mmhead;\r
193 //                      while (scan->useptr != &BBUFNAME && scan)\r
194 //                      {\r
195 //                              scan = scan->next;\r
196 //                      }\r
197 //                      printf("\n      %Fp     %Fp\n", scan->useptr, &BBUFNAME);\r
198                         printf("\nstrlen of buffer = %zu\n", strlen(BBUFSTRING));\r
199                         printf("length of buffer = %zu\n", file_s);\r
200 //                      printf("length of buffer = %lu\n", scan->length);\r
201 #endif\r
202                 }\r
203                                                                 #endif\r
204                                                                 #ifdef PRINTBBDUMP\r
205                 PRINTBB;\r
206                                                                 #endif\r
207 \r
208                 //printf("dark purple = purgable\n");\r
209                 //printf("medium blue = non purgable\n");\r
210                 //printf("red = locked\n");\r
211         //      KEYP\r
212         //      DebugMemory_(&gvar, 1);\r
213                 if(baka) printf("\nyay!\n");\r
214                 else printf("\npoo!\n");\r
215                                                                 #ifdef BUFFDUMPPAUSE\r
216                 KEYP\r
217                                                                 #endif\r
218                                                                 #ifdef FILEREAD\r
219         }\r
220                                                                 #endif\r
221                                                                 #endif  //filereadload\r
222         }\r
223 \r
224                                                         #ifdef SCROLLLOAD\r
225         CA_loadmap(bakapee2, &gvar.map, &gvar); //BREAKS!\r
226 //      newloadmap(bakapee2, &gvar.map);\r
227         VRS_LoadVRS(bakapee1, &gvar.player[0].enti, &gvar);\r
228 //      HC_heapdump(&gvar);\r
229         KEYP\r
230                                                         #endif  //scrollload\r
231 \r
232 #ifndef NOVID\r
233         VGAmodeX(8, 0, &gvar); VL_LoadPalFileCore(&gvar.video.palette, &gvar);\r
234         VL_ClearVideo (0);\r
235         modexHiganbanaPageSetup(&gvar);\r
236         gvar.video.page[0].dx = gvar.video.page[0].dy = 0;\r
237 //      VL_modexPalScramble(&gvar.video.palette);\r
238 //      ShapeTest_(&gvar);\r
239 #endif\r
240         MM_ShowMemory(&gvar);\r
241 #if 0\r
242         {\r
243         boolean                 done;\r
244         ScanCode                scan;\r
245         for (done = false;!done;)\r
246         {\r
247                 while (!(scan = gvar.in.inst->LastScan))\r
248                 {}\r
249         //                      SD_Poll();\r
250 \r
251                 IN_ClearKey(scan);\r
252                 switch (scan)\r
253                 {\r
254 //                      case sc_Space:\r
255 //                              MM_ShowMemory(&gvar);\r
256 //                      break;\r
257 //#ifdef __WATCOMC__\r
258                         case sc_O:\r
259                                 VL_modexPalScramble(&gvar.video.palette); modexpdump(&gvar.video.page);\r
260                         break;\r
261                         case sc_P:\r
262                                 modexpdump(&gvar.video.page[0]);\r
263                         break;\r
264                         case sc_V:\r
265                                 VL_PatternDraw(&gvar.video, 0, 1, 1);\r
266                         break;\r
267 //#endif\r
268                         default:\r
269                         case sc_Escape:\r
270                                 done = true;\r
271                         break;\r
272                 }\r
273         }\r
274 }\r
275 #endif\r
276 #ifndef NOVID\r
277         if(gvar.video.VL_Started)\r
278                 VL_Shutdown (&gvar);//VGAmodeX(0, 0, gvar);\r
279         modexFadeOn(4, gvar.video.dpal);\r
280 #endif\r
281         DebugMemory_(&gvar, 1);\r
282         MM_DumpData(&gvar);\r
283         KEYP\r
284         MM_Report_(&gvar);\r
285         //printf("bakapee1=%s\n", bakapee1);\r
286         //printf("bakapee2=%s\n", bakapee2);\r
287         MM_FreePtr(BBUFPTR, &gvar);\r
288                                                                 #ifndef NOVID\r
289         Shutdown16(&gvar);\r
290                                                                 #else //novid\r
291         ShutdownCAMMPM(&gvar);\r
292                                                                 #endif //NOVID\r
293         IN_Shutdown(&gvar);\r
294         printf("========================================\n");\r
295         printf("near=   %Fp ",  gvar.mm.nearheap);\r
296         printf("far=    %Fp",                   gvar.mm.farheap);\r
297         printf("\n");\r
298         printf("&near=  %Fp ",  &(gvar.mm.nearheap));\r
299         printf("&far=   %Fp",           &(gvar.mm.farheap));\r
300         printf("\n");\r
301                                                                 #ifdef EXMMVERBOSE\r
302         printf("bigb=   %Fp ",  BBUF);\r
303         //printf("bigbr=        %04x",  BBUF);\r
304         //printf("\n");\r
305         printf("&bigb=%Fp ",            BBUFPTR);\r
306         //printf("&bigb=%04x",          BBUFPTR);\r
307         printf("\n");\r
308                                                                 #endif\r
309         printf("========================================\n");\r
310 \r
311                                                                 #ifdef EXMMVERBOSE__\r
312         printf("coreleft():             %u\n", coreleft());\r
313         printf("farcoreleft():          %ld\n", farcoreleft());\r
314                                                                 #endif\r
315 #ifdef __WATCOMC__\r
316 //this is far   printf("Total free:                     %lu\n", (dword)(HC_GetFreeSize()));\r
317 //super buggy   printf("HC_coreleft():                  %u\n", HC_coreleft());\r
318 //      printf("HC_farcoreleft():                       %lu\n", (dword)HC_farcoreleft());\r
319         //printf("HC_GetNearFreeSize():         %u\n", HC_GetNearFreeSize());\r
320         //printf("HC_GetFarFreeSize():                  %lu\n", (dword)HC_GetFarFreeSize());\r
321 //      segatesuto();\r
322 #endif\r
323 #ifdef __BORLANDC__\r
324 //      printf("HC_coreleft:                    %lu\n", (dword)HC_coreleft());\r
325 //      printf("HC_farcoreleft:                 %lu\n", (dword)HC_farcoreleft());\r
326 //      printf("HC_Newfarcoreleft():            %lu\n", (dword)HC_Newfarcoreleft());\r
327 #endif\r
328         HC_heapdump(&gvar);\r
329         printf("Project 16 ");\r
330 #ifdef __WATCOMC__\r
331         printf("exmmtest");\r
332 #endif\r
333 #ifdef __BORLANDC__\r
334         printf("bcexmm");\r
335 #endif\r
336         printf(".exe. This is just a test file!\n");\r
337         printf("version %s\n", VERSION);\r
338 \r
339 //end of program\r
340 \r
341 \r
342 #if defined(__DEBUG__) && ( defined(__DEBUG_PM__) || defined(__DEBUG_MM__) )\r
343 #ifdef __DEBUG_MM__\r
344         printf("debugmm: %u\t", dbg_debugmm);\r
345 #endif\r
346 #ifdef __DEBUG_PM__\r
347         printf("debugpm: %u", dbg_debugpm);\r
348 #endif\r
349         printf("\n");\r
350 #endif\r
351 //      printf("curr_mode=%u\n", gvar.video.curr_mode);\r
352 //      VL_PrintmodexmemInfo(&gvar.video);\r
353         //printf("old_mode=%u   VL_Started=%u", gvar.video.old_mode, gvar.video.VL_Started);\r
354         //printf("based core left:                      %lu\n", (dword)_basedcoreleft());\r
355         //printf("huge core left:                       %lu\n", (dword)_hugecoreleft());\r
356 }\r