mirror of
https://github.com/ValveSoftware/Proton.git
synced 2025-01-16 16:47:58 +03:00
lsteamclient: Use the names array for the param converters.
CW-Bug-Id: #22729
This commit is contained in:
parent
f8a14dfd27
commit
4fc0934c83
@ -765,19 +765,19 @@ def handle_method_cpp(method_name, classname, cppname, method, cpp):
|
|||||||
for i, p in enumerate(method.get_arguments())]
|
for i, p in enumerate(method.get_arguments())]
|
||||||
params = [declspec(p, names[i]) for i, p in enumerate(method.get_arguments())]
|
params = [declspec(p, names[i]) for i, p in enumerate(method.get_arguments())]
|
||||||
|
|
||||||
|
need_convert = {n: p for n, p in zip(names, method.get_arguments())
|
||||||
|
if param_needs_conversion(p)}
|
||||||
|
manual_convert = {n: p for n, p in zip(names, method.get_arguments())
|
||||||
|
if underlying_type(p).spelling in MANUAL_TYPES
|
||||||
|
or p.spelling in MANUAL_PARAMS}
|
||||||
|
|
||||||
names = ['linux_side'] + names
|
names = ['linux_side'] + names
|
||||||
params = ['void *linux_side'] + params
|
params = ['void *linux_side'] + params
|
||||||
|
|
||||||
cpp.write(f'{ret}{cppname}_{method_name}({", ".join(params)})\n')
|
cpp.write(f'{ret}{cppname}_{method_name}({", ".join(params)})\n')
|
||||||
cpp.write("{\n")
|
cpp.write("{\n")
|
||||||
|
|
||||||
need_convert = [p for p in method.get_arguments()
|
for name, param in sorted(need_convert.items()):
|
||||||
if param_needs_conversion(p)]
|
|
||||||
manual_convert = [p for p in method.get_arguments()
|
|
||||||
if underlying_type(p).spelling in MANUAL_TYPES
|
|
||||||
or p.spelling in MANUAL_PARAMS]
|
|
||||||
|
|
||||||
for param in need_convert:
|
|
||||||
if param.type.kind == TypeKind.POINTER:
|
if param.type.kind == TypeKind.POINTER:
|
||||||
#handle single pointers, but not double pointers
|
#handle single pointers, but not double pointers
|
||||||
real_type = param.type
|
real_type = param.type
|
||||||
@ -786,17 +786,18 @@ def handle_method_cpp(method_name, classname, cppname, method, cpp):
|
|||||||
real_name = canonical_typename(real_type)
|
real_name = canonical_typename(real_type)
|
||||||
assert(param.type.get_pointee().kind == TypeKind.RECORD or real_name in MANUAL_STRUCTS)
|
assert(param.type.get_pointee().kind == TypeKind.RECORD or real_name in MANUAL_STRUCTS)
|
||||||
pointee_name = canonical_typename(param.type.get_pointee())
|
pointee_name = canonical_typename(param.type.get_pointee())
|
||||||
cpp.write(f" {pointee_name} lin_{param.spelling};\n")
|
cpp.write(f" {pointee_name} lin_{name};\n")
|
||||||
cpp.write(f" win_to_lin_struct_{real_name}_{sdkver}({param.spelling}, &lin_{param.spelling});\n")
|
cpp.write(f" win_to_lin_struct_{real_name}_{sdkver}({name}, &lin_{name});\n")
|
||||||
else:
|
else:
|
||||||
#raw structs
|
#raw structs
|
||||||
cpp.write(f" {param.type.spelling} lin_{param.spelling};\n")
|
cpp.write(f" {param.type.spelling} lin_{name};\n")
|
||||||
cpp.write(f" win_to_lin_struct_{param.type.spelling}_{sdkver}(&{param.spelling}, &lin_{param.spelling});\n")
|
cpp.write(f" win_to_lin_struct_{param.type.spelling}_{sdkver}(&{name}, &lin_{name});\n")
|
||||||
for param in manual_convert:
|
|
||||||
if param.spelling in MANUAL_PARAMS:
|
for name, param in sorted(manual_convert.items()):
|
||||||
cpp.write(f" {param.spelling} = manual_convert_{param.spelling}({param.spelling});\n")
|
if name in MANUAL_PARAMS:
|
||||||
|
cpp.write(f" {name} = manual_convert_{name}({name});\n")
|
||||||
else:
|
else:
|
||||||
cpp.write(f" {param.spelling} = ({param.type.spelling})manual_convert_{param.type.spelling}((void*){param.spelling});\n")
|
cpp.write(f" {name} = ({param.type.spelling})manual_convert_{param.type.spelling}((void*){name});\n")
|
||||||
|
|
||||||
if method.result_type.kind == TypeKind.VOID:
|
if method.result_type.kind == TypeKind.VOID:
|
||||||
cpp.write(" ")
|
cpp.write(" ")
|
||||||
@ -809,41 +810,27 @@ def handle_method_cpp(method_name, classname, cppname, method, cpp):
|
|||||||
if post_exec != None:
|
if post_exec != None:
|
||||||
cpp.write(post_exec + '(');
|
cpp.write(post_exec + '(');
|
||||||
|
|
||||||
cpp.write(f"(({classname}*)linux_side)->{method.spelling}(")
|
def param_call(name, param):
|
||||||
first = True
|
pfx = '&' if param.type.kind == TypeKind.POINTER else ''
|
||||||
for i, param in enumerate(method.get_arguments()):
|
if name in need_convert: return f"{pfx}lin_{name}"
|
||||||
if param.kind == CursorKind.PARM_DECL:
|
if param.type.kind == TypeKind.LVALUEREFERENCE: return f'*{name}'
|
||||||
if not first:
|
return f"({param.type.spelling}){name}"
|
||||||
cpp.write(", ")
|
|
||||||
else:
|
|
||||||
first = False
|
|
||||||
if param.spelling == "":
|
|
||||||
cpp.write(f"({param.type.spelling})_{chr(0x61 + i)}")
|
|
||||||
elif param.type.kind == TypeKind.POINTER and \
|
|
||||||
param.type.get_pointee().spelling in WRAPPED_CLASSES:
|
|
||||||
cpp.write(f"({param.type.spelling}){param.spelling}")
|
|
||||||
elif param in need_convert:
|
|
||||||
if param.type.kind != TypeKind.POINTER:
|
|
||||||
cpp.write(f"lin_{param.spelling}")
|
|
||||||
else:
|
|
||||||
cpp.write(f"&lin_{param.spelling}")
|
|
||||||
elif param.type.kind == TypeKind.LVALUEREFERENCE:
|
|
||||||
cpp.write(f"*{param.spelling}")
|
|
||||||
else:
|
|
||||||
cpp.write(f"({param.type.spelling}){param.spelling}")
|
|
||||||
|
|
||||||
|
params = [param_call(n, p) for n, p in zip(names[1:], method.get_arguments())]
|
||||||
|
cpp.write(f'(({classname}*)linux_side)->{method.spelling}({", ".join(params)}')
|
||||||
if post_exec != None:
|
if post_exec != None:
|
||||||
cpp.write(")")
|
cpp.write(")")
|
||||||
cpp.write(");\n")
|
cpp.write(");\n")
|
||||||
for param in need_convert:
|
|
||||||
|
for name, param in sorted(need_convert.items()):
|
||||||
if param.type.kind == TypeKind.POINTER:
|
if param.type.kind == TypeKind.POINTER:
|
||||||
if not "const " in param.type.spelling: #don't modify const arguments
|
if not "const " in param.type.spelling: #don't modify const arguments
|
||||||
real_type = param.type
|
real_type = param.type
|
||||||
while real_type.kind == TypeKind.POINTER:
|
while real_type.kind == TypeKind.POINTER:
|
||||||
real_type = real_type.get_pointee()
|
real_type = real_type.get_pointee()
|
||||||
cpp.write(f" lin_to_win_struct_{real_type.spelling}_{sdkver}(&lin_{param.spelling}, {param.spelling});\n")
|
cpp.write(f" lin_to_win_struct_{real_type.spelling}_{sdkver}(&lin_{name}, {name});\n")
|
||||||
else:
|
else:
|
||||||
cpp.write(f" lin_to_win_struct_{param.type.spelling}_{sdkver}(&lin_{param.spelling}, &{param.spelling});\n")
|
cpp.write(f" lin_to_win_struct_{param.type.spelling}_{sdkver}(&lin_{name}, &{name});\n")
|
||||||
if method.result_type.kind != TypeKind.VOID and \
|
if method.result_type.kind != TypeKind.VOID and \
|
||||||
len(need_convert) > 0:
|
len(need_convert) > 0:
|
||||||
cpp.write(" return retval;\n")
|
cpp.write(" return retval;\n")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user