import org.ldk.impl.bindings;
import org.ldk.enums.*;
+import org.ldk.util.*;
+import java.util.Arrays;
+
+/**
+ * A revoke_and_ack message to be sent or received from a peer
+ */
+@SuppressWarnings("unchecked") // We correctly assign various generic arrays
public class RevokeAndACK extends CommonBase {
RevokeAndACK(Object _dummy, long ptr) { super(ptr); }
@Override @SuppressWarnings("deprecation")
protected void finalize() throws Throwable {
- bindings.RevokeAndACK_free(ptr); super.finalize();
+ super.finalize();
+ if (ptr != 0) { bindings.RevokeAndACK_free(ptr); }
+ }
+
+ /**
+ * The channel ID
+ */
+ public byte[] get_channel_id() {
+ byte[] ret = bindings.RevokeAndACK_get_channel_id(this.ptr);
+ return ret;
}
- public RevokeAndACK(RevokeAndACK orig) {
- super(bindings.RevokeAndACK_clone(orig == null ? 0 : orig.ptr & ~1));
- this.ptrs_to.add(orig);
+ /**
+ * The channel ID
+ */
+ public void set_channel_id(byte[] val) {
+ bindings.RevokeAndACK_set_channel_id(this.ptr, val);
}
- public byte[] get_channel_id(RevokeAndACK this_ptr) {
- byte[] ret = bindings.RevokeAndACK_get_channel_id(this_ptr == null ? 0 : this_ptr.ptr & ~1);
- this.ptrs_to.add(this_ptr);
+ /**
+ * The secret corresponding to the per-commitment point
+ */
+ public byte[] get_per_commitment_secret() {
+ byte[] ret = bindings.RevokeAndACK_get_per_commitment_secret(this.ptr);
return ret;
}
- public void set_channel_id(RevokeAndACK this_ptr, byte[] val) {
- bindings.RevokeAndACK_set_channel_id(this_ptr == null ? 0 : this_ptr.ptr & ~1, val);
- this.ptrs_to.add(this_ptr);
+ /**
+ * The secret corresponding to the per-commitment point
+ */
+ public void set_per_commitment_secret(byte[] val) {
+ bindings.RevokeAndACK_set_per_commitment_secret(this.ptr, val);
}
- public byte[] get_per_commitment_secret(RevokeAndACK this_ptr) {
- byte[] ret = bindings.RevokeAndACK_get_per_commitment_secret(this_ptr == null ? 0 : this_ptr.ptr & ~1);
- this.ptrs_to.add(this_ptr);
+ /**
+ * The next sender-broadcast commitment transaction's per-commitment point
+ */
+ public byte[] get_next_per_commitment_point() {
+ byte[] ret = bindings.RevokeAndACK_get_next_per_commitment_point(this.ptr);
return ret;
}
- public void set_per_commitment_secret(RevokeAndACK this_ptr, byte[] val) {
- bindings.RevokeAndACK_set_per_commitment_secret(this_ptr == null ? 0 : this_ptr.ptr & ~1, val);
- this.ptrs_to.add(this_ptr);
+ /**
+ * The next sender-broadcast commitment transaction's per-commitment point
+ */
+ public void set_next_per_commitment_point(byte[] val) {
+ bindings.RevokeAndACK_set_next_per_commitment_point(this.ptr, val);
}
- public byte[] get_next_per_commitment_point(RevokeAndACK this_ptr) {
- byte[] ret = bindings.RevokeAndACK_get_next_per_commitment_point(this_ptr == null ? 0 : this_ptr.ptr & ~1);
- this.ptrs_to.add(this_ptr);
- return ret;
+ /**
+ * Constructs a new RevokeAndACK given each field
+ */
+ public static RevokeAndACK of(byte[] channel_id_arg, byte[] per_commitment_secret_arg, byte[] next_per_commitment_point_arg) {
+ long ret = bindings.RevokeAndACK_new(channel_id_arg, per_commitment_secret_arg, next_per_commitment_point_arg);
+ RevokeAndACK ret_hu_conv = new RevokeAndACK(null, ret);
+ ret_hu_conv.ptrs_to.add(ret_hu_conv);
+ return ret_hu_conv;
}
- public void set_next_per_commitment_point(RevokeAndACK this_ptr, byte[] val) {
- bindings.RevokeAndACK_set_next_per_commitment_point(this_ptr == null ? 0 : this_ptr.ptr & ~1, val);
- this.ptrs_to.add(this_ptr);
+ /**
+ * Creates a copy of the RevokeAndACK
+ */
+ public RevokeAndACK clone() {
+ long ret = bindings.RevokeAndACK_clone(this.ptr);
+ RevokeAndACK ret_hu_conv = new RevokeAndACK(null, ret);
+ ret_hu_conv.ptrs_to.add(this);
+ return ret_hu_conv;
}
- public RevokeAndACK(byte[] channel_id_arg, byte[] per_commitment_secret_arg, byte[] next_per_commitment_point_arg) {
- super(bindings.RevokeAndACK_new(channel_id_arg, per_commitment_secret_arg, next_per_commitment_point_arg));
+ /**
+ * Serialize the RevokeAndACK object into a byte array which can be read by RevokeAndACK_read
+ */
+ public byte[] write() {
+ byte[] ret = bindings.RevokeAndACK_write(this.ptr);
+ return ret;
}
- // Skipped RevokeAndACK_write
- public RevokeAndACK(byte[] ser) {
- super(bindings.RevokeAndACK_read(ser));
+ /**
+ * Read a RevokeAndACK from a byte array, created by RevokeAndACK_write
+ */
+ public static Result_RevokeAndACKDecodeErrorZ read(byte[] ser) {
+ long ret = bindings.RevokeAndACK_read(ser);
+ Result_RevokeAndACKDecodeErrorZ ret_hu_conv = Result_RevokeAndACKDecodeErrorZ.constr_from_ptr(ret);
+ return ret_hu_conv;
}
}