mirror of
https://github.com/ValveSoftware/Proton.git
synced 2025-01-16 00:28:27 +03:00
lsteamclient: Fixup ISteamUser_SteamUser_InitiateGameConnection directly.
CW-Bug-Id: #22729
This commit is contained in:
parent
468731b011
commit
09846111bd
@ -239,7 +239,6 @@ SOURCES = \
|
|||||||
cppISteamUtils_SteamUtils010.cpp \
|
cppISteamUtils_SteamUtils010.cpp \
|
||||||
cppISteamVideo_STEAMVIDEO_INTERFACE_V001.cpp \
|
cppISteamVideo_STEAMVIDEO_INTERFACE_V001.cpp \
|
||||||
cppISteamVideo_STEAMVIDEO_INTERFACE_V002.cpp \
|
cppISteamVideo_STEAMVIDEO_INTERFACE_V002.cpp \
|
||||||
steamclient_manual_099y.cpp \
|
|
||||||
steamclient_manual_141.cpp \
|
steamclient_manual_141.cpp \
|
||||||
steamclient_manual_142.cpp \
|
steamclient_manual_142.cpp \
|
||||||
steamclient_manual_144.cpp \
|
steamclient_manual_144.cpp \
|
||||||
|
@ -18,7 +18,7 @@ struct cppISteamUser_SteamUser008
|
|||||||
virtual int32_t GetHSteamUser( ) = 0;
|
virtual int32_t GetHSteamUser( ) = 0;
|
||||||
virtual bool BLoggedOn( ) = 0;
|
virtual bool BLoggedOn( ) = 0;
|
||||||
virtual CSteamID GetSteamID( ) = 0;
|
virtual CSteamID GetSteamID( ) = 0;
|
||||||
virtual int32_t InitiateGameConnection( void *, int32_t, CSteamID, CGameID, uint32_t, uint16_t, bool, void *, int32_t ) = 0;
|
virtual int32_t InitiateGameConnection( void *, int32_t, CSteamID, CGameID *, uint32_t, uint16_t, bool, void *, int32_t ) = 0;
|
||||||
virtual void TerminateGameConnection( uint32_t, uint16_t ) = 0;
|
virtual void TerminateGameConnection( uint32_t, uint16_t ) = 0;
|
||||||
virtual void TrackAppUsageEvent( CGameID, int32_t, const char * ) = 0;
|
virtual void TrackAppUsageEvent( CGameID, int32_t, const char * ) = 0;
|
||||||
virtual void RefreshSteam2Login( ) = 0;
|
virtual void RefreshSteam2Login( ) = 0;
|
||||||
@ -43,6 +43,12 @@ void cppISteamUser_SteamUser008_GetSteamID( struct cppISteamUser_SteamUser008_Ge
|
|||||||
*params->_ret = iface->GetSteamID( );
|
*params->_ret = iface->GetSteamID( );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void cppISteamUser_SteamUser008_InitiateGameConnection( struct cppISteamUser_SteamUser008_InitiateGameConnection_params *params )
|
||||||
|
{
|
||||||
|
struct cppISteamUser_SteamUser008 *iface = (struct cppISteamUser_SteamUser008 *)params->linux_side;
|
||||||
|
params->_ret = iface->InitiateGameConnection( params->pBlob, params->cbMaxBlob, params->steamID, ¶ms->gameID, params->unIPServer, params->usPortServer, params->bSecure, params->pvSteam2GetEncryptionKey, params->cbSteam2GetEncryptionKey );
|
||||||
|
}
|
||||||
|
|
||||||
void cppISteamUser_SteamUser008_TerminateGameConnection( struct cppISteamUser_SteamUser008_TerminateGameConnection_params *params )
|
void cppISteamUser_SteamUser008_TerminateGameConnection( struct cppISteamUser_SteamUser008_TerminateGameConnection_params *params )
|
||||||
{
|
{
|
||||||
struct cppISteamUser_SteamUser008 *iface = (struct cppISteamUser_SteamUser008 *)params->linux_side;
|
struct cppISteamUser_SteamUser008 *iface = (struct cppISteamUser_SteamUser008 *)params->linux_side;
|
||||||
|
@ -229,13 +229,6 @@ MANUAL_METHODS = {
|
|||||||
Method("DestroyFakeUDPPort"),
|
Method("DestroyFakeUDPPort"),
|
||||||
Method("ReceiveMessages"),
|
Method("ReceiveMessages"),
|
||||||
],
|
],
|
||||||
"cppISteamUser_SteamUser": [
|
|
||||||
#TODO: Do we need the the value -> pointer conversion for other versions of the interface?
|
|
||||||
Method("InitiateGameConnection", lambda version: version == 8),
|
|
||||||
],
|
|
||||||
#"cppISteamClient_SteamClient": [
|
|
||||||
# Method("BShutdownIfAllPipesClosed"),
|
|
||||||
#],
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -482,6 +475,14 @@ class Class:
|
|||||||
for method in self.methods:
|
for method in self.methods:
|
||||||
types = [declspec(p, "", prefix if prefix != "cpp" else None)
|
types = [declspec(p, "", prefix if prefix != "cpp" else None)
|
||||||
for p in method.get_arguments()]
|
for p in method.get_arguments()]
|
||||||
|
|
||||||
|
# CGameID -> CGameID &
|
||||||
|
# Windows side follows the prototype in the header while Linux
|
||||||
|
# steamclient treats gameID parameter as pointer
|
||||||
|
if self.full_name == 'ISteamUser_SteamUser008' \
|
||||||
|
and method.name == 'InitiateGameConnection':
|
||||||
|
types[3] = 'CGameID *'
|
||||||
|
|
||||||
if type(method) is Destructor:
|
if type(method) is Destructor:
|
||||||
out(f' virtual ~{prefix}{self.full_name}( {", ".join(types)} ) = 0;\n')
|
out(f' virtual ~{prefix}{self.full_name}( {", ".join(types)} ) = 0;\n')
|
||||||
else:
|
else:
|
||||||
@ -728,6 +729,14 @@ def handle_method_cpp(method, classname, cppname, out):
|
|||||||
return f'params->{name}'
|
return f'params->{name}'
|
||||||
|
|
||||||
params = [param_call(n, p) for n, p in zip(names[1:], method.get_arguments())]
|
params = [param_call(n, p) for n, p in zip(names[1:], method.get_arguments())]
|
||||||
|
|
||||||
|
# CGameID -> CGameID &
|
||||||
|
# Windows side follows the prototype in the header while Linux
|
||||||
|
# steamclient treats gameID parameter as pointer
|
||||||
|
if klass.full_name == 'ISteamUser_SteamUser008' \
|
||||||
|
and method.name == 'InitiateGameConnection':
|
||||||
|
params[3] = f'&{params[3]}'
|
||||||
|
|
||||||
out(f'iface->{method.spelling}( {", ".join(params)} );\n')
|
out(f'iface->{method.spelling}( {", ".join(params)} );\n')
|
||||||
|
|
||||||
for name, param in sorted(need_output.items()):
|
for name, param in sorted(need_output.items()):
|
||||||
|
@ -1,47 +0,0 @@
|
|||||||
#include "steamclient_private.h"
|
|
||||||
|
|
||||||
#include "steam_defs.h"
|
|
||||||
#pragma push_macro("__cdecl")
|
|
||||||
#undef __cdecl
|
|
||||||
#pragma push_macro("strncpy")
|
|
||||||
#undef strncpy
|
|
||||||
#include "steamworks_sdk_099y/steam_api.h"
|
|
||||||
#pragma pop_macro("__cdecl")
|
|
||||||
#pragma pop_macro("strncpy")
|
|
||||||
|
|
||||||
#define SDK_VERSION 992
|
|
||||||
#include "steamclient_manual_common.h"
|
|
||||||
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#include "cppISteamUser_SteamUser008.h"
|
|
||||||
}
|
|
||||||
|
|
||||||
WINE_DEFAULT_DEBUG_CHANNEL(steamclient);
|
|
||||||
|
|
||||||
class ISteamUser_linux
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
virtual HSteamUser GetHSteamUser() = 0;
|
|
||||||
virtual bool BLoggedOn() = 0;
|
|
||||||
virtual CSteamID GetSteamID() = 0;
|
|
||||||
|
|
||||||
/* CGameID -> CGameID &.
|
|
||||||
* Windows side follows the prototype in the header while Linux
|
|
||||||
* steamclient treats gameID parameter as pointer. */
|
|
||||||
virtual int InitiateGameConnection( void *pBlob, int cbMaxBlob, CSteamID steamID, CGameID &gameID, uint32 unIPServer, uint16 usPortServer, bool bSecure, void *pvSteam2GetEncryptionKey, int cbSteam2GetEncryptionKey ) = 0;
|
|
||||||
|
|
||||||
virtual void TerminateGameConnection( uint32 unIPServer, uint16 usPortServer ) = 0;
|
|
||||||
virtual void TrackAppUsageEvent( CGameID gameID, int eAppUsageEvent, const char *pchExtraInfo = "" ) = 0;
|
|
||||||
virtual void RefreshSteam2Login() = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
void cppISteamUser_SteamUser008_InitiateGameConnection( struct cppISteamUser_SteamUser008_InitiateGameConnection_params *params )
|
|
||||||
{
|
|
||||||
ISteamUser_linux *iface = (ISteamUser_linux *)params->linux_side;
|
|
||||||
WARN( "Manual call fixup.\n" );
|
|
||||||
params->_ret = iface->InitiateGameConnection( params->pBlob, params->cbMaxBlob, params->steamID,
|
|
||||||
params->gameID, params->unIPServer, params->usPortServer,
|
|
||||||
params->bSecure, params->pvSteam2GetEncryptionKey,
|
|
||||||
params->cbSteam2GetEncryptionKey );
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user