[Java] Update auto-generated Java bindings to LDK 0.0.121
[ldk-java] / src / main / java / org / ldk / structs / NodeFeatures.java
index 7f6c696022562c2b65ad3dc80f8f5b657e9550ba..032f6f67b5068b800037baf2ec2c36b4e44c0375 100644 (file)
@@ -25,7 +25,7 @@ public class NodeFeatures extends CommonBase {
         * This ignores pointers and is_owned flags and looks at the values in fields.
         * Two objects with NULL inner values will be considered "equal" here.
         */
-       public boolean eq(NodeFeatures b) {
+       public boolean eq(org.ldk.structs.NodeFeatures b) {
                boolean ret = bindings.NodeFeatures_eq(this.ptr, b == null ? 0 : b.ptr);
                Reference.reachabilityFence(this);
                Reference.reachabilityFence(b);
@@ -55,6 +55,18 @@ public class NodeFeatures extends CommonBase {
                return ret_hu_conv;
        }
 
+       /**
+        * Generates a non-cryptographic 64-bit hash of the NodeFeatures.
+        */
+       public long hash() {
+               long ret = bindings.NodeFeatures_hash(this.ptr);
+               Reference.reachabilityFence(this);
+               return ret;
+       }
+
+       @Override public int hashCode() {
+               return (int)this.hash();
+       }
        /**
         * Create a blank Features with no features set
         */
@@ -67,14 +79,14 @@ public class NodeFeatures extends CommonBase {
        }
 
        /**
-        * Creates a Features with the bits set which are known by the implementation
+        * Returns true if this `Features` object contains required features unknown by `other`.
         */
-       public static NodeFeatures known() {
-               long ret = bindings.NodeFeatures_known();
-               if (ret >= 0 && ret <= 4096) { return null; }
-               org.ldk.structs.NodeFeatures ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.NodeFeatures(null, ret); }
-               if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.add(ret_hu_conv); };
-               return ret_hu_conv;
+       public boolean requires_unknown_bits_from(org.ldk.structs.NodeFeatures other) {
+               boolean ret = bindings.NodeFeatures_requires_unknown_bits_from(this.ptr, other == null ? 0 : other.ptr);
+               Reference.reachabilityFence(this);
+               Reference.reachabilityFence(other);
+               if (this != null) { this.ptrs_to.add(other); };
+               return ret;
        }
 
        /**
@@ -87,6 +99,78 @@ public class NodeFeatures extends CommonBase {
                return ret;
        }
 
+       /**
+        * Sets a required feature bit. Errors if `bit` is outside the feature range as defined
+        * by [BOLT 9].
+        * 
+        * Note: Required bits are even. If an odd bit is given, then the corresponding even bit will
+        * be set instead (i.e., `bit - 1`).
+        * 
+        * [BOLT 9]: https://github.com/lightning/bolts/blob/master/09-features.md
+        */
+       public Result_NoneNoneZ set_required_feature_bit(long bit) {
+               long ret = bindings.NodeFeatures_set_required_feature_bit(this.ptr, bit);
+               Reference.reachabilityFence(this);
+               Reference.reachabilityFence(bit);
+               if (ret >= 0 && ret <= 4096) { return null; }
+               Result_NoneNoneZ ret_hu_conv = Result_NoneNoneZ.constr_from_ptr(ret);
+               return ret_hu_conv;
+       }
+
+       /**
+        * Sets an optional feature bit. Errors if `bit` is outside the feature range as defined
+        * by [BOLT 9].
+        * 
+        * Note: Optional bits are odd. If an even bit is given, then the corresponding odd bit will be
+        * set instead (i.e., `bit + 1`).
+        * 
+        * [BOLT 9]: https://github.com/lightning/bolts/blob/master/09-features.md
+        */
+       public Result_NoneNoneZ set_optional_feature_bit(long bit) {
+               long ret = bindings.NodeFeatures_set_optional_feature_bit(this.ptr, bit);
+               Reference.reachabilityFence(this);
+               Reference.reachabilityFence(bit);
+               if (ret >= 0 && ret <= 4096) { return null; }
+               Result_NoneNoneZ ret_hu_conv = Result_NoneNoneZ.constr_from_ptr(ret);
+               return ret_hu_conv;
+       }
+
+       /**
+        * Sets a required custom feature bit. Errors if `bit` is outside the custom range as defined
+        * by [bLIP 2] or if it is a known `T` feature.
+        * 
+        * Note: Required bits are even. If an odd bit is given, then the corresponding even bit will
+        * be set instead (i.e., `bit - 1`).
+        * 
+        * [bLIP 2]: https://github.com/lightning/blips/blob/master/blip-0002.md#feature-bits
+        */
+       public Result_NoneNoneZ set_required_custom_bit(long bit) {
+               long ret = bindings.NodeFeatures_set_required_custom_bit(this.ptr, bit);
+               Reference.reachabilityFence(this);
+               Reference.reachabilityFence(bit);
+               if (ret >= 0 && ret <= 4096) { return null; }
+               Result_NoneNoneZ ret_hu_conv = Result_NoneNoneZ.constr_from_ptr(ret);
+               return ret_hu_conv;
+       }
+
+       /**
+        * Sets an optional custom feature bit. Errors if `bit` is outside the custom range as defined
+        * by [bLIP 2] or if it is a known `T` feature.
+        * 
+        * Note: Optional bits are odd. If an even bit is given, then the corresponding odd bit will be
+        * set instead (i.e., `bit + 1`).
+        * 
+        * [bLIP 2]: https://github.com/lightning/blips/blob/master/blip-0002.md#feature-bits
+        */
+       public Result_NoneNoneZ set_optional_custom_bit(long bit) {
+               long ret = bindings.NodeFeatures_set_optional_custom_bit(this.ptr, bit);
+               Reference.reachabilityFence(this);
+               Reference.reachabilityFence(bit);
+               if (ret >= 0 && ret <= 4096) { return null; }
+               Result_NoneNoneZ ret_hu_conv = Result_NoneNoneZ.constr_from_ptr(ret);
+               return ret_hu_conv;
+       }
+
        /**
         * Serialize the NodeFeatures object into a byte array which can be read by NodeFeatures_read
         */
@@ -379,6 +463,108 @@ public class NodeFeatures extends CommonBase {
                return ret;
        }
 
+       /**
+        * Set this feature as optional.
+        */
+       public void set_anchors_nonzero_fee_htlc_tx_optional() {
+               bindings.NodeFeatures_set_anchors_nonzero_fee_htlc_tx_optional(this.ptr);
+               Reference.reachabilityFence(this);
+       }
+
+       /**
+        * Set this feature as required.
+        */
+       public void set_anchors_nonzero_fee_htlc_tx_required() {
+               bindings.NodeFeatures_set_anchors_nonzero_fee_htlc_tx_required(this.ptr);
+               Reference.reachabilityFence(this);
+       }
+
+       /**
+        * Checks if this feature is supported.
+        */
+       public boolean supports_anchors_nonzero_fee_htlc_tx() {
+               boolean ret = bindings.NodeFeatures_supports_anchors_nonzero_fee_htlc_tx(this.ptr);
+               Reference.reachabilityFence(this);
+               return ret;
+       }
+
+       /**
+        * Checks if this feature is required.
+        */
+       public boolean requires_anchors_nonzero_fee_htlc_tx() {
+               boolean ret = bindings.NodeFeatures_requires_anchors_nonzero_fee_htlc_tx(this.ptr);
+               Reference.reachabilityFence(this);
+               return ret;
+       }
+
+       /**
+        * Set this feature as optional.
+        */
+       public void set_anchors_zero_fee_htlc_tx_optional() {
+               bindings.NodeFeatures_set_anchors_zero_fee_htlc_tx_optional(this.ptr);
+               Reference.reachabilityFence(this);
+       }
+
+       /**
+        * Set this feature as required.
+        */
+       public void set_anchors_zero_fee_htlc_tx_required() {
+               bindings.NodeFeatures_set_anchors_zero_fee_htlc_tx_required(this.ptr);
+               Reference.reachabilityFence(this);
+       }
+
+       /**
+        * Checks if this feature is supported.
+        */
+       public boolean supports_anchors_zero_fee_htlc_tx() {
+               boolean ret = bindings.NodeFeatures_supports_anchors_zero_fee_htlc_tx(this.ptr);
+               Reference.reachabilityFence(this);
+               return ret;
+       }
+
+       /**
+        * Checks if this feature is required.
+        */
+       public boolean requires_anchors_zero_fee_htlc_tx() {
+               boolean ret = bindings.NodeFeatures_requires_anchors_zero_fee_htlc_tx(this.ptr);
+               Reference.reachabilityFence(this);
+               return ret;
+       }
+
+       /**
+        * Set this feature as optional.
+        */
+       public void set_route_blinding_optional() {
+               bindings.NodeFeatures_set_route_blinding_optional(this.ptr);
+               Reference.reachabilityFence(this);
+       }
+
+       /**
+        * Set this feature as required.
+        */
+       public void set_route_blinding_required() {
+               bindings.NodeFeatures_set_route_blinding_required(this.ptr);
+               Reference.reachabilityFence(this);
+       }
+
+       /**
+        * Checks if this feature is supported.
+        */
+       public boolean supports_route_blinding() {
+               boolean ret = bindings.NodeFeatures_supports_route_blinding(this.ptr);
+               Reference.reachabilityFence(this);
+               return ret;
+       }
+
+       /**
+        * Checks if this feature is required.
+        */
+       public boolean requires_route_blinding() {
+               boolean ret = bindings.NodeFeatures_requires_route_blinding(this.ptr);
+               Reference.reachabilityFence(this);
+               return ret;
+       }
+
        /**
         * Set this feature as optional.
         */
@@ -413,6 +599,74 @@ public class NodeFeatures extends CommonBase {
                return ret;
        }
 
+       /**
+        * Set this feature as optional.
+        */
+       public void set_taproot_optional() {
+               bindings.NodeFeatures_set_taproot_optional(this.ptr);
+               Reference.reachabilityFence(this);
+       }
+
+       /**
+        * Set this feature as required.
+        */
+       public void set_taproot_required() {
+               bindings.NodeFeatures_set_taproot_required(this.ptr);
+               Reference.reachabilityFence(this);
+       }
+
+       /**
+        * Checks if this feature is supported.
+        */
+       public boolean supports_taproot() {
+               boolean ret = bindings.NodeFeatures_supports_taproot(this.ptr);
+               Reference.reachabilityFence(this);
+               return ret;
+       }
+
+       /**
+        * Checks if this feature is required.
+        */
+       public boolean requires_taproot() {
+               boolean ret = bindings.NodeFeatures_requires_taproot(this.ptr);
+               Reference.reachabilityFence(this);
+               return ret;
+       }
+
+       /**
+        * Set this feature as optional.
+        */
+       public void set_onion_messages_optional() {
+               bindings.NodeFeatures_set_onion_messages_optional(this.ptr);
+               Reference.reachabilityFence(this);
+       }
+
+       /**
+        * Set this feature as required.
+        */
+       public void set_onion_messages_required() {
+               bindings.NodeFeatures_set_onion_messages_required(this.ptr);
+               Reference.reachabilityFence(this);
+       }
+
+       /**
+        * Checks if this feature is supported.
+        */
+       public boolean supports_onion_messages() {
+               boolean ret = bindings.NodeFeatures_supports_onion_messages(this.ptr);
+               Reference.reachabilityFence(this);
+               return ret;
+       }
+
+       /**
+        * Checks if this feature is required.
+        */
+       public boolean requires_onion_messages() {
+               boolean ret = bindings.NodeFeatures_requires_onion_messages(this.ptr);
+               Reference.reachabilityFence(this);
+               return ret;
+       }
+
        /**
         * Set this feature as optional.
         */