[Proxy] Set mod before setting the game
This commit is contained in:
parent
495a55e135
commit
6e718fc929
@ -75,17 +75,17 @@ namespace Steam
|
|||||||
void Proxy::SetGame(uint32_t appId)
|
void Proxy::SetGame(uint32_t appId)
|
||||||
{
|
{
|
||||||
Proxy::AppId = appId;
|
Proxy::AppId = appId;
|
||||||
|
remove("steam_appid.txt");
|
||||||
|
}
|
||||||
|
|
||||||
|
void Proxy::RunGame()
|
||||||
|
{
|
||||||
if (!Components::Flags::HasFlag("nosteam") && !Components::Dedicated::IsEnabled())
|
if (!Components::Flags::HasFlag("nosteam") && !Components::Dedicated::IsEnabled())
|
||||||
{
|
{
|
||||||
SetEnvironmentVariableA("SteamAppId", ::Utils::String::VA("%lu", appId));
|
SetEnvironmentVariableA("SteamAppId", ::Utils::String::VA("%lu", Proxy::AppId));
|
||||||
SetEnvironmentVariableA("SteamGameId", ::Utils::String::VA("%llu", appId & 0xFFFFFF));
|
SetEnvironmentVariableA("SteamGameId", ::Utils::String::VA("%llu", Proxy::AppId & 0xFFFFFF));
|
||||||
|
|
||||||
::Utils::IO::WriteFile("steam_appid.txt", ::Utils::String::VA("%lu", appId), false);
|
::Utils::IO::WriteFile("steam_appid.txt", ::Utils::String::VA("%lu", Proxy::AppId), false);
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
remove("steam_appid.txt");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -100,7 +100,7 @@ namespace Steam
|
|||||||
|
|
||||||
Interface clientApps(Proxy::ClientEngine->GetIClientApps(Proxy::SteamUser, Proxy::SteamPipe, "CLIENTAPPS_INTERFACE_VERSION001"));
|
Interface clientApps(Proxy::ClientEngine->GetIClientApps(Proxy::SteamUser, Proxy::SteamPipe, "CLIENTAPPS_INTERFACE_VERSION001"));
|
||||||
Interface clientShortcuts(Proxy::ClientEngine->GetIClientShortcuts(Proxy::SteamUser, Proxy::SteamPipe, "CLIENTSHORTCUTS_INTERFACE_VERSION001"));
|
Interface clientShortcuts(Proxy::ClientEngine->GetIClientShortcuts(Proxy::SteamUser, Proxy::SteamPipe, "CLIENTSHORTCUTS_INTERFACE_VERSION001"));
|
||||||
if (!clientApps || clientShortcuts) return;
|
if (!clientApps || !clientShortcuts) return;
|
||||||
|
|
||||||
KeyValuesBuilder builder;
|
KeyValuesBuilder builder;
|
||||||
builder.packString("name", mod.data());
|
builder.packString("name", mod.data());
|
||||||
@ -114,6 +114,9 @@ namespace Steam
|
|||||||
uint32_t uniqueId = clientShortcuts.invoke<uint32_t>("GetUniqueLocalAppId");
|
uint32_t uniqueId = clientShortcuts.invoke<uint32_t>("GetUniqueLocalAppId");
|
||||||
if (clientApps.invoke<bool>("SetLocalAppConfig", uniqueId, str.data(), static_cast<uint32_t>(str.size())))
|
if (clientApps.invoke<bool>("SetLocalAppConfig", uniqueId, str.data(), static_cast<uint32_t>(str.size())))
|
||||||
{
|
{
|
||||||
|
Interface clientUtils(Proxy::ClientEngine->GetIClientUtils(Proxy::SteamPipe, "CLIENTUTILS_INTERFACE_VERSION001"));
|
||||||
|
clientUtils.invoke<void>("SetAppIDForCurrentPipe", Proxy::AppId, false);
|
||||||
|
|
||||||
char ourPath[MAX_PATH] = { 0 };
|
char ourPath[MAX_PATH] = { 0 };
|
||||||
GetModuleFileNameA(GetModuleHandle(nullptr), ourPath, sizeof(ourPath));
|
GetModuleFileNameA(GetModuleHandle(nullptr), ourPath, sizeof(ourPath));
|
||||||
|
|
||||||
|
@ -185,6 +185,8 @@ namespace Steam
|
|||||||
static void Uninititalize();
|
static void Uninititalize();
|
||||||
|
|
||||||
static void SetGame(uint32_t appId);
|
static void SetGame(uint32_t appId);
|
||||||
|
static void RunGame();
|
||||||
|
|
||||||
static void SetMod(std::string mod);
|
static void SetMod(std::string mod);
|
||||||
static void RunMod();
|
static void RunMod();
|
||||||
|
|
||||||
|
@ -115,7 +115,8 @@ namespace Steam
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Steam::Proxy::SetMod("IW4x \xF0\x9F\x90\x8D");
|
Proxy::SetMod("IW4x \xF0\x9F\x90\x8D");
|
||||||
|
Proxy::RunGame();
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
Loading…
Reference in New Issue
Block a user