import org.ldk.util.*;
import java.util.Arrays;
+
+/**
+ * The information we received from a peer along the route of a payment we originated. This is
+ * returned by ChannelMessageHandler::handle_update_fail_htlc to be passed into
+ * RoutingMessageHandler::handle_htlc_fail_channel_update to update our network map.
+ */
@SuppressWarnings("unchecked") // We correctly assign various generic arrays
public class HTLCFailChannelUpdate extends CommonBase {
private HTLCFailChannelUpdate(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.HTLCFailChannelUpdate_free(ptr); }
+ }
static HTLCFailChannelUpdate constr_from_ptr(long ptr) {
bindings.LDKHTLCFailChannelUpdate raw_val = bindings.LDKHTLCFailChannelUpdate_ref_from_ptr(ptr);
if (raw_val.getClass() == bindings.LDKHTLCFailChannelUpdate.ChannelUpdateMessage.class) {
- return new ChannelUpdateMessage(null, ptr);
+ return new ChannelUpdateMessage(ptr, (bindings.LDKHTLCFailChannelUpdate.ChannelUpdateMessage)raw_val);
}
if (raw_val.getClass() == bindings.LDKHTLCFailChannelUpdate.ChannelClosed.class) {
- return new ChannelClosed(null, ptr);
+ return new ChannelClosed(ptr, (bindings.LDKHTLCFailChannelUpdate.ChannelClosed)raw_val);
}
if (raw_val.getClass() == bindings.LDKHTLCFailChannelUpdate.NodeFailure.class) {
- return new NodeFailure(null, ptr);
+ return new NodeFailure(ptr, (bindings.LDKHTLCFailChannelUpdate.NodeFailure)raw_val);
}
assert false; return null; // Unreachable without extending the (internal) bindings interface
}
public final static class ChannelUpdateMessage extends HTLCFailChannelUpdate {
- public ChannelUpdate msg;
- private ChannelUpdateMessage(Object _dummy, long ptr) { super(null, ptr); }
- @Override long conv_to_c() { return 0; /*XXX*/ }
+ public final ChannelUpdate msg;
+ private ChannelUpdateMessage(long ptr, bindings.LDKHTLCFailChannelUpdate.ChannelUpdateMessage obj) {
+ super(null, ptr);
+ long msg = obj.msg;
+ ChannelUpdate msg_hu_conv = new ChannelUpdate(null, msg);
+ msg_hu_conv.ptrs_to.add(this);
+ this.msg = msg_hu_conv;
+ }
}
public final static class ChannelClosed extends HTLCFailChannelUpdate {
- public long short_channel_id;
- public boolean is_permanent;
- private ChannelClosed(Object _dummy, long ptr) { super(null, ptr); }
- @Override long conv_to_c() { return 0; /*XXX*/ }
+ public final long short_channel_id;
+ public final boolean is_permanent;
+ private ChannelClosed(long ptr, bindings.LDKHTLCFailChannelUpdate.ChannelClosed obj) {
+ super(null, ptr);
+ this.short_channel_id = obj.short_channel_id;
+ this.is_permanent = obj.is_permanent;
+ }
}
public final static class NodeFailure extends HTLCFailChannelUpdate {
- public byte[] node_id;
- public boolean is_permanent;
- private NodeFailure(Object _dummy, long ptr) { super(null, ptr); }
- @Override long conv_to_c() { return 0; /*XXX*/ }
+ public final byte[] node_id;
+ public final boolean is_permanent;
+ private NodeFailure(long ptr, bindings.LDKHTLCFailChannelUpdate.NodeFailure obj) {
+ super(null, ptr);
+ this.node_id = obj.node_id;
+ this.is_permanent = obj.is_permanent;
+ }
+ }
+ /**
+ * Creates a copy of the HTLCFailChannelUpdate
+ */
+ public HTLCFailChannelUpdate clone() {
+ long ret = bindings.HTLCFailChannelUpdate_clone(this.ptr);
+ HTLCFailChannelUpdate ret_hu_conv = HTLCFailChannelUpdate.constr_from_ptr(ret);
+ ret_hu_conv.ptrs_to.add(this);
+ return ret_hu_conv;
}
+
}