1
0
mirror of https://github.com/FunkyFr3sh/cnc-ddraw.git synced 2025-03-25 01:57:47 +01:00

always use full path to avoid issues with working directories in wine

This commit is contained in:
FunkyFr3sh 2023-11-12 23:58:10 +01:00
parent 8cfe73e834
commit 07d26d7bed
2 changed files with 16 additions and 10 deletions

View File

@ -24,6 +24,8 @@ int Savesettings;
int Resolutions; int Resolutions;
int Minfps; int Minfps;
#define GAME_PATH (TPath::GetDirectoryName(Application->ExeName) + "\\")
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
__fastcall TConfigForm::TConfigForm(TComponent* Owner) __fastcall TConfigForm::TConfigForm(TComponent* Owner)
: TForm(Owner) : TForm(Owner)
@ -41,7 +43,7 @@ void __fastcall TConfigForm::CreateParams(TCreateParams & Params)
void __fastcall TConfigForm::LanguageImgClick(TObject *Sender) void __fastcall TConfigForm::LanguageImgClick(TObject *Sender)
{ {
auto *ini = new TIniFile(".\\ddraw.ini"); auto *ini = new TIniFile(GAME_PATH + "ddraw.ini");
ini->WriteString("ddraw", "configlang", IsEnglish ? "auto" : "english"); ini->WriteString("ddraw", "configlang", IsEnglish ? "auto" : "english");
delete ini; delete ini;
@ -58,7 +60,7 @@ void __fastcall TConfigForm::LanguageImgClick(TObject *Sender)
void __fastcall TConfigForm::ThemePnlClick(TObject *Sender) void __fastcall TConfigForm::ThemePnlClick(TObject *Sender)
{ {
auto *ini = new TIniFile(".\\ddraw.ini"); auto *ini = new TIniFile(GAME_PATH + "ddraw.ini");
auto theme = auto theme =
ThemePnl->Color == (TColor)RGB(31, 31, 31) ? "Cobalt XEMedia" : "Windows10"; ThemePnl->Color == (TColor)RGB(31, 31, 31) ? "Cobalt XEMedia" : "Windows10";
@ -87,7 +89,7 @@ void __fastcall TConfigForm::RestoreDefaultsBtnClick(TObject *Sender)
return; return;
} }
DeleteFile(".\\ddraw.ini"); DeleteFile(GAME_PATH + "ddraw.ini");
ShellExecute( ShellExecute(
NULL, NULL,
@ -670,11 +672,11 @@ void __fastcall TConfigForm::CompatibilityBtnClick(TObject *Sender)
void __fastcall TConfigForm::FormCreate(TObject *Sender) void __fastcall TConfigForm::FormCreate(TObject *Sender)
{ {
/* Let cnc-ddraw create a new ddraw.ini if it doesn't exist */ /* Let cnc-ddraw create a new ddraw.ini if it doesn't exist */
if (FileExists(".\\ddraw.dll") && !FileExists(".\\ddraw.ini")) { if (FileExists(GAME_PATH + "ddraw.dll") && !FileExists(GAME_PATH + "ddraw.ini")) {
SetEnvironmentVariableW(L"cnc_ddraw_config_init", L"1"); SetEnvironmentVariableW(L"cnc_ddraw_config_init", L"1");
HMODULE ddraw = LoadLibraryW(L".\\ddraw.dll"); HMODULE ddraw = LoadLibraryW((GAME_PATH + "ddraw.dll").w_str());
if (ddraw) { if (ddraw) {
@ -694,7 +696,7 @@ void __fastcall TConfigForm::FormCreate(TObject *Sender)
} }
} }
auto *ini = new TIniFile(".\\ddraw.ini"); auto *ini = new TIniFile(GAME_PATH + "ddraw.ini");
if (ini->ReadString("ddraw", "configtheme", "Windows10") == "Cobalt XEMedia") { if (ini->ReadString("ddraw", "configtheme", "Windows10") == "Cobalt XEMedia") {
@ -902,8 +904,8 @@ void __fastcall TConfigForm::FormCreate(TObject *Sender)
CompatibilityBtn->Visible = !GetBool(ini, "hide_compat_tab", false); CompatibilityBtn->Visible = !GetBool(ini, "hide_compat_tab", false);
RestoreDefaultsBtn->Visible = RestoreDefaultsBtn->Visible =
FileExists(".\\ddraw.dll") && FileExists(GAME_PATH + "ddraw.dll") &&
FileExists(".\\ddraw.ini") && FileExists(GAME_PATH + "ddraw.ini") &&
GetBool(ini, "allow_reset", true); GetBool(ini, "allow_reset", true);
delete ini; delete ini;
@ -916,7 +918,7 @@ void TConfigForm::SaveSettings()
if (!Initialized) if (!Initialized)
return; return;
auto *ini = new TIniFile(".\\ddraw.ini"); auto *ini = new TIniFile(GAME_PATH + "ddraw.ini");
/* Display Settings */ /* Display Settings */

View File

@ -3,6 +3,7 @@
#include <vcl.h> #include <vcl.h>
#pragma hdrstop #pragma hdrstop
#include <IniFiles.hpp> #include <IniFiles.hpp>
#include <IOUtils.hpp>
#include <System.Hash.hpp> #include <System.Hash.hpp>
#include <tchar.h> #include <tchar.h>
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
@ -10,6 +11,9 @@
#include <Vcl.Themes.hpp> #include <Vcl.Themes.hpp>
USEFORM("ConfigFormUnit.cpp", ConfigForm); USEFORM("ConfigFormUnit.cpp", ConfigForm);
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
#define GAME_PATH (TPath::GetDirectoryName(Application->ExeName) + "\\")
int WINAPI _tWinMain(HINSTANCE, HINSTANCE, LPTSTR, int) int WINAPI _tWinMain(HINSTANCE, HINSTANCE, LPTSTR, int)
{ {
try try
@ -31,7 +35,7 @@ int WINAPI _tWinMain(HINSTANCE, HINSTANCE, LPTSTR, int)
return 0; return 0;
} }
auto *ini = new TIniFile(".\\ddraw.ini"); auto *ini = new TIniFile(GAME_PATH + "ddraw.ini");
auto theme = ini->ReadString("ddraw", "configtheme", "Windows10"); auto theme = ini->ReadString("ddraw", "configtheme", "Windows10");
TStyleManager::TrySetStyle( TStyleManager::TrySetStyle(