X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Forg%2Fldk%2Fstructs%2FEvent.java;h=edfa67cde20e10d46a0f0cab3e8654c510819077;hb=c3ae2d6897e5a809459c8d9a72a4b3aa0052c8c8;hp=d191cb0ad41ab851fc02997578fd6c12fbaee4e6;hpb=110f2f104ba8fc34caa7e34e04737f36f064b050;p=ldk-java diff --git a/src/main/java/org/ldk/structs/Event.java b/src/main/java/org/ldk/structs/Event.java index d191cb0a..edfa67cd 100644 --- a/src/main/java/org/ldk/structs/Event.java +++ b/src/main/java/org/ldk/structs/Event.java @@ -5,76 +5,138 @@ import org.ldk.enums.*; import org.ldk.util.*; import java.util.Arrays; + +/** + * An Event which you should probably take some action in response to. + * + * Note that while Writeable and Readable are implemented for Event, you probably shouldn't use + * them directly as they don't round-trip exactly (for example FundingGenerationReady is never + * written as it makes no sense to respond to it after reconnecting to peers). + */ @SuppressWarnings("unchecked") // We correctly assign various generic arrays public class Event extends CommonBase { private Event(Object _dummy, long ptr) { super(ptr); } - long conv_to_c() { assert false; return 0; /* Should only be called on subclasses */ } + @Override @SuppressWarnings("deprecation") + protected void finalize() throws Throwable { + super.finalize(); + if (ptr != 0) { bindings.Event_free(ptr); } + } static Event constr_from_ptr(long ptr) { bindings.LDKEvent raw_val = bindings.LDKEvent_ref_from_ptr(ptr); if (raw_val.getClass() == bindings.LDKEvent.FundingGenerationReady.class) { - return new FundingGenerationReady(null, ptr); + return new FundingGenerationReady(ptr, (bindings.LDKEvent.FundingGenerationReady)raw_val); } if (raw_val.getClass() == bindings.LDKEvent.FundingBroadcastSafe.class) { - return new FundingBroadcastSafe(null, ptr); + return new FundingBroadcastSafe(ptr, (bindings.LDKEvent.FundingBroadcastSafe)raw_val); } if (raw_val.getClass() == bindings.LDKEvent.PaymentReceived.class) { - return new PaymentReceived(null, ptr); + return new PaymentReceived(ptr, (bindings.LDKEvent.PaymentReceived)raw_val); } if (raw_val.getClass() == bindings.LDKEvent.PaymentSent.class) { - return new PaymentSent(null, ptr); + return new PaymentSent(ptr, (bindings.LDKEvent.PaymentSent)raw_val); } if (raw_val.getClass() == bindings.LDKEvent.PaymentFailed.class) { - return new PaymentFailed(null, ptr); + return new PaymentFailed(ptr, (bindings.LDKEvent.PaymentFailed)raw_val); } if (raw_val.getClass() == bindings.LDKEvent.PendingHTLCsForwardable.class) { - return new PendingHTLCsForwardable(null, ptr); + return new PendingHTLCsForwardable(ptr, (bindings.LDKEvent.PendingHTLCsForwardable)raw_val); } if (raw_val.getClass() == bindings.LDKEvent.SpendableOutputs.class) { - return new SpendableOutputs(null, ptr); + return new SpendableOutputs(ptr, (bindings.LDKEvent.SpendableOutputs)raw_val); } assert false; return null; // Unreachable without extending the (internal) bindings interface } public final static class FundingGenerationReady extends Event { - public byte[] temporary_channel_id; - public long channel_value_satoshis; - public byte[] output_script; - public long user_channel_id; - private FundingGenerationReady(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + public final byte[] temporary_channel_id; + public final long channel_value_satoshis; + public final byte[] output_script; + public final long user_channel_id; + private FundingGenerationReady(long ptr, bindings.LDKEvent.FundingGenerationReady obj) { + super(null, ptr); + this.temporary_channel_id = obj.temporary_channel_id; + this.channel_value_satoshis = obj.channel_value_satoshis; + this.output_script = obj.output_script; + this.user_channel_id = obj.user_channel_id; + } } public final static class FundingBroadcastSafe extends Event { - public OutPoint funding_txo; - public long user_channel_id; - private FundingBroadcastSafe(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + public final OutPoint funding_txo; + public final long user_channel_id; + private FundingBroadcastSafe(long ptr, bindings.LDKEvent.FundingBroadcastSafe obj) { + super(null, ptr); + long funding_txo = obj.funding_txo; + OutPoint funding_txo_hu_conv = new OutPoint(null, funding_txo); + funding_txo_hu_conv.ptrs_to.add(this); + this.funding_txo = funding_txo_hu_conv; + this.user_channel_id = obj.user_channel_id; + } } public final static class PaymentReceived extends Event { - public byte[] payment_hash; - public byte[] payment_secret; - public long amt; - private PaymentReceived(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + public final byte[] payment_hash; + public final byte[] payment_secret; + public final long amt; + private PaymentReceived(long ptr, bindings.LDKEvent.PaymentReceived obj) { + super(null, ptr); + this.payment_hash = obj.payment_hash; + this.payment_secret = obj.payment_secret; + this.amt = obj.amt; + } } public final static class PaymentSent extends Event { - public byte[] payment_preimage; - private PaymentSent(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + public final byte[] payment_preimage; + private PaymentSent(long ptr, bindings.LDKEvent.PaymentSent obj) { + super(null, ptr); + this.payment_preimage = obj.payment_preimage; + } } public final static class PaymentFailed extends Event { - public byte[] payment_hash; - public boolean rejected_by_dest; - private PaymentFailed(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + public final byte[] payment_hash; + public final boolean rejected_by_dest; + private PaymentFailed(long ptr, bindings.LDKEvent.PaymentFailed obj) { + super(null, ptr); + this.payment_hash = obj.payment_hash; + this.rejected_by_dest = obj.rejected_by_dest; + } } public final static class PendingHTLCsForwardable extends Event { - public long time_forwardable; - private PendingHTLCsForwardable(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + public final long time_forwardable; + private PendingHTLCsForwardable(long ptr, bindings.LDKEvent.PendingHTLCsForwardable obj) { + super(null, ptr); + this.time_forwardable = obj.time_forwardable; + } } public final static class SpendableOutputs extends Event { - public SpendableOutputDescriptor[] outputs; - private SpendableOutputs(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + public final SpendableOutputDescriptor[] outputs; + private SpendableOutputs(long ptr, bindings.LDKEvent.SpendableOutputs obj) { + super(null, ptr); + long[] outputs = obj.outputs; + SpendableOutputDescriptor[] outputs_conv_27_arr = new SpendableOutputDescriptor[outputs.length]; + for (int b = 0; b < outputs.length; b++) { + long outputs_conv_27 = outputs[b]; + SpendableOutputDescriptor outputs_conv_27_hu_conv = SpendableOutputDescriptor.constr_from_ptr(outputs_conv_27); + outputs_conv_27_hu_conv.ptrs_to.add(this); + outputs_conv_27_arr[b] = outputs_conv_27_hu_conv; + } + this.outputs = outputs_conv_27_arr; + } + } + /** + * Creates a copy of the Event + */ + public Event clone() { + long ret = bindings.Event_clone(this.ptr); + Event ret_hu_conv = Event.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(this); + return ret_hu_conv; } + + /** + * Serialize the Event object into a byte array which can be read by Event_read + */ + public byte[] write() { + byte[] ret = bindings.Event_write(this.ptr); + return ret; + } + }