X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Forg%2Fldk%2Fstructs%2FBroadcasterInterface.java;h=5052076dfab22a56bea96e9b528e99afa70781d6;hb=1854b5cebef22ace9e9e4dd191f609818df9ce08;hp=b2541a836105bb8dfcc617f3df4ebf5db249035a;hpb=a26d77400b9be7cb401019e8562edb515b70ed41;p=ldk-java diff --git a/src/main/java/org/ldk/structs/BroadcasterInterface.java b/src/main/java/org/ldk/structs/BroadcasterInterface.java index b2541a83..5052076d 100644 --- a/src/main/java/org/ldk/structs/BroadcasterInterface.java +++ b/src/main/java/org/ldk/structs/BroadcasterInterface.java @@ -4,7 +4,12 @@ import org.ldk.impl.bindings; import org.ldk.enums.*; import org.ldk.util.*; import java.util.Arrays; +import java.lang.ref.Reference; +import javax.annotation.Nullable; +/** + * An interface to send a transaction to the Bitcoin network. + */ @SuppressWarnings("unchecked") // We correctly assign various generic arrays public class BroadcasterInterface extends CommonBase { final bindings.LDKBroadcasterInterface bindings_instance; @@ -20,18 +25,28 @@ public class BroadcasterInterface extends CommonBase { } public static interface BroadcasterInterfaceInterface { - void broadcast_transaction(Transaction tx); + /** + * Sends a transaction out to (hopefully) be mined. + */ + void broadcast_transaction(byte[] tx); } - public BroadcasterInterface(BroadcasterInterfaceInterface arg) { - this(new bindings.LDKBroadcasterInterface() { - @Override public void broadcast_transaction(long tx) { - Transaction tx_conv = new Transaction(null, tx); - arg.broadcast_transaction(tx_conv); + private static class LDKBroadcasterInterfaceHolder { BroadcasterInterface held; } + public static BroadcasterInterface new_impl(BroadcasterInterfaceInterface arg) { + final LDKBroadcasterInterfaceHolder impl_holder = new LDKBroadcasterInterfaceHolder(); + impl_holder.held = new BroadcasterInterface(new bindings.LDKBroadcasterInterface() { + @Override public void broadcast_transaction(byte[] tx) { + arg.broadcast_transaction(tx); } }); + return impl_holder.held; } - public void broadcast_transaction(Transaction tx) { - bindings.BroadcasterInterface_broadcast_transaction(this.ptr, tx.ptr); + /** + * Sends a transaction out to (hopefully) be mined. + */ + public void broadcast_transaction(byte[] tx) { + bindings.BroadcasterInterface_broadcast_transaction(this.ptr, tx); + Reference.reachabilityFence(this); + Reference.reachabilityFence(tx); } }