]> 4ch.mooo.com Git - 16.git/blob - src/exmmtest.c
p16 is being worked on a bunch by me wwww [16_ca needs huge amounts of work and I...
[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 <malloc.h>             // for _memavl()\r
26 #include "src/lib/16_head.h"\r
27 #include "src/lib/16_tail.h"\r
28 #include "src/lib/16_pm.h"\r
29 #include "src/lib/16_ca.h"\r
30 #include "src/lib/16_mm.h"\r
31 #include "src/lib/16_hc.h"\r
32 #include "src/lib/16_dbg.h"\r
33 \r
34 #pragma hdrstop\r
35 \r
36 #pragma warn -pro\r
37 #pragma warn -use\r
38 \r
39 //file load or read definition\r
40 #define FILEREADLOAD\r
41 #define FILEREAD\r
42 //#define EXMMVERBOSE\r
43 //#define BUFFDUMPPAUSE\r
44 //#define EXMMVERBOSE__\r
45 //      #define PRINTBBDUMP\r
46 #define BUFFDUMP\r
47 #define NOVID\r
48 \r
49 \r
50 #define KEYP IN_Shutdown(&gvar); printf("\n\npress any key to continue!\n"); getch(); IN_Startup(&gvar);\r
51 \r
52 #define BBUFNAME gvar.mm.bufferseg//bigbuffer\r
53 //#define INITBBUF static memptr BBUFNAME;\r
54 #define BBUFPTR MEMPTR BBUFNAME\r
55 \r
56 #ifdef __BORLANDC__\r
57 #define BBUF            (memptr *)BBUFPTR\r
58 #define BBUFSTRING      (memptr *)BBUFNAME\r
59 #endif\r
60 #ifdef __WATCOMC__\r
61 #define BBUF            BBUFNAME\r
62 #define BBUFSTRING      BBUF\r
63 #endif\r
64 \r
65 ////////////////////////////////////////////////////////////////////////////\r
66 #ifdef __BORLANDC__\r
67 void VGAmodeX(sword vq, boolean cmem, global_game_variables_t *gv)\r
68 {\r
69         printf("VGAmodeX dummy:\n       %Fp     %Fp     %Fp\n", &vq, &cmem, gv);\r
70 }\r
71 #endif\r
72 \r
73 //printf("*     %Fp\t", *BBUF);\r
74 //printf("*          %04x\t", *BBUF);\r
75 #define PRINTBB {\\r
76         printf("-------------------------------------------------------------------------------\n");\\r
77         printf("&main()=        %Fp\n", argv[0]);\\r
78         printf("buffer:\n");\\r
79         printf("        %Fp\t", BBUF);\\r
80         printf("&%Fp\n", BBUFPTR);\\r
81         printf("             %04x\t", BBUF);\\r
82         printf("&     %04x\n", BBUFPTR);\\r
83         printf("-------------------------------------------------------------------------------\n");\\r
84 }\r
85         //printf("&main()=      %Fp\n", *argv[0]);\r
86         //printf("bigbuffer=    %Fp\n", bigbuffer);\r
87         //printf("&bigbuffer=   %Fp\n", &bigbuffer);\r
88         //printf("bigbuffer=    %04x\n", bigbuffer);\r
89         //printf("&bigbuffer=   %04x\n", &bigbuffer);\r
90 #ifdef __WATCOMC__\r
91 void segatesuto()\r
92 {\r
93         __segment screen;\r
94         char __based( void ) * scrptr;\r
95 \r
96         screen = 0xB800;\r
97         scrptr = 0;\r
98         printf( "Top left character is '%c'.\n", *(screen:>scrptr) );\r
99 //      printf("Next string is: [");\r
100 //      while(*scrptr<16)\r
101 //      {\r
102 //              printf("%c", *(screen:>scrptr));\r
103 //              //printf("\b");\r
104 //              scrptr++;\r
105 //\r
106 //      }\r
107 //      printf("]\n");\r
108 //      KEYP\r
109 }\r
110 #endif\r
111 \r
112 //===========================================================================//\r
113 \r
114 //=======================================//\r
115 \r
116 //      main\r
117 \r
118 //=======================================//\r
119 void\r
120 main(int argc, char *argv[])\r
121 {\r
122         byte w;\r
123                                                                 #ifndef NOVID\r
124         boolean                 done;\r
125         ScanCode                scan;\r
126                                                                 #endif\r
127         static global_game_variables_t gvar;\r
128                                                                 #ifdef INITBBUF\r
129         INITBBUF\r
130                                                                 #endif\r
131 #if 0\r
132 //#ifdef __WATCOMC__\r
133         __segment sega;\r
134 #endif\r
135         char bakapee1[64] = "data/koishi~.pcx";\r
136         char bakapee2[64] = "data/test.map";\r
137         word baka;\r
138 \r
139                 #ifdef __BORLANDC__\r
140                         argc=argc;\r
141                 #endif\r
142 \r
143                                                                 #ifdef PRINTBBDUMP\r
144                                                                 //0000PRINTBB; KEYP\r
145                                                                 #endif\r
146 #ifdef __16_PM__\r
147 #ifdef __DEBUG_PM__\r
148         dbg_debugpm=1;  //debug pm\r
149 #endif\r
150 #endif\r
151 #ifdef __DEBUG_CA__\r
152         dbg_debugca=1;\r
153 #endif\r
154 #ifdef __DEBUG_MM__\r
155         dbg_debugmm=1;\r
156 #endif\r
157 \r
158         if(argv[1]){ strcpy(bakapee1, argv[1]);//bakapee1[] = *argv[1];\r
159         if(argv[2]) strcpy(bakapee2, argv[2]); }//bakapee2[] = argv[2]; }\r
160 #if 0\r
161         else{\r
162         //{ printf("filename!: "); scanf("%[^\n]", &bakapee); }\r
163                 strcpy(bakapee1, "data/koishi~.pcx"); //bakapee1 = "data/koishi~.pcx";\r
164                 strcpy(bakapee2, "data/test.map"); //bakapee2 = "data/test.map";\r
165         }\r
166 #endif\r
167         printf("bakapee1[%s]\n", bakapee1);\r
168         printf("bakapee2[%s]\n", bakapee2);\r
169         KEYP\r
170 \r
171                                                                 #ifndef NOVID\r
172         Startup16(&gvar);\r
173         // save the palette\r
174                                                                 #ifdef __WATCOMC__\r
175         modexPalSave(&gvar.video.dpal); modexFadeOff(4, &gvar.video.dpal); //modexPalBlack();\r
176                                                                 #endif\r
177                                                                 #else //NOVID\r
178         //printf("main()=%Fp    start MM\n", *argv[0]);\r
179         MM_Startup(&gvar);\r
180                                                                 #ifdef __16_PM__\r
181                                                                 #ifdef __DEBUG_PM__\r
182                                                                         if(dbg_debugpm>0)\r
183                                                                         {\r
184                                                                 #endif //__DEBUG_PM__\r
185         PM_Startup(&gvar); PM_CheckMainMem(&gvar); PM_UnlockMainMem(&gvar);\r
186                                                                 //0000printf("PM Started\n"); KEYP\r
187                                                                 #ifdef __DEBUG_PM__\r
188                                                                         }\r
189                                                                 #endif //__DEBUG_PM__\r
190                                                                 #endif //__16_PM__\r
191                                                                 #endif //elsed NOVID\r
192 \r
193         CA_Startup(&gvar);\r
194                                                                 #ifdef PRINTBBDUMP\r
195                                                                 //0000\r
196 PRINTBB; KEYP\r
197                                                                 #endif\r
198 \r
199         w=0;\r
200                                                                 #ifdef FILEREADLOAD\r
201                                                                 #ifdef FILEREAD\r
202         for(;w<2;w++)\r
203         {\r
204         //      printf("size of big buffer~=%u\n", _bmsize(segu, BBUF));\r
205                 if(w>0)\r
206                 {\r
207                         printf("======================================read=====================================\n");\r
208                         if(CA_ReadFile(bakapee2, BBUFPTR, &gvar)) baka=1; else baka=0;\r
209                         printf("====================================read end===================================\n");\r
210                 }\r
211                                                                 #endif //FILEREAD\r
212                 if(w==0)\r
213                 {\r
214                         printf("======================================load=====================================\n");\r
215                         if(CA_LoadFile(bakapee1, BBUFPTR, &gvar)) baka=1; else baka=0;\r
216                         printf("====================================load end===================================\n");\r
217                 }\r
218                                                                 //#ifdef __WATCOMC__\r
219                                                                 //      printf("\nsize of big buffer~=%u\n", _bmsize(sega, BBUF));\r
220                                                                 //#endif\r
221                                                                 #ifdef BUFFDUMP\r
222                 printf("contents of the buffer\n[\n%s\n]\n", BBUFSTRING);\r
223                                                                 #endif// #else\r
224                                                                 #ifdef PRINTBBDUMP\r
225                 PRINTBB;\r
226                                                                 #endif\r
227 \r
228                                                                 //endif // BUFFDUMP\r
229 \r
230                 //printf("dark purple = purgable\n");\r
231                 //printf("medium blue = non purgable\n");\r
232                 //printf("red = locked\n");\r
233         //      KEYP\r
234         //      DebugMemory_(&gvar, 1);\r
235                 if(baka) printf("\nyay!\n");\r
236                 else printf("\npoo!\n");\r
237                                                                 #ifdef BUFFDUMPPAUSE\r
238                 KEYP\r
239                                                                 #endif\r
240                                                                 #ifdef FILEREAD\r
241         }\r
242                                                                 #endif\r
243                                                                 #endif  //filereadload\r
244 \r
245 #ifdef __WATCOMC__\r
246 #ifndef NOVID\r
247         VGAmodeX(1, 0, &gvar);\r
248 //      modexPalUpdate0(&gvar.video.palette);\r
249 //      ShapeTest_(&gvar);\r
250 \r
251         for (done = false;!done;)\r
252         {\r
253                 while (!(scan = gvar.in.inst->LastScan))\r
254                 {}\r
255         //                      SD_Poll();\r
256 \r
257                 IN_ClearKey(scan);\r
258                 switch (scan)\r
259                 {\r
260 //                      case sc_Space:\r
261 //                              MM_ShowMemory(&gvar);\r
262 //                      break;\r
263 //#ifdef __WATCOMC__\r
264                         case sc_O:\r
265                                 modexPalUpdate0(&gvar.video.palette); modexpdump(&gvar.video.page);\r
266                         break;\r
267                         case sc_P:\r
268                                 modexpdump(&gvar.video.page[0]);\r
269                         break;\r
270                         case sc_V:\r
271                                 VL_PatternDraw(&gvar.video, 0, 1, 1);\r
272                         break;\r
273 //#endif\r
274                         default:\r
275                         case sc_Escape:\r
276                                 done = true;\r
277                         break;\r
278                 }\r
279         }\r
280         VGAmodeX(0, 0, &gvar);\r
281 #endif\r
282 #endif\r
283 //      MM_ShowMemory(&gvar);\r
284         DebugMemory_(&gvar, 1);\r
285         MM_DumpData(&gvar);\r
286         MM_Report_(&gvar);\r
287         //printf("bakapee1=%s\n", bakapee1);\r
288         //printf("bakapee2=%s\n", bakapee2);\r
289         MM_FreePtr(BBUFPTR, &gvar);\r
290                                                                 #ifndef NOVID\r
291         Shutdown16(&gvar);\r
292                                                                 #else //novid\r
293                                                                 #ifdef __16_PM__\r
294                                                                 #ifdef __DEBUG_PM__\r
295                                                                         if(dbg_debugpm>0)\r
296                                                                 #endif //__DEBUG_PM__\r
297         PM_Shutdown(&gvar);\r
298                                                                 #endif //__16_PM__\r
299         CA_Shutdown(&gvar);\r
300         MM_Shutdown(&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", _memavl());\r
322         printf("farcoreleft():                  %lu\n", (dword)HC_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         HC_heapdump(&gvar);\r
331 //      segatesuto();\r
332 #endif\r
333 /*#ifdef __BORLANDC__\r
334         //printf("core left:                    %lu\n", (dword)HC_coreleft());\r
335         //printf("far core left:                        %lu\n", (dword)HC_farcoreleft());\r
336 //      printf("\nfarcoreleft():                        %lu\n", farcoreleft());\r
337 #endif*/\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("old_mode=%u   VL_Started=%u", gvar.video.old_mode, gvar.video.VL_Started);\r
361         //printf("based core left:                      %lu\n", (dword)_basedcoreleft());\r
362         //printf("huge core left:                       %lu\n", (dword)_hugecoreleft());\r
363 }\r