1 package org.ldk.structs;
3 import org.ldk.impl.bindings;
4 import org.ldk.enums.*;
6 import java.util.Arrays;
7 import java.lang.ref.Reference;
8 import javax.annotation.Nullable;
12 * A tx_remove_output message for removing an output during interactive transaction construction.
14 @SuppressWarnings("unchecked") // We correctly assign various generic arrays
15 public class TxRemoveOutput extends CommonBase {
16 TxRemoveOutput(Object _dummy, long ptr) { super(ptr); }
17 @Override @SuppressWarnings("deprecation")
18 protected void finalize() throws Throwable {
20 if (ptr != 0) { bindings.TxRemoveOutput_free(ptr); }
26 public byte[] get_channel_id() {
27 byte[] ret = bindings.TxRemoveOutput_get_channel_id(this.ptr);
28 Reference.reachabilityFence(this);
35 public void set_channel_id(byte[] val) {
36 bindings.TxRemoveOutput_set_channel_id(this.ptr, InternalUtils.check_arr_len(val, 32));
37 Reference.reachabilityFence(this);
38 Reference.reachabilityFence(val);
42 * The serial ID of the output to be removed
44 public long get_serial_id() {
45 long ret = bindings.TxRemoveOutput_get_serial_id(this.ptr);
46 Reference.reachabilityFence(this);
51 * The serial ID of the output to be removed
53 public void set_serial_id(long val) {
54 bindings.TxRemoveOutput_set_serial_id(this.ptr, val);
55 Reference.reachabilityFence(this);
56 Reference.reachabilityFence(val);
60 * Constructs a new TxRemoveOutput given each field
62 public static TxRemoveOutput of(byte[] channel_id_arg, long serial_id_arg) {
63 long ret = bindings.TxRemoveOutput_new(InternalUtils.check_arr_len(channel_id_arg, 32), serial_id_arg);
64 Reference.reachabilityFence(channel_id_arg);
65 Reference.reachabilityFence(serial_id_arg);
66 if (ret >= 0 && ret <= 4096) { return null; }
67 org.ldk.structs.TxRemoveOutput ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.TxRemoveOutput(null, ret); }
68 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.add(ret_hu_conv); };
73 long ret = bindings.TxRemoveOutput_clone_ptr(this.ptr);
74 Reference.reachabilityFence(this);
79 * Creates a copy of the TxRemoveOutput
81 public TxRemoveOutput clone() {
82 long ret = bindings.TxRemoveOutput_clone(this.ptr);
83 Reference.reachabilityFence(this);
84 if (ret >= 0 && ret <= 4096) { return null; }
85 org.ldk.structs.TxRemoveOutput ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.TxRemoveOutput(null, ret); }
86 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.add(this); };
91 * Generates a non-cryptographic 64-bit hash of the TxRemoveOutput.
94 long ret = bindings.TxRemoveOutput_hash(this.ptr);
95 Reference.reachabilityFence(this);
99 @Override public int hashCode() {
100 return (int)this.hash();
103 * Checks if two TxRemoveOutputs contain equal inner contents.
104 * This ignores pointers and is_owned flags and looks at the values in fields.
105 * Two objects with NULL inner values will be considered "equal" here.
107 public boolean eq(org.ldk.structs.TxRemoveOutput b) {
108 boolean ret = bindings.TxRemoveOutput_eq(this.ptr, b == null ? 0 : b.ptr);
109 Reference.reachabilityFence(this);
110 Reference.reachabilityFence(b);
111 if (this != null) { this.ptrs_to.add(b); };
115 @Override public boolean equals(Object o) {
116 if (!(o instanceof TxRemoveOutput)) return false;
117 return this.eq((TxRemoveOutput)o);
120 * Serialize the TxRemoveOutput object into a byte array which can be read by TxRemoveOutput_read
122 public byte[] write() {
123 byte[] ret = bindings.TxRemoveOutput_write(this.ptr);
124 Reference.reachabilityFence(this);
129 * Read a TxRemoveOutput from a byte array, created by TxRemoveOutput_write
131 public static Result_TxRemoveOutputDecodeErrorZ read(byte[] ser) {
132 long ret = bindings.TxRemoveOutput_read(ser);
133 Reference.reachabilityFence(ser);
134 if (ret >= 0 && ret <= 4096) { return null; }
135 Result_TxRemoveOutputDecodeErrorZ ret_hu_conv = Result_TxRemoveOutputDecodeErrorZ.constr_from_ptr(ret);