Update bindings to latest upstream.
[ldk-java] / src / main / java / org / ldk / structs / KeysManager.java
index ca95138ed299d828e33b5aaa4b496503c602499a..c0c4cfe6b3525854f39d1fe564df577020983244 100644 (file)
@@ -2,27 +2,45 @@ package org.ldk.structs;
 
 import org.ldk.impl.bindings;
 import org.ldk.enums.*;
+import org.ldk.util.*;
+import java.util.Arrays;
 
+@SuppressWarnings("unchecked") // We correctly assign various generic arrays
 public class KeysManager extends CommonBase {
        KeysManager(Object _dummy, long ptr) { super(ptr); }
        @Override @SuppressWarnings("deprecation")
        protected void finalize() throws Throwable {
-               bindings.KeysManager_free(ptr); super.finalize();
+               super.finalize();
+               if (ptr != 0) { bindings.KeysManager_free(ptr); }
        }
 
-       public KeysManager(byte[] seed, LDKNetwork network, long starting_time_secs, int starting_time_nanos) {
-               super(bindings.KeysManager_new(seed, network, starting_time_secs, starting_time_nanos));
+       public static KeysManager constructor_new(byte[] seed, long starting_time_secs, int starting_time_nanos) {
+               long ret = bindings.KeysManager_new(seed, starting_time_secs, starting_time_nanos);
+               KeysManager ret_hu_conv = new KeysManager(null, ret);
+               ret_hu_conv.ptrs_to.add(ret_hu_conv);
+               return ret_hu_conv;
        }
 
-       public InMemoryChannelKeys derive_channel_keys(long channel_value_satoshis, long params_1, long params_2) {
-               InMemoryChannelKeys ret = new InMemoryChannelKeys(null, bindings.KeysManager_derive_channel_keys(this.ptr, channel_value_satoshis, params_1, params_2));
-               return ret;
+       public InMemorySigner derive_channel_keys(long channel_value_satoshis, byte[] params) {
+               long ret = bindings.KeysManager_derive_channel_keys(this.ptr, channel_value_satoshis, params);
+               InMemorySigner ret_hu_conv = new InMemorySigner(null, ret);
+               ret_hu_conv.ptrs_to.add(this);
+               return ret_hu_conv;
+       }
+
+       public Result_TransactionNoneZ spend_spendable_outputs(SpendableOutputDescriptor[] descriptors, TxOut[] outputs, byte[] change_destination_script, int feerate_sat_per_1000_weight) {
+               long ret = bindings.KeysManager_spend_spendable_outputs(this.ptr, Arrays.stream(descriptors).mapToLong(descriptors_conv_27 -> descriptors_conv_27.ptr).toArray(), Arrays.stream(outputs).mapToLong(outputs_conv_7 -> outputs_conv_7.ptr).toArray(), change_destination_script, feerate_sat_per_1000_weight);
+               Result_TransactionNoneZ ret_hu_conv = Result_TransactionNoneZ.constr_from_ptr(ret);
+               /* TODO 2 SpendableOutputDescriptor  */;
+               /* TODO 2 TxOut  */;
+               return ret_hu_conv;
        }
 
        public KeysInterface as_KeysInterface() {
-               KeysInterface ret = new KeysInterface(null, bindings.KeysManager_as_KeysInterface(this.ptr));
-               ret.ptrs_to.add(this);
-               return ret;
+               long ret = bindings.KeysManager_as_KeysInterface(this.ptr);
+               KeysInterface ret_hu_conv = new KeysInterface(null, ret);
+               ret_hu_conv.ptrs_to.add(this);
+               return ret_hu_conv;
        }
 
 }