mirror of https://github.com/PCSX2/pcsx2.git
PAD: fix ini on windows
This commit is contained in:
parent
093e19aae6
commit
dc5e4e61c5
|
@ -36,6 +36,7 @@
|
||||||
#include "KeyboardQueue.h"
|
#include "KeyboardQueue.h"
|
||||||
#include "svnrev.h"
|
#include "svnrev.h"
|
||||||
#include "DualShock3.h"
|
#include "DualShock3.h"
|
||||||
|
#include "AppConfig.h"
|
||||||
#include <timeapi.h>
|
#include <timeapi.h>
|
||||||
#include "Utilities/pxStreams.h"
|
#include "Utilities/pxStreams.h"
|
||||||
|
|
||||||
|
@ -477,24 +478,6 @@ char padReadKeyUpdated[4] = {0, 0, 0, 0};
|
||||||
#define LOCK_BUTTONS 4
|
#define LOCK_BUTTONS 4
|
||||||
#define LOCK_BOTH 1
|
#define LOCK_BOTH 1
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
struct EnterScopedSection
|
|
||||||
{
|
|
||||||
CRITICAL_SECTION& m_cs;
|
|
||||||
|
|
||||||
EnterScopedSection(CRITICAL_SECTION& cs)
|
|
||||||
: m_cs(cs)
|
|
||||||
{
|
|
||||||
EnterCriticalSection(&m_cs);
|
|
||||||
}
|
|
||||||
|
|
||||||
~EnterScopedSection()
|
|
||||||
{
|
|
||||||
LeaveCriticalSection(&m_cs);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void Update(unsigned int port, unsigned int slot)
|
void Update(unsigned int port, unsigned int slot)
|
||||||
{
|
{
|
||||||
char* stateUpdated;
|
char* stateUpdated;
|
||||||
|
|
|
@ -44,7 +44,6 @@ typedef struct
|
||||||
unsigned char reserved[91];
|
unsigned char reserved[91];
|
||||||
} PadDataS;
|
} PadDataS;
|
||||||
|
|
||||||
|
|
||||||
void PADupdate(int pad);
|
void PADupdate(int pad);
|
||||||
void PADshutdown();
|
void PADshutdown();
|
||||||
s32 PADinit();
|
s32 PADinit();
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
#include "KeyboardQueue.h"
|
#include "KeyboardQueue.h"
|
||||||
#include "WndProcEater.h"
|
#include "WndProcEater.h"
|
||||||
#include "DualShock3.h"
|
#include "DualShock3.h"
|
||||||
|
#include "PAD.h"
|
||||||
|
|
||||||
#include <Shlwapi.h>
|
#include <Shlwapi.h>
|
||||||
|
|
||||||
|
@ -33,6 +34,7 @@
|
||||||
#include "PADRawInput.h"
|
#include "PADRawInput.h"
|
||||||
#include <commdlg.h>
|
#include <commdlg.h>
|
||||||
#include <timeapi.h>
|
#include <timeapi.h>
|
||||||
|
#include "AppConfig.h"
|
||||||
|
|
||||||
//max len 24 wchar_t
|
//max len 24 wchar_t
|
||||||
const wchar_t* padTypes[] = {
|
const wchar_t* padTypes[] = {
|
||||||
|
@ -331,20 +333,21 @@ wchar_t* GetCommandStringW(u8 command, int port, int slot)
|
||||||
return L"";
|
return L"";
|
||||||
}
|
}
|
||||||
|
|
||||||
static wchar_t iniFile[MAX_PATH * 2] = L"inis/PAD.ini";
|
static wchar_t iniFileUSB[MAX_PATH * 2] = L"inis/PAD.ini";
|
||||||
|
|
||||||
|
// we disregard dir and use global settings instead, we should probably clean that up someday...
|
||||||
void PADsetSettingsDir(const char* dir)
|
void PADsetSettingsDir(const char* dir)
|
||||||
{
|
{
|
||||||
//swprintf_s( iniFile, L"%S", (dir==NULL) ? "inis" : dir );
|
//swprintf_s( iniFileUSB, L"%S", (dir==NULL) ? "inis" : dir );
|
||||||
|
|
||||||
//uint targlen = MultiByteToWideChar(CP_ACP, 0, dir, -1, NULL, 0);
|
//uint targlen = MultiByteToWideChar(CP_ACP, 0, dir, -1, NULL, 0);
|
||||||
MultiByteToWideChar(CP_UTF8, 0, dir, -1, iniFile, MAX_PATH * 2);
|
wxString iniName = "PAD.ini";
|
||||||
wcscat_s(iniFile, L"/PAD.ini");
|
MultiByteToWideChar(CP_UTF8, 0, std::string(GetSettingsFolder().Combine(iniName).GetFullPath()).c_str(), -1, iniFileUSB, MAX_PATH * 2);
|
||||||
|
|
||||||
createIniDir = false;
|
createIniDir = false;
|
||||||
|
|
||||||
FILE* temp = nullptr;
|
FILE* temp = nullptr;
|
||||||
_wfopen_s(&temp, iniFile, L"r");
|
_wfopen_s(&temp, iniFileUSB, L"r");
|
||||||
if (!temp)
|
if (!temp)
|
||||||
{ // File not found, possibly.
|
{ // File not found, possibly.
|
||||||
HRSRC res = FindResource(hInst, MAKEINTRESOURCE(IDR_INI1), RT_RCDATA);
|
HRSRC res = FindResource(hInst, MAKEINTRESOURCE(IDR_INI1), RT_RCDATA);
|
||||||
|
@ -355,7 +358,7 @@ void PADsetSettingsDir(const char* dir)
|
||||||
return;
|
return;
|
||||||
size_t size = SizeofResource(hInst, res);
|
size_t size = SizeofResource(hInst, res);
|
||||||
u8* fdata = (u8*)LockResource(data);
|
u8* fdata = (u8*)LockResource(data);
|
||||||
_wfopen_s(&temp, iniFile, L"w");
|
_wfopen_s(&temp, iniFileUSB, L"w");
|
||||||
if (!temp)
|
if (!temp)
|
||||||
return;
|
return;
|
||||||
fwrite(fdata, 1, size, temp);
|
fwrite(fdata, 1, size, temp);
|
||||||
|
@ -933,7 +936,7 @@ int SaveSettings(wchar_t* file = 0)
|
||||||
// Need this either way for saving path.
|
// Need this either way for saving path.
|
||||||
if (!file)
|
if (!file)
|
||||||
{
|
{
|
||||||
file = iniFile;
|
file = iniFileUSB;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -948,8 +951,8 @@ int SaveSettings(wchar_t* file = 0)
|
||||||
}
|
}
|
||||||
DeleteFileW(file);
|
DeleteFileW(file);
|
||||||
|
|
||||||
WritePrivateProfileStringW(L"General Settings", L"Last Config Path", config.lastSaveConfigPath, iniFile);
|
WritePrivateProfileStringW(L"General Settings", L"Last Config Path", config.lastSaveConfigPath, iniFileUSB);
|
||||||
WritePrivateProfileStringW(L"General Settings", L"Last Config Name", config.lastSaveConfigFileName, iniFile);
|
WritePrivateProfileStringW(L"General Settings", L"Last Config Name", config.lastSaveConfigFileName, iniFileUSB);
|
||||||
|
|
||||||
// Just check first, last, and all pad bindings. Should be more than enough. No real need to check
|
// Just check first, last, and all pad bindings. Should be more than enough. No real need to check
|
||||||
// config path.
|
// config path.
|
||||||
|
@ -1063,7 +1066,7 @@ int LoadSettings(int force, wchar_t* file)
|
||||||
|
|
||||||
if (!file)
|
if (!file)
|
||||||
{
|
{
|
||||||
file = iniFile;
|
file = iniFileUSB;
|
||||||
GetPrivateProfileStringW(L"General Settings", L"Last Config Path", L"inis", config.lastSaveConfigPath, sizeof(config.lastSaveConfigPath), file);
|
GetPrivateProfileStringW(L"General Settings", L"Last Config Path", L"inis", config.lastSaveConfigPath, sizeof(config.lastSaveConfigPath), file);
|
||||||
GetPrivateProfileStringW(L"General Settings", L"Last Config Name", L"PAD.pad", config.lastSaveConfigFileName, sizeof(config.lastSaveConfigFileName), file);
|
GetPrivateProfileStringW(L"General Settings", L"Last Config Name", L"PAD.pad", config.lastSaveConfigFileName, sizeof(config.lastSaveConfigFileName), file);
|
||||||
}
|
}
|
||||||
|
@ -1076,8 +1079,8 @@ int LoadSettings(int force, wchar_t* file)
|
||||||
wcscpy(config.lastSaveConfigPath, file);
|
wcscpy(config.lastSaveConfigPath, file);
|
||||||
wcscpy(config.lastSaveConfigFileName, c + 1);
|
wcscpy(config.lastSaveConfigFileName, c + 1);
|
||||||
*c = '\\';
|
*c = '\\';
|
||||||
WritePrivateProfileStringW(L"General Settings", L"Last Config Path", config.lastSaveConfigPath, iniFile);
|
WritePrivateProfileStringW(L"General Settings", L"Last Config Path", config.lastSaveConfigPath, iniFileUSB);
|
||||||
WritePrivateProfileStringW(L"General Settings", L"Last Config Name", config.lastSaveConfigFileName, iniFile);
|
WritePrivateProfileStringW(L"General Settings", L"Last Config Name", config.lastSaveConfigFileName, iniFileUSB);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
std::map<std::pair<int, std::string>, std::string> changedAPIs;
|
std::map<std::pair<int, std::string>, std::string> changedAPIs;
|
||||||
wxString iniFile(L"USB.ini");
|
wxString iniFileUSB(L"USB.ini");
|
||||||
static TSTDSTRING usb_path;
|
static TSTDSTRING usb_path;
|
||||||
TSTDSTRING IniPath; // default path, just in case
|
TSTDSTRING IniPath; // default path, just in case
|
||||||
TSTDSTRING LogDir;
|
TSTDSTRING LogDir;
|
||||||
|
@ -35,9 +35,9 @@ void USBsetSettingsDir()
|
||||||
if(!USBpathSet)
|
if(!USBpathSet)
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
IniPath = GetSettingsFolder().Combine( iniFile ).GetFullPath(); // default path, just in case
|
IniPath = GetSettingsFolder().Combine( iniFileUSB ).GetFullPath(); // default path, just in case
|
||||||
#else
|
#else
|
||||||
IniPath = std::string(GetSettingsFolder().Combine( iniFile ).GetFullPath()); // default path, just in case
|
IniPath = std::string(GetSettingsFolder().Combine( iniFileUSB ).GetFullPath()); // default path, just in case
|
||||||
#endif
|
#endif
|
||||||
USBpathSet = true;
|
USBpathSet = true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,7 +71,6 @@ void RemoveSection(const char* dev_type, int port, const std::string& key);
|
||||||
|
|
||||||
extern TSTDSTRING IniPath;
|
extern TSTDSTRING IniPath;
|
||||||
extern TSTDSTRING LogDir;
|
extern TSTDSTRING LogDir;
|
||||||
extern wxString iniFile;
|
|
||||||
extern std::map<std::pair<int /*port*/, std::string /*devname*/>, std::string> changedAPIs;
|
extern std::map<std::pair<int /*port*/, std::string /*devname*/>, std::string> changedAPIs;
|
||||||
std::string GetSelectedAPI(const std::pair<int /*port*/, std::string /*devname*/>& pair);
|
std::string GetSelectedAPI(const std::pair<int /*port*/, std::string /*devname*/>& pair);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue