1 Commits
v2.7.0 ... 193

Author SHA1 Message Date
Tixx
db1aad37a8 Change and debug CreateProcessW params 2025-09-23 22:40:36 +02:00
8 changed files with 22 additions and 23 deletions

View File

@@ -38,7 +38,6 @@ extern std::string MStatus;
extern std::string UlStatus; extern std::string UlStatus;
extern std::string PublicKey; extern std::string PublicKey;
extern std::string PrivateKey; extern std::string PrivateKey;
extern std::string magic;
int KillSocket(uint64_t Dead); int KillSocket(uint64_t Dead);
void UUl(const std::string& R); void UUl(const std::string& R);
void UDPSend(std::string Data); void UDPSend(std::string Data);

View File

@@ -21,14 +21,12 @@
#define beammp_fs_string std::wstring #define beammp_fs_string std::wstring
#define beammp_fs_char wchar_t #define beammp_fs_char wchar_t
#define beammp_wide(str) L##str #define beammp_wide(str) L##str
#define beammp_stdout std::wcout
#define WIN32_LEAN_AND_MEAN #define WIN32_LEAN_AND_MEAN
#include <windows.h> #include <windows.h>
#else #else
#define beammp_fs_string std::string #define beammp_fs_string std::string
#define beammp_fs_char char #define beammp_fs_char char
#define beammp_wide(str) str #define beammp_wide(str) str
#define beammp_stdout std::cout
#endif #endif
namespace Utils { namespace Utils {
@@ -122,6 +120,13 @@ namespace Utils {
if (line.empty() || line[0] == ';' || line[0] == '#') if (line.empty() || line[0] == ';' || line[0] == '#')
continue; continue;
for (auto& c : line) {
if (c == '#' || c == ';') {
line = line.substr(0, &c - &line[0]);
break;
}
}
auto invalidLineLog = [&]{ auto invalidLineLog = [&]{
debug("Invalid INI line: " + line); debug("Invalid INI line: " + line);
debug("Surrounding lines: \n" + debug("Surrounding lines: \n" +

View File

@@ -148,7 +148,13 @@ void StartGame(std::wstring Dir) {
debug(L"BeamNG executable path: " + Dir); debug(L"BeamNG executable path: " + Dir);
bSuccess = CreateProcessW(nullptr, (wchar_t*)(Dir + gameArgs).c_str(), nullptr, nullptr, TRUE, 0, nullptr, BaseDir.c_str(), &si, &pi); wchar_t* lpApplicationName = Dir.data();
wchar_t* lpCommandLine = (Dir + gameArgs).data();
debug(L"lpApplicationName: " + std::wstring(lpApplicationName));
debug(L"lpCommandLine: " + std::wstring(lpCommandLine));
bSuccess = CreateProcessW(lpApplicationName, lpCommandLine, nullptr, nullptr, TRUE, 0, nullptr, BaseDir.c_str(), &si, &pi);
if (bSuccess) { if (bSuccess) {
info("Game Launched!"); info("Game Launched!");
GamePID = pi.dwProcessId; GamePID = pi.dwProcessId;

View File

@@ -57,36 +57,36 @@ void addToLog(const std::wstring& Line) {
} }
void info(const std::string& toPrint) { void info(const std::string& toPrint) {
std::string Print = getDate() + "[INFO] " + toPrint + "\n"; std::string Print = getDate() + "[INFO] " + toPrint + "\n";
beammp_stdout << Utils::ToWString(Print); std::cout << Print;
addToLog(Print); addToLog(Print);
} }
void debug(const std::string& toPrint) { void debug(const std::string& toPrint) {
std::string Print = getDate() + "[DEBUG] " + toPrint + "\n"; std::string Print = getDate() + "[DEBUG] " + toPrint + "\n";
if (options.verbose) { if (options.verbose) {
beammp_stdout << Utils::ToWString(Print); std::cout << Print;
} }
addToLog(Print); addToLog(Print);
} }
void warn(const std::string& toPrint) { void warn(const std::string& toPrint) {
std::string Print = getDate() + "[WARN] " + toPrint + "\n"; std::string Print = getDate() + "[WARN] " + toPrint + "\n";
beammp_stdout << Utils::ToWString(Print); std::cout << Print;
addToLog(Print); addToLog(Print);
} }
void error(const std::string& toPrint) { void error(const std::string& toPrint) {
std::string Print = getDate() + "[ERROR] " + toPrint + "\n"; std::string Print = getDate() + "[ERROR] " + toPrint + "\n";
beammp_stdout << Utils::ToWString(Print); std::cout << Print;
addToLog(Print); addToLog(Print);
} }
void fatal(const std::string& toPrint) { void fatal(const std::string& toPrint) {
std::string Print = getDate() + "[FATAL] " + toPrint + "\n"; std::string Print = getDate() + "[FATAL] " + toPrint + "\n";
beammp_stdout << Utils::ToWString(Print); std::cout << Print;
addToLog(Print); addToLog(Print);
std::this_thread::sleep_for(std::chrono::seconds(5)); std::this_thread::sleep_for(std::chrono::seconds(5));
std::exit(1); std::exit(1);
} }
void except(const std::string& toPrint) { void except(const std::string& toPrint) {
std::string Print = getDate() + "[EXCEP] " + toPrint + "\n"; std::string Print = getDate() + "[EXCEP] " + toPrint + "\n";
beammp_stdout << Utils::ToWString(Print); std::cout << Print;
addToLog(Print); addToLog(Print);
} }

View File

@@ -33,7 +33,6 @@ bool GConnected = false;
bool CServer = true; bool CServer = true;
SOCKET CSocket = -1; SOCKET CSocket = -1;
SOCKET GSocket = -1; SOCKET GSocket = -1;
std::string magic;
int KillSocket(uint64_t Dead) { int KillSocket(uint64_t Dead) {
if (Dead == (SOCKET)-1) { if (Dead == (SOCKET)-1) {
@@ -219,8 +218,6 @@ void ParserAsync(std::string_view Data) {
MStatus = Data; MStatus = Data;
UlStatus = "Uldone"; UlStatus = "Uldone";
return; return;
case 'U':
magic = Data.substr(1);
default: default:
break; break;
} }

View File

@@ -93,8 +93,6 @@ void UDPClientMain(const std::string& IP, int Port) {
ToServer->sin_port = htons(Port); ToServer->sin_port = htons(Port);
inet_pton(AF_INET, IP.c_str(), &ToServer->sin_addr); inet_pton(AF_INET, IP.c_str(), &ToServer->sin_addr);
UDPSock = socket(AF_INET, SOCK_DGRAM, 0); UDPSock = socket(AF_INET, SOCK_DGRAM, 0);
if (!magic.empty())
UDPSend(magic);
GameSend("P" + std::to_string(ClientID)); GameSend("P" + std::to_string(ClientID));
TCPSend("H", TCPSock); TCPSend("H", TCPSock);
UDPSend("p"); UDPSend("p");

View File

@@ -177,10 +177,6 @@ void LegitimacyCheck() {
std::string contents((std::istreambuf_iterator(beamngIni)), std::istreambuf_iterator<char>()); std::string contents((std::istreambuf_iterator(beamngIni)), std::istreambuf_iterator<char>());
beamngIni.close(); beamngIni.close();
if (contents.size() >= 3 && (unsigned char)contents[0] == 0xEF && (unsigned char)contents[1] == 0xBB && (unsigned char)contents[2] == 0xBF) {
contents = contents.substr(3);
}
auto ini = Utils::ParseINI(contents); auto ini = Utils::ParseINI(contents);
if (ini.empty()) if (ini.empty())
lowExit(3); lowExit(3);

View File

@@ -84,10 +84,10 @@ beammp_fs_string GetEN() {
} }
std::string GetVer() { std::string GetVer() {
return "2.7"; return "2.6";
} }
std::string GetPatch() { std::string GetPatch() {
return ".0"; return ".3";
} }
beammp_fs_string GetEP(const beammp_fs_char* P) { beammp_fs_string GetEP(const beammp_fs_char* P) {
@@ -269,8 +269,6 @@ void LinuxPatch() {
void InitLauncher() { void InitLauncher() {
SetConsoleTitleA(("BeamMP Launcher v" + std::string(GetVer()) + GetPatch()).c_str()); SetConsoleTitleA(("BeamMP Launcher v" + std::string(GetVer()) + GetPatch()).c_str());
SetConsoleOutputCP(CP_UTF8);
_setmode(_fileno(stdout), _O_U8TEXT);
debug("Launcher Version : " + GetVer() + GetPatch()); debug("Launcher Version : " + GetVer() + GetPatch());
CheckName(); CheckName();
LinuxPatch(); LinuxPatch();