OSDN Git Service

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