X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Forg%2Fldk%2Fstructs%2FMonitorEvent.java;h=68421e71b46e7c1b82bdb7ac26004156aa5f008d;hb=c3ae2d6897e5a809459c8d9a72a4b3aa0052c8c8;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..68421e71 100644 --- a/src/main/java/org/ldk/structs/MonitorEvent.java +++ b/src/main/java/org/ldk/structs/MonitorEvent.java @@ -2,12 +2,60 @@ package org.ldk.structs; import org.ldk.impl.bindings; import org.ldk.enums.*; +import org.ldk.util.*; +import java.util.Arrays; + +/** + * 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.CommitmentTxBroadcasted.class) { + return new CommitmentTxBroadcasted(ptr, (bindings.LDKMonitorEvent.CommitmentTxBroadcasted)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 CommitmentTxBroadcasted extends MonitorEvent { + public final OutPoint commitment_tx_broadcasted; + private CommitmentTxBroadcasted(long ptr, bindings.LDKMonitorEvent.CommitmentTxBroadcasted obj) { + super(null, ptr); + long commitment_tx_broadcasted = obj.commitment_tx_broadcasted; + OutPoint commitment_tx_broadcasted_hu_conv = new OutPoint(null, commitment_tx_broadcasted); + commitment_tx_broadcasted_hu_conv.ptrs_to.add(this); + this.commitment_tx_broadcasted = commitment_tx_broadcasted_hu_conv; + } + } + /** + * Creates a copy of the MonitorEvent + */ + public MonitorEvent clone() { + long ret = bindings.MonitorEvent_clone(this.ptr); + MonitorEvent ret_hu_conv = MonitorEvent.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(this); + return ret_hu_conv; } }