X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;ds=sidebyside;f=src%2Fmain%2Fjava%2Forg%2Fldk%2Fstructs%2FMonitorEvent.java;h=2b2acb8381d37cdde18794584f3fbb87f0a0fcd1;hb=0e5e33e2bb46c905f6c9478fbfcda11be6b309ff;hp=d425905448865c8f03802bd5ae7e4ebb5d7c2fbf;hpb=3d559f3266fde7c6a21248c10d9a7145125b5e69;p=ldk-java diff --git a/src/main/java/org/ldk/structs/MonitorEvent.java b/src/main/java/org/ldk/structs/MonitorEvent.java index d4259054..2b2acb83 100644 --- a/src/main/java/org/ldk/structs/MonitorEvent.java +++ b/src/main/java/org/ldk/structs/MonitorEvent.java @@ -2,12 +2,84 @@ package org.ldk.structs; import org.ldk.impl.bindings; import org.ldk.enums.*; +import org.ldk.util.*; +import java.util.Arrays; +import javax.annotation.Nullable; + +/** + * An event to be processed by the ChannelManager. + */ +@SuppressWarnings("unchecked") // We correctly assign various generic arrays public class MonitorEvent extends CommonBase { - MonitorEvent(Object _dummy, long ptr) { super(ptr); } + private MonitorEvent(Object _dummy, long ptr) { super(ptr); } @Override @SuppressWarnings("deprecation") protected void finalize() throws Throwable { - bindings.MonitorEvent_free(ptr); super.finalize(); + super.finalize(); + if (ptr != 0) { bindings.MonitorEvent_free(ptr); } + } + static MonitorEvent constr_from_ptr(long ptr) { + bindings.LDKMonitorEvent raw_val = bindings.LDKMonitorEvent_ref_from_ptr(ptr); + if (raw_val.getClass() == bindings.LDKMonitorEvent.HTLCEvent.class) { + return new HTLCEvent(ptr, (bindings.LDKMonitorEvent.HTLCEvent)raw_val); + } + if (raw_val.getClass() == bindings.LDKMonitorEvent.CommitmentTxConfirmed.class) { + return new CommitmentTxConfirmed(ptr, (bindings.LDKMonitorEvent.CommitmentTxConfirmed)raw_val); + } + assert false; return null; // Unreachable without extending the (internal) bindings interface + } + + public final static class HTLCEvent extends MonitorEvent { + public final HTLCUpdate htlc_event; + private HTLCEvent(long ptr, bindings.LDKMonitorEvent.HTLCEvent obj) { + super(null, ptr); + long htlc_event = obj.htlc_event; + HTLCUpdate htlc_event_hu_conv = new HTLCUpdate(null, htlc_event); + htlc_event_hu_conv.ptrs_to.add(this); + this.htlc_event = htlc_event_hu_conv; + } + } + public final static class CommitmentTxConfirmed extends MonitorEvent { + public final OutPoint commitment_tx_confirmed; + private CommitmentTxConfirmed(long ptr, bindings.LDKMonitorEvent.CommitmentTxConfirmed obj) { + super(null, ptr); + long commitment_tx_confirmed = obj.commitment_tx_confirmed; + OutPoint commitment_tx_confirmed_hu_conv = new OutPoint(null, commitment_tx_confirmed); + commitment_tx_confirmed_hu_conv.ptrs_to.add(this); + this.commitment_tx_confirmed = commitment_tx_confirmed_hu_conv; + } + } + /** + * Creates a copy of the MonitorEvent + */ + public MonitorEvent clone() { + long ret = bindings.MonitorEvent_clone(this.ptr); + if (ret >= 0 && ret < 1024) { return null; } + MonitorEvent ret_hu_conv = MonitorEvent.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(this); + return ret_hu_conv; + } + + /** + * Utility method to constructs a new HTLCEvent-variant MonitorEvent + */ + public static MonitorEvent htlcevent(HTLCUpdate a) { + long ret = bindings.MonitorEvent_htlcevent(a == null ? 0 : a.ptr & ~1); + if (ret >= 0 && ret < 1024) { return null; } + MonitorEvent ret_hu_conv = MonitorEvent.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(ret_hu_conv); + return ret_hu_conv; + } + + /** + * Utility method to constructs a new CommitmentTxConfirmed-variant MonitorEvent + */ + public static MonitorEvent commitment_tx_confirmed(OutPoint a) { + long ret = bindings.MonitorEvent_commitment_tx_confirmed(a == null ? 0 : a.ptr & ~1); + if (ret >= 0 && ret < 1024) { return null; } + MonitorEvent ret_hu_conv = MonitorEvent.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(ret_hu_conv); + return ret_hu_conv; } }