mirror of
https://github.com/ValveSoftware/Proton.git
synced 2025-01-15 16:18:20 +03:00
lsteamclient: Simplify unix side parameter conversions.
CW-Bug-Id: #22729
This commit is contained in:
parent
87a65c1993
commit
d8038254d4
@ -100,7 +100,6 @@ bool cppISteamParties_SteamParties002_GetBeaconLocationData(void *linux_side, wi
|
|||||||
SteamPartyBeaconLocation_t lin_BeaconLocation;
|
SteamPartyBeaconLocation_t lin_BeaconLocation;
|
||||||
win_to_lin_struct_SteamPartyBeaconLocation_t_158(&BeaconLocation, &lin_BeaconLocation);
|
win_to_lin_struct_SteamPartyBeaconLocation_t_158(&BeaconLocation, &lin_BeaconLocation);
|
||||||
_ret = ((ISteamParties*)linux_side)->GetBeaconLocationData(lin_BeaconLocation, (ESteamPartyBeaconLocationData)eData, (char *)pchDataStringOut, (int)cchDataStringOut);
|
_ret = ((ISteamParties*)linux_side)->GetBeaconLocationData(lin_BeaconLocation, (ESteamPartyBeaconLocationData)eData, (char *)pchDataStringOut, (int)cchDataStringOut);
|
||||||
lin_to_win_struct_SteamPartyBeaconLocation_t_158(&lin_BeaconLocation, &BeaconLocation);
|
|
||||||
return (_ret);
|
return (_ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -483,6 +483,10 @@ def canonical_typename(cursor):
|
|||||||
return name.removeprefix("const ")
|
return name.removeprefix("const ")
|
||||||
|
|
||||||
|
|
||||||
|
def underlying_typename(decl):
|
||||||
|
return canonical_typename(underlying_type(decl))
|
||||||
|
|
||||||
|
|
||||||
def find_struct_abis(name):
|
def find_struct_abis(name):
|
||||||
records = all_records[sdkver]
|
records = all_records[sdkver]
|
||||||
missing = [name not in records[abi] for abi in ABIS]
|
missing = [name not in records[abi] for abi in ABIS]
|
||||||
@ -621,21 +625,27 @@ def handle_method_cpp(method, classname, cppname, out):
|
|||||||
if not returns_void:
|
if not returns_void:
|
||||||
out(f' {declspec(method.result_type, "_ret")};\n')
|
out(f' {declspec(method.result_type, "_ret")};\n')
|
||||||
|
|
||||||
|
need_output = {}
|
||||||
|
|
||||||
for name, param in sorted(need_convert.items()):
|
for name, param in sorted(need_convert.items()):
|
||||||
if param.type.kind == TypeKind.POINTER:
|
type_name = underlying_typename(param)
|
||||||
#handle single pointers, but not double pointers
|
|
||||||
real_type = param.type
|
if param.type.kind != TypeKind.POINTER:
|
||||||
while real_type.kind == TypeKind.POINTER:
|
out(f' {type_name} lin_{name};\n')
|
||||||
real_type = real_type.get_pointee()
|
out(f' win_to_lin_struct_{type_name}_{sdkver}(&{name}, &lin_{name});\n')
|
||||||
real_name = canonical_typename(real_type)
|
continue
|
||||||
assert(param.type.get_pointee().kind == TypeKind.RECORD or real_name in MANUAL_STRUCTS)
|
|
||||||
pointee_name = canonical_typename(param.type.get_pointee())
|
pointee = param.type.get_pointee()
|
||||||
out(f' {pointee_name} lin_{name};\n')
|
if pointee.kind == TypeKind.POINTER:
|
||||||
out(f' win_to_lin_struct_{real_name}_{sdkver}({name}, &lin_{name});\n')
|
need_output[name] = param
|
||||||
else:
|
out(f' {type_name} *lin_{name};\n')
|
||||||
#raw structs
|
continue
|
||||||
out(f' {param.type.spelling} lin_{name};\n')
|
|
||||||
out(f' win_to_lin_struct_{param.type.spelling}_{sdkver}(&{name}, &lin_{name});\n')
|
if not pointee.is_const_qualified():
|
||||||
|
need_output[name] = param
|
||||||
|
|
||||||
|
out(f' {type_name} lin_{name};\n')
|
||||||
|
out(f' win_to_lin_struct_{type_name}_{sdkver}({name}, &lin_{name});\n')
|
||||||
|
|
||||||
for name, param in sorted(manual_convert.items()):
|
for name, param in sorted(manual_convert.items()):
|
||||||
if name in MANUAL_PARAMS:
|
if name in MANUAL_PARAMS:
|
||||||
@ -657,15 +667,9 @@ def handle_method_cpp(method, classname, cppname, out):
|
|||||||
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())]
|
||||||
out(f'(({classname}*)linux_side)->{method.spelling}({", ".join(params)});\n')
|
out(f'(({classname}*)linux_side)->{method.spelling}({", ".join(params)});\n')
|
||||||
|
|
||||||
for name, param in sorted(need_convert.items()):
|
for name, param in sorted(need_output.items()):
|
||||||
if param.type.kind == TypeKind.POINTER:
|
type_name = underlying_typename(param)
|
||||||
if not "const " in param.type.spelling: #don't modify const arguments
|
out(f' lin_to_win_struct_{type_name}_{sdkver}(&lin_{name}, {name});\n')
|
||||||
real_type = param.type
|
|
||||||
while real_type.kind == TypeKind.POINTER:
|
|
||||||
real_type = real_type.get_pointee()
|
|
||||||
out(f' lin_to_win_struct_{real_type.spelling}_{sdkver}(&lin_{name}, {name});\n')
|
|
||||||
else:
|
|
||||||
out(f' lin_to_win_struct_{param.type.spelling}_{sdkver}(&lin_{name}, &{name});\n')
|
|
||||||
|
|
||||||
if method.result_type.kind != TypeKind.VOID:
|
if method.result_type.kind != TypeKind.VOID:
|
||||||
post_exec = post_execution_function(classname, method.spelling)
|
post_exec = post_execution_function(classname, method.spelling)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user