winmain, memory, options v1.

This commit is contained in:
oz 2020-11-05 18:44:34 +03:00
parent 4157e79c83
commit 473ed6b9d9
17 changed files with 418 additions and 35 deletions

View file

@ -17,7 +17,9 @@ int main()
{ {
std::cout << "Hello World!\n"; std::cout << "Hello World!\n";
pinball::hinst = GetModuleHandle(nullptr); pinball::hinst = GetModuleHandleA(nullptr);
char cmdLine[1];
WinMain(pinball::hinst, 0, cmdLine, 0);
objlist_class d = objlist_class(2, 4); objlist_class d = objlist_class(2, 4);
for (int i = 0; i < 100; i++) for (int i = 0; i < 100; i++)
@ -65,6 +67,7 @@ int main()
if (rsc) if (rsc)
printf_s("%d:\t%s\n", i, rsc); printf_s("%d:\t%s\n", i, rsc);
} }
//DatParser::Parse(dataFileName); //DatParser::Parse(dataFileName);
std::cout << "Goodby World!\n"; std::cout << "Goodby World!\n";
} }

View file

@ -96,6 +96,7 @@
<Link> <Link>
<SubSystem>Console</SubSystem> <SubSystem>Console</SubSystem>
<GenerateDebugInformation>true</GenerateDebugInformation> <GenerateDebugInformation>true</GenerateDebugInformation>
<AdditionalDependencies>Comctl32.lib;%(AdditionalDependencies)</AdditionalDependencies>
</Link> </Link>
</ItemDefinitionGroup> </ItemDefinitionGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
@ -154,7 +155,9 @@
<ItemGroup> <ItemGroup>
<ClInclude Include="DatParser.h" /> <ClInclude Include="DatParser.h" />
<ClInclude Include="loader.h" /> <ClInclude Include="loader.h" />
<ClInclude Include="memory.h" />
<ClInclude Include="objlist_class.h" /> <ClInclude Include="objlist_class.h" />
<ClInclude Include="options.h" />
<ClInclude Include="partman.h" /> <ClInclude Include="partman.h" />
<ClInclude Include="pch.h" /> <ClInclude Include="pch.h" />
<ClInclude Include="pinball.h" /> <ClInclude Include="pinball.h" />
@ -191,11 +194,14 @@
<ClInclude Include="TTimer.h" /> <ClInclude Include="TTimer.h" />
<ClInclude Include="TTripwire.h" /> <ClInclude Include="TTripwire.h" />
<ClInclude Include="TZmapList.h" /> <ClInclude Include="TZmapList.h" />
<ClInclude Include="winmain.h" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ClCompile Include="DatParser.cpp" /> <ClCompile Include="DatParser.cpp" />
<ClCompile Include="loader.cpp" /> <ClCompile Include="loader.cpp" />
<ClCompile Include="memory.cpp" />
<ClCompile Include="objlist_class.cpp" /> <ClCompile Include="objlist_class.cpp" />
<ClCompile Include="options.cpp" />
<ClCompile Include="partman.cpp" /> <ClCompile Include="partman.cpp" />
<ClCompile Include="pch.cpp"> <ClCompile Include="pch.cpp">
<PrecompiledHeader Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Create</PrecompiledHeader> <PrecompiledHeader Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Create</PrecompiledHeader>
@ -236,6 +242,7 @@
<ClCompile Include="TTextBox.cpp" /> <ClCompile Include="TTextBox.cpp" />
<ClCompile Include="TTimer.cpp" /> <ClCompile Include="TTimer.cpp" />
<ClCompile Include="TTripwire.cpp" /> <ClCompile Include="TTripwire.cpp" />
<ClCompile Include="winmain.cpp" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Natvis Include="NatvisFile.natvis" /> <Natvis Include="NatvisFile.natvis" />

View file

@ -138,6 +138,15 @@
<ClInclude Include="TZmapList.h"> <ClInclude Include="TZmapList.h">
<Filter>Header Files\PinballComponents</Filter> <Filter>Header Files\PinballComponents</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="memory.h">
<Filter>Header Files</Filter>
</ClInclude>
<ClInclude Include="winmain.h">
<Filter>Header Files</Filter>
</ClInclude>
<ClInclude Include="options.h">
<Filter>Header Files</Filter>
</ClInclude>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ClCompile Include="pch.cpp"> <ClCompile Include="pch.cpp">
@ -254,6 +263,15 @@
<ClCompile Include="TTripwire.cpp"> <ClCompile Include="TTripwire.cpp">
<Filter>Source Files\PinballComponents</Filter> <Filter>Source Files\PinballComponents</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="memory.cpp">
<Filter>Source Files</Filter>
</ClCompile>
<ClCompile Include="winmain.cpp">
<Filter>Source Files</Filter>
</ClCompile>
<ClCompile Include="options.cpp">
<Filter>Source Files</Filter>
</ClCompile>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Natvis Include="NatvisFile.natvis" /> <Natvis Include="NatvisFile.natvis" />

View file

@ -3,6 +3,7 @@
#include "loader.h" #include "loader.h"
#include "memory.h"
#include "pinball.h" #include "pinball.h"
#include "TBall.h" #include "TBall.h"
#include "TBlocker.h" #include "TBlocker.h"
@ -196,7 +197,7 @@ TPinballTable::~TPinballTable()
{ {
if (*scorePtr) if (*scorePtr)
{ {
free(*scorePtr); memory::free(*scorePtr);
*scorePtr = nullptr; *scorePtr = nullptr;
} }
scorePtr += 7; scorePtr += 7;
@ -205,12 +206,12 @@ TPinballTable::~TPinballTable()
while (index); while (index);
if (ScorePlayerNumber1) if (ScorePlayerNumber1)
{ {
free(ScorePlayerNumber1); memory::free(ScorePlayerNumber1);
ScorePlayerNumber1 = nullptr; ScorePlayerNumber1 = nullptr;
} }
if (ScoreBallcount) if (ScoreBallcount)
{ {
free(ScoreBallcount); memory::free(ScoreBallcount);
ScoreBallcount = nullptr; ScoreBallcount = nullptr;
} }
for (auto i = LightGroup; ; i = static_cast<TLightGroup*>(ListP1->Get(0))) for (auto i = LightGroup; ; i = static_cast<TLightGroup*>(ListP1->Get(0)))

View file

@ -1,6 +1,8 @@
#include "pch.h" #include "pch.h"
#include "loader.h" #include "loader.h"
#include "memory.h"
#include "partman.h" #include "partman.h"
#include "pinball.h" #include "pinball.h"
@ -138,7 +140,7 @@ void loader::unload()
while (index < sound_count); while (index < sound_count);
} }
if (sound_list[index].PtrToSmth) if (sound_list[index].PtrToSmth)
memoryfree(sound_list[index].PtrToSmth); memory::free(sound_list[index].PtrToSmth);
sound_count = 1; sound_count = 1;
} }

View file

@ -0,0 +1,58 @@
#include "pch.h"
#include "memory.h"
unsigned int memory::use_total;
int memory::critical_allocation;
void (*memory::critical_callback)();
void memory::init(void (*callback)())
{
critical_callback = callback;
}
char* memory::allocate(unsigned int size)
{
char* buf = static_cast<char*>(malloc(size + 4));
if (buf)
{
*(unsigned int*)buf = size << 8;
use_total += size + 4;
*buf = size >= 0xFFDC ? -91 : 90;
return buf + 4;
}
if (critical_allocation && critical_callback)
critical_callback();
return nullptr;
}
void memory::free(void* buf)
{
unsigned int* bufStart = static_cast<unsigned int*>(buf) - 1;
use_total -= (*bufStart >> 8) + 4;
char firstChar = *(char*)bufStart;
if (firstChar == 90 || firstChar == -91)
std::free(bufStart);
else
assertm(false, "Unknown memory type");
}
char* memory::realloc(void* buf, unsigned int size)
{
if (!buf)
return allocate(size);
char* bufStart = static_cast<char*>(buf) - 4;
use_total -= *(unsigned int*)bufStart >> 8;
if (*bufStart != 90 && *bufStart != -91 ||
(bufStart = static_cast<char*>(std::realloc(bufStart, size + 4))) != nullptr)
{
char bufType = *bufStart;
*(unsigned int*)bufStart = size << 8;
use_total += size;
*bufStart = bufType;
return bufStart + 4;
}
if (critical_allocation && critical_callback)
critical_callback();
return nullptr;
}

View file

@ -0,0 +1,13 @@
#pragma once
class memory
{
public:
static void init(void (*callback)(void));
static char* allocate(unsigned int size);
static void free(void* buf);
static char* realloc(void* buf, unsigned int size);
static unsigned int use_total;
static int critical_allocation;
static void (*critical_callback)();
};

View file

@ -1,6 +1,8 @@
#include "pch.h" #include "pch.h"
#include "objlist_class.h" #include "objlist_class.h"
#include <cstdlib> #include <cstdlib>
#include "memory.h"
// v1 from Ida // v1 from Ida
objlist_class::objlist_class(int SizeInt, int growSize) objlist_class::objlist_class(int SizeInt, int growSize)
@ -12,7 +14,7 @@ objlist_class::objlist_class(int SizeInt, int growSize)
objlist_class::~objlist_class() objlist_class::~objlist_class()
{ {
if (ListPtr) if (ListPtr)
free(ListPtr); memory::free(ListPtr);
} }
void objlist_class::Add(void* value) void objlist_class::Add(void* value)
@ -42,7 +44,7 @@ void* objlist_class::Get(int index)
objlist_struct1* objlist_class::objlist_new(int sizeInt) objlist_struct1* objlist_class::objlist_new(int sizeInt)
{ {
objlist_struct1* result = (objlist_struct1 *)malloc(sizeof(void*) * sizeInt + sizeof(objlist_struct1)); objlist_struct1* result = (objlist_struct1 *)memory::allocate(sizeof(void*) * sizeInt + sizeof(objlist_struct1));
if (!result) if (!result)
return result; return result;
result->Count = 0; result->Count = 0;
@ -67,7 +69,7 @@ objlist_struct1* objlist_class::objlist_grow(objlist_struct1* ptrToStruct, int g
int newSizeInt = growSize + ptrToStruct->Count; int newSizeInt = growSize + ptrToStruct->Count;
if (newSizeInt <= ptrToStruct->Size) if (newSizeInt <= ptrToStruct->Size)
return resultPtr; return resultPtr;
objlist_struct1* resultPtr2 = (objlist_struct1*)realloc(ptrToStruct, sizeof(void*) * newSizeInt + sizeof(objlist_struct1)); objlist_struct1* resultPtr2 = (objlist_struct1*)memory::realloc(ptrToStruct, sizeof(void*) * newSizeInt + sizeof(objlist_struct1));
if (!resultPtr2) if (!resultPtr2)
return resultPtr; return resultPtr;
resultPtr = resultPtr2; resultPtr = resultPtr2;

View file

@ -0,0 +1,118 @@
#include "pch.h"
#include "options.h"
#include "memory.h"
LPCSTR options::OptionsRegPath;
LPSTR options::OptionsRegPathCur;
void options::path_init(LPCSTR regPath)
{
char* buf = memory::allocate(lstrlenA(regPath) + 1);
OptionsRegPath = buf;
if (buf)
lstrcpyA(buf, regPath);
}
void options::path_uninit()
{
if (OptionsRegPath)
memory::free((void*)OptionsRegPath);
OptionsRegPath = nullptr;
}
LPCSTR options::path(LPCSTR regPath)
{
char* buf = OptionsRegPathCur;
if (!OptionsRegPathCur)
{
buf = memory::allocate(0x7D0u);
OptionsRegPathCur = buf;
if (!buf)
return OptionsRegPath;
}
lstrcpyA(buf, OptionsRegPath);
if (!regPath)
return OptionsRegPathCur;
lstrcatA(OptionsRegPathCur, "\\");
lstrcatA(OptionsRegPathCur, regPath);
return OptionsRegPathCur;
}
void options::path_free()
{
if (OptionsRegPathCur)
memory::free(OptionsRegPathCur);
OptionsRegPathCur = nullptr;
}
int options::get_int(LPCSTR optPath, LPCSTR lpValueName, int defaultValue)
{
DWORD dwDisposition; // [esp+4h] [ebp-8h]
HKEY result = (HKEY)defaultValue, Data = (HKEY)defaultValue;
if (!OptionsRegPath)
return defaultValue;
LPCSTR regPath = path(optPath);
if (!RegCreateKeyExA(HKEY_CURRENT_USER, regPath, 0, nullptr, 0, 0xF003Fu, nullptr, &result, &dwDisposition))
{
optPath = (LPCSTR)4;
RegQueryValueExA(result, lpValueName, nullptr, nullptr, (LPBYTE)&Data, (LPDWORD)&optPath);
RegCloseKey(result);
}
path_free();
return (int)Data;
}
void options::set_int(LPCSTR optPath, LPCSTR lpValueName, int data)
{
DWORD dwDisposition; // [esp+4h] [ebp-4h]
if (OptionsRegPath)
{
const CHAR* regPath = path(optPath);
if (!RegCreateKeyExA(HKEY_CURRENT_USER, regPath, 0, nullptr, 0, 0xF003Fu, nullptr, (PHKEY)&optPath,
&dwDisposition))
{
RegSetValueExA((HKEY)optPath, lpValueName, 0, 4u, (const BYTE*)&data, 4u);
RegCloseKey((HKEY)optPath);
}
path_free();
}
}
void options::get_string(LPCSTR optPath, LPCSTR lpValueName, LPSTR lpString1, LPCSTR lpString2, int iMaxLength)
{
const CHAR* v5 = (const CHAR*)iMaxLength;
lstrcpynA(lpString1, lpString2, iMaxLength);
if (OptionsRegPath)
{
const CHAR* regPath = path(optPath);
if (!RegCreateKeyExA(HKEY_CURRENT_USER, regPath, 0, nullptr, 0, 0xF003Fu, nullptr, (PHKEY)&iMaxLength,
(LPDWORD)&optPath))
{
lpString2 = v5;
RegQueryValueExA((HKEY)iMaxLength, lpValueName, nullptr, nullptr, (LPBYTE)lpString1, (LPDWORD)&lpString2);
RegCloseKey((HKEY)iMaxLength);
}
path_free();
}
}
void options::set_string(LPCSTR optPath, LPCSTR lpValueName, LPCSTR value)
{
DWORD dwDisposition; // [esp+4h] [ebp-4h]
if (OptionsRegPath)
{
const CHAR* regPath = path(optPath);
if (!RegCreateKeyExA(HKEY_CURRENT_USER, regPath, 0, nullptr, 0, 0xF003Fu, nullptr, (PHKEY)&optPath,
&dwDisposition))
{
int v4 = lstrlenA(value);
RegSetValueExA((HKEY)optPath, lpValueName, 0, 1u, (const BYTE*)value, v4 + 1);
RegCloseKey((HKEY)optPath);
}
path_free();
}
}

View file

@ -0,0 +1,16 @@
#pragma once
class options
{
public:
static void path_init(LPCSTR regPath);
static void path_uninit();
static int get_int(LPCSTR optPath, LPCSTR lpValueName, int defaultValue);
static void set_int(LPCSTR optPath, LPCSTR lpValueName, int data);
static void get_string(LPCSTR optPath, LPCSTR lpValueName, LPSTR lpString1, LPCSTR lpString2, int iMaxLength);
static void set_string(LPCSTR optPath, LPCSTR lpValueName, LPCSTR value);
private:
static LPCSTR OptionsRegPath;
static LPSTR OptionsRegPathCur;
static LPCSTR path(LPCSTR regPath);
static void path_free();
};

View file

@ -1,6 +1,8 @@
#include "pch.h" #include "pch.h"
#include "partman.h" #include "partman.h"
#include "memory.h"
short partman::_field_size[] = { short partman::_field_size[] = {
2, -1, 2, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0 2, -1, 2, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0
}; };
@ -24,7 +26,7 @@ datFileStruct* partman::load_records(LPCSTR lpFileName)
_lclose(fileHandle); _lclose(fileHandle);
return nullptr; return nullptr;
} }
datFile = (datFileStruct*)memoryallocate(sizeof(datFileStruct)); datFile = (datFileStruct*)memory::allocate(sizeof(datFileStruct));
if (!datFile) if (!datFile)
{ {
_lclose(fileHandle); _lclose(fileHandle);
@ -37,12 +39,12 @@ datFileStruct* partman::load_records(LPCSTR lpFileName)
else else
{ {
int lenOfStr = lstrlenA(Buffer.Description); int lenOfStr = lstrlenA(Buffer.Description);
auto descriptionBuf = (char*)memoryallocate(lenOfStr + 1); auto descriptionBuf = (char*)memory::allocate(lenOfStr + 1);
datFile->Description = descriptionBuf; datFile->Description = descriptionBuf;
if (!descriptionBuf) if (!descriptionBuf)
{ {
_lclose(fileHandle); _lclose(fileHandle);
memoryfree(datFile); memory::free(datFile);
return nullptr; return nullptr;
} }
lstrcpyA(descriptionBuf, Buffer.Description); lstrcpyA(descriptionBuf, Buffer.Description);
@ -50,26 +52,26 @@ datFileStruct* partman::load_records(LPCSTR lpFileName)
if (Buffer.Unknown) if (Buffer.Unknown)
{ {
auto unknownBuf = (char*)memoryallocate(Buffer.Unknown); auto unknownBuf = (char*)memory::allocate(Buffer.Unknown);
if (!unknownBuf) if (!unknownBuf)
{ {
_lclose(fileHandle); _lclose(fileHandle);
if (datFile->Description) if (datFile->Description)
memoryfree(datFile->Description); memory::free(datFile->Description);
memoryfree(datFile); memory::free(datFile);
return nullptr; return nullptr;
} }
_lread(fileHandle, static_cast<void*>(unknownBuf), Buffer.Unknown); _lread(fileHandle, static_cast<void*>(unknownBuf), Buffer.Unknown);
memoryfree(unknownBuf); memory::free(unknownBuf);
} }
groupDataBuf = (datGroupData**)memoryallocate(sizeof(void*) * Buffer.NumberOfGroups); groupDataBuf = (datGroupData**)memory::allocate(sizeof(void*) * Buffer.NumberOfGroups);
datFile->GroupData = groupDataBuf; datFile->GroupData = groupDataBuf;
if (!groupDataBuf) if (!groupDataBuf)
{ {
if (datFile->Description) if (datFile->Description)
memoryfree(datFile->Description); memory::free(datFile->Description);
memoryfree(datFile); memory::free(datFile);
return nullptr; return nullptr;
} }
@ -83,7 +85,7 @@ datFileStruct* partman::load_records(LPCSTR lpFileName)
groupDataSize = 0; groupDataSize = 0;
else else
groupDataSize = entryCount - 1; groupDataSize = entryCount - 1;
datFile->GroupData[groupIndex] = (datGroupData*)memoryallocate( datFile->GroupData[groupIndex] = (datGroupData*)memory::allocate(
sizeof(datEntryData) * groupDataSize + sizeof(datGroupData)); sizeof(datEntryData) * groupDataSize + sizeof(datGroupData));
datGroupData* groupData = datFile->GroupData[groupIndex]; datGroupData* groupData = datFile->GroupData[groupIndex];
if (!groupData) if (!groupData)
@ -105,22 +107,22 @@ datFileStruct* partman::load_records(LPCSTR lpFileName)
if (entryType == Bitmap8bit) if (entryType == Bitmap8bit)
{ {
_hread(fileHandle, &bmpHeader, 14); _hread(fileHandle, &bmpHeader, 14);
char* bmpBuffer = (char*)memoryallocate(0x25u); char* bmpBuffer = (char*)memory::allocate(0x25u);
entryData->Buffer = bmpBuffer; entryData->Buffer = bmpBuffer;
if (!bmpBuffer) if (!bmpBuffer)
goto LABEL_41; goto LABEL_41;
/*if (bmpHeader.Unknown2 & 2 ? gdrv_create_bitmap((int)bmpBuffer, bmpHeader.Width, bmpHeader.Height) : gdrv_create_raw_bitmap((int)bmpBuffer, bmpHeader.Width, bmpHeader.Height, bmpHeader.Unknown2 & 1)) /*if (bmpHeader.Unknown2 & 2 ? gdrv_create_bitmap((int)bmpBuffer, bmpHeader.Width, bmpHeader.Height) : gdrv_create_raw_bitmap((int)bmpBuffer, bmpHeader.Width, bmpHeader.Height, bmpHeader.Unknown2 & 1))
goto LABEL_41;*/ goto LABEL_41;*/
//_hread(fileHandle, *(LPVOID*)(entryData->Buffer + 8), bmpHeader.Size); //_hread(fileHandle, *(LPVOID*)(entryData->Buffer + 8), bmpHeader.Size);
char* tempBuff = (char*)memoryallocate(bmpHeader.Size); char* tempBuff = (char*)memory::allocate(bmpHeader.Size);
_hread(fileHandle, tempBuff, bmpHeader.Size); _hread(fileHandle, tempBuff, bmpHeader.Size);
memoryfree(tempBuff); memory::free(tempBuff);
//*((int*)entryData->Buffer + 29) = bmpHeader.XPosition; //*((int*)entryData->Buffer + 29) = bmpHeader.XPosition;
//*((int*)entryData->Buffer + 33) = bmpHeader.YPosition; //*((int*)entryData->Buffer + 33) = bmpHeader.YPosition;
} }
else else
{ {
char* entryBuffer = (char*)memoryallocate(fieldSize); char* entryBuffer = (char*)memory::allocate(fieldSize);
entryData->Buffer = entryBuffer; entryData->Buffer = entryBuffer;
if (!entryBuffer) if (!entryBuffer)
goto LABEL_41; goto LABEL_41;
@ -165,20 +167,20 @@ void partman::unload_records(datFileStruct* datFile)
{ {
//if (HIWORD(entry->EntryType) == 1) //if (HIWORD(entry->EntryType) == 1)
//gdrv_destroy_bitmap(entry->Buffer); //gdrv_destroy_bitmap(entry->Buffer);
memoryfree(entry->Buffer); memory::free(entry->Buffer);
} }
++entryIndex; ++entryIndex;
++entry; ++entry;
} }
while (entryIndex < group->EntryCount); while (entryIndex < group->EntryCount);
} }
memoryfree(group); memory::free(group);
} }
} }
if (datFile->Description) if (datFile->Description)
memoryfree(datFile->Description); memory::free(datFile->Description);
memoryfree(datFile->GroupData); memory::free(datFile->GroupData);
memoryfree(datFile); memory::free(datFile);
} }
char* partman::field(datFileStruct* datFile, int groupIndex, datFieldTypes targetEntryType) char* partman::field(datFileStruct* datFile, int groupIndex, datFieldTypes targetEntryType)

View file

@ -14,9 +14,10 @@
#include <cstdio> #include <cstdio>
#include <cassert> #include <cassert>
#include <cmath> #include <cmath>
#include <CommCtrl.h>
//#include <cstdlib> //#include <cstdlib>
#define memoryallocate(x) malloc(x); // Use (void) to silent unused warnings.
#define memoryfree(x) free(x); #define assertm(exp, msg) assert(((void)msg, exp))
#endif //PCH_H #endif //PCH_H

View file

@ -1,5 +1,6 @@
#include "pch.h" #include "pch.h"
#include "pinball.h" #include "pinball.h"
#include "memory.h"
int pinball::quickFlag = 0; int pinball::quickFlag = 0;
@ -9,6 +10,8 @@ TTextBox* pinball::MissTextBox;
char pinball::getRcBuffer[6 * 256]; char pinball::getRcBuffer[6 * 256];
int pinball::rc_string_slot = 0; int pinball::rc_string_slot = 0;
HINSTANCE pinball::hinst; HINSTANCE pinball::hinst;
char pinball::WindowName[2]{};
char pinball::DatFileName[300]{};
char* pinball::get_rc_string(int uID, int a2) char* pinball::get_rc_string(int uID, int a2)

View file

@ -9,9 +9,10 @@ public:
static TTextBox* InfoTextBox; static TTextBox* InfoTextBox;
static TTextBox* MissTextBox; static TTextBox* MissTextBox;
static HINSTANCE hinst; static HINSTANCE hinst;
static char WindowName[2];
static char DatFileName[300];
static char* get_rc_string(int uID, int a2); static char* get_rc_string(int uID, int a2);
private: private:
static char getRcBuffer[256 * 6]; static char getRcBuffer[256 * 6];
static int rc_string_slot; static int rc_string_slot;
}; };

View file

@ -1,12 +1,13 @@
#include "pch.h" #include "pch.h"
#include "score.h" #include "score.h"
#include "loader.h" #include "loader.h"
#include "memory.h"
#include "partman.h" #include "partman.h"
scoreStruct* score::create(LPCSTR fieldName, int renderBgBmp) scoreStruct* score::create(LPCSTR fieldName, int renderBgBmp)
{ {
scoreStruct* score = (scoreStruct*)memoryallocate(sizeof(scoreStruct)); scoreStruct* score = (scoreStruct*)memory::allocate(sizeof(scoreStruct));
if (!score) if (!score)
return nullptr; return nullptr;
score->Unknown1 = -9999; score->Unknown1 = -9999;
@ -14,7 +15,7 @@ scoreStruct* score::create(LPCSTR fieldName, int renderBgBmp)
__int16* shortArr = (__int16*)partman::field_labeled(loader::loader_table, fieldName, ShortArray); __int16* shortArr = (__int16*)partman::field_labeled(loader::loader_table, fieldName, ShortArray);
if (!shortArr) if (!shortArr)
{ {
memoryfree(score); memory::free(score);
return nullptr; return nullptr;
} }
int groupIndex = *shortArr++; int groupIndex = *shortArr++;
@ -37,7 +38,7 @@ scoreStruct* score::create(LPCSTR fieldName, int renderBgBmp)
scoreStruct* score::dup(scoreStruct* score, int scoreIndex) scoreStruct* score::dup(scoreStruct* score, int scoreIndex)
{ {
scoreStruct* result = (scoreStruct*)memoryallocate(0x44u); scoreStruct* result = (scoreStruct*)memory::allocate(sizeof(scoreStruct));
if (result) if (result)
memcpy(result, score, sizeof(scoreStruct)); memcpy(result, score, sizeof(scoreStruct));
return result; return result;

View file

@ -0,0 +1,133 @@
#include "pch.h"
#include "winmain.h"
#include "memory.h"
#include "pinball.h"
#include "options.h"
int iFrostUniqueMsg;
//HWND, UINT, WPARAM, LPARAM
//typedef LRESULT (CALLBACK* WNDPROC)(HWND, UINT, WPARAM, LPARAM);
LRESULT CALLBACK message_handler(HWND hWnd, UINT Msg, WPARAM wParam, LPARAM LPARAM)
{
return 0;
}
int check_expiration_date()
{
return 0;
}
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nShowCmd)
{
memory::init(winmain_memalloc_failure);
++memory::critical_allocation;
auto optionsRegPath = pinball::get_rc_string(165, 0);
options::path_init(optionsRegPath);
auto regSpaceCadet = pinball::get_rc_string(166, 0);
if (options::get_int(regSpaceCadet, "Table Version", 1) <= 1)
{
auto tmpBuf = memory::allocate(0x1F4u);
if (!tmpBuf)
{
options::path_uninit();
return 0;
}
options::set_int(regSpaceCadet, "Table Version", 1u);
GetModuleFileNameA(pinball::hinst, tmpBuf, 0x1F4u);
options::set_string(regSpaceCadet, "Table Exe", tmpBuf);
options::set_string(regSpaceCadet, "Table Name", pinball::get_rc_string(169, 0));
options::set_string(nullptr, "Last Table Played", regSpaceCadet);
memory::free(static_cast<void*>(tmpBuf));
tmpBuf = memory::allocate(0x1F4u);
if (tmpBuf)
{
auto tmpBuf2 = memory::allocate(0x1F4u);
if (tmpBuf2)
{
char Buffer[40];
for (int i = 0; i < 32700; ++i)
{
sprintf_s(Buffer, "Table%d", i);
options::get_string(nullptr, Buffer, tmpBuf, pinball::WindowName, 500);
if (!*tmpBuf)
break;
options::get_string(tmpBuf, "Table Name", tmpBuf2, pinball::WindowName, 500);
if (!lstrcmpA(tmpBuf2, pinball::get_rc_string(169, 0)))
goto LABEL_15;
if (!*tmpBuf2)
break;
}
options::set_string(nullptr, Buffer, regSpaceCadet);
LABEL_15:
memory::free(tmpBuf2);
}
memory::free(tmpBuf);
}
}
else
{
auto tmpBuf = memory::allocate(0x1F4u);
if (!tmpBuf)
{
options::path_uninit();
return 0;
}
options::get_string(regSpaceCadet, "Shell Exe", tmpBuf, pinball::WindowName, 500);
auto execRes = WinExec(tmpBuf, 5u);
memory::free(tmpBuf);
if (execRes >= 32)
{
options::path_uninit();
return 0;
}
}
--memory::critical_allocation;
pinball::quickFlag = strstr(lpCmdLine, "-quick") != 0;
pinball::hinst = hInstance;
options::get_string(regSpaceCadet, "Pinball Data", pinball::DatFileName, pinball::get_rc_string(168, 0), 300);
iFrostUniqueMsg = RegisterWindowMessageA("PinballThemeSwitcherUniqueMsgString");
auto windowHandle= FindWindowA(pinball::get_rc_string(167, 0), nullptr);
if (windowHandle)
{
SendMessageA(windowHandle, iFrostUniqueMsg, 0, 0);
return 0;
}
if (check_expiration_date())
return 0;
INITCOMMONCONTROLSEX picce{};
picce.dwSize = 8;
picce.dwICC = 5885;
InitCommonControlsEx(&picce);
WNDCLASSA WndClass;
WndClass.style = 4104;
WndClass.lpfnWndProc = message_handler;
WndClass.cbClsExtra = 0;
WndClass.cbWndExtra = 0;
WndClass.hInstance = hInstance;
WndClass.hIcon = LoadIconA(hInstance, "ICON_1");
WndClass.hCursor = LoadCursorA(0, (LPCSTR)0x7F00);
WndClass.hbrBackground = (HBRUSH)16;
WndClass.lpszMenuName = "MENU_1";
WndClass.lpszClassName = pinball::get_rc_string(167, 0);
//auto tmpBuf = splash_screen((int)hInstance, "splash_bitmap", "splash_bitmap");
RegisterClassA(&WndClass);
}
void winmain_memalloc_failure()
{
/*midi_music_stop();
Sound_Close();
gdrv_uninit();*/
char* caption = pinball::get_rc_string(170, 0);
char* text = pinball::get_rc_string(179, 0);
MessageBoxA(nullptr, text, caption, 0x2030u);
_exit(1);
}

View file

@ -0,0 +1,4 @@
#pragma once
static int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nShowCmd);
static void winmain_memalloc_failure();