X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=genbindings.py;h=e5a59700352c6f0c1cdff2de3546783770396ee8;hb=32f9a53661edef495b11b2be5dce7115bb2b34d8;hp=77f9b472f7864383c2780524fb722f16982415cf;hpb=1d4aa806117a28f8a5899ed0dc4e9ad7ed117787;p=ldk-java diff --git a/genbindings.py b/genbindings.py index 77f9b472..e5a59700 100755 --- a/genbindings.py +++ b/genbindings.py @@ -30,8 +30,12 @@ elif sys.argv[6] == "c_sharp": import csharp_strings from csharp_strings import Consts target = csharp_strings.Target.CSHARP +elif sys.argv[6] == "python": + import python_strings + from python_strings import Consts + target = python_strings.Target.PYTHON else: - print("Only java, typescript, or c_sharp can be set for lang") + print("Only java, typescript, python, or c_sharp can be set for lang") sys.exit(1) @@ -128,13 +132,15 @@ def java_c_types(fn_arg, ret_arr_len): rust_obj = None arr_access = None java_hu_ty = None - if fn_arg.startswith("LDKPaymentPreimage") or fn_arg.startswith("LDKPaymentSecret") or fn_arg.startswith("LDKPaymentHash"): + if fn_arg.startswith("LDKPaymentPreimage") or fn_arg.startswith("LDKPaymentSecret") or fn_arg.startswith("LDKPaymentHash") or fn_arg.startswith("LDKChainHash"): if fn_arg.startswith("LDKPaymentPreimage"): fn_arg = "uint8_t (*" + fn_arg[19:] + ")[32]" elif fn_arg.startswith("LDKPaymentSecret"): fn_arg = "uint8_t (*" + fn_arg[17:] + ")[32]" elif fn_arg.startswith("LDKPaymentHash"): fn_arg = "uint8_t (*" + fn_arg[15:] + ")[32]" + elif fn_arg.startswith("LDKChainHash"): + fn_arg = "uint8_t (*" + fn_arg[13:] + ")[32]" assert var_is_arr_regex.match(fn_arg[8:]) rust_obj = "LDKThirtyTwoBytes" arr_access = "data" @@ -339,14 +345,17 @@ def java_c_types(fn_arg, ret_arr_len): arr_ty = "LDKStr" fn_ty_arg = "Ljava/lang/String;" fn_arg = fn_arg[6:].strip() - elif fn_arg.startswith("LDKStr"): + elif fn_arg.startswith("LDKStr") or fn_arg.startswith("LDKAddress"): rust_obj = "LDKStr" arr_ty = "LDKStr" java_ty = consts.java_type_map["String"] java_hu_ty = consts.java_hu_type_map["String"] c_ty = "jstring" fn_ty_arg = "Ljava/lang/String;" - fn_arg = fn_arg[6:].strip() + if fn_arg.startswith("LDKAddress"): + fn_arg = fn_arg[10:].strip() + else: + fn_arg = fn_arg[6:].strip() arr_access = "chars" arr_len = "len" elif fn_arg.startswith("LDKError ") or fn_arg == "LDKError": @@ -765,13 +774,20 @@ with open(sys.argv[1]) as in_h, open(f"{sys.argv[2]}/bindings{consts.file_ext}", for var_line in field_var_lines: if var_line.group(1) in trait_structs: field_var_convs.append((var_line.group(1), var_line.group(2), trait_structs[var_line.group(1)])) - flattened_field_var_convs.append((var_line.group(1), var_line.group(2), )) - flattened_field_var_convs.extend(trait_structs[var_line.group(1)]) + flattened_field_var_convs.append((var_line.group(1), var_line.group(2), var_line.group(2))) + for field_var in trait_structs[var_line.group(1)]: + if isinstance(field_var, ConvInfo): + flattened_field_var_convs.append(field_var) + else: + path = var_line.group(2) + if len(field_var) > 2: + path = var_line.group(2) + "." + field_var[2] + flattened_field_var_convs.append((field_var[0], field_var[1], path)) else: mapped = type_mapping_generator.map_type(var_line.group(1) + " " + var_line.group(2), False, None, False, False) field_var_convs.append(mapped) flattened_field_var_convs.append(mapped) - trait_structs[struct_name] = field_var_convs + trait_structs[struct_name] = flattened_field_var_convs field_fns = [] for fn_docs, fn_line in trait_fn_lines: