return ret_hu_conv;
}
+ /**
+ * Returns true if this `Features` object contains required features unknown by `other`.
+ */
+ public bool requires_unknown_bits_from(org.ldk.structs.ChannelTypeFeatures other) {
+ bool ret = bindings.ChannelTypeFeatures_requires_unknown_bits_from(this.ptr, other == null ? 0 : other.ptr);
+ GC.KeepAlive(this);
+ GC.KeepAlive(other);
+ if (this != null) { this.ptrs_to.AddLast(other); };
+ return ret;
+ }
+
/**
* Returns true if this `Features` object contains unknown feature flags which are set as
* \"required\".
return ret;
}
+ /**
+ * 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.ChannelTypeFeatures_set_required_custom_bit(this.ptr, bit);
+ GC.KeepAlive(this);
+ GC.KeepAlive(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.ChannelTypeFeatures_set_optional_custom_bit(this.ptr, bit);
+ GC.KeepAlive(this);
+ GC.KeepAlive(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 ChannelTypeFeatures object into a byte array which can be read by ChannelTypeFeatures_read
*/
return ret;
}
+ /**
+ * Set this feature as optional.
+ */
+ public void set_anchors_nonzero_fee_htlc_tx_optional() {
+ bindings.ChannelTypeFeatures_set_anchors_nonzero_fee_htlc_tx_optional(this.ptr);
+ GC.KeepAlive(this);
+ }
+
+ /**
+ * Set this feature as required.
+ */
+ public void set_anchors_nonzero_fee_htlc_tx_required() {
+ bindings.ChannelTypeFeatures_set_anchors_nonzero_fee_htlc_tx_required(this.ptr);
+ GC.KeepAlive(this);
+ }
+
+ /**
+ * Checks if this feature is supported.
+ */
+ public bool supports_anchors_nonzero_fee_htlc_tx() {
+ bool ret = bindings.ChannelTypeFeatures_supports_anchors_nonzero_fee_htlc_tx(this.ptr);
+ GC.KeepAlive(this);
+ return ret;
+ }
+
+ /**
+ * Checks if this feature is required.
+ */
+ public bool requires_anchors_nonzero_fee_htlc_tx() {
+ bool ret = bindings.ChannelTypeFeatures_requires_anchors_nonzero_fee_htlc_tx(this.ptr);
+ GC.KeepAlive(this);
+ return ret;
+ }
+
+ /**
+ * Set this feature as optional.
+ */
+ public void set_anchors_zero_fee_htlc_tx_optional() {
+ bindings.ChannelTypeFeatures_set_anchors_zero_fee_htlc_tx_optional(this.ptr);
+ GC.KeepAlive(this);
+ }
+
+ /**
+ * Set this feature as required.
+ */
+ public void set_anchors_zero_fee_htlc_tx_required() {
+ bindings.ChannelTypeFeatures_set_anchors_zero_fee_htlc_tx_required(this.ptr);
+ GC.KeepAlive(this);
+ }
+
+ /**
+ * Checks if this feature is supported.
+ */
+ public bool supports_anchors_zero_fee_htlc_tx() {
+ bool ret = bindings.ChannelTypeFeatures_supports_anchors_zero_fee_htlc_tx(this.ptr);
+ GC.KeepAlive(this);
+ return ret;
+ }
+
+ /**
+ * Checks if this feature is required.
+ */
+ public bool requires_anchors_zero_fee_htlc_tx() {
+ bool ret = bindings.ChannelTypeFeatures_requires_anchors_zero_fee_htlc_tx(this.ptr);
+ GC.KeepAlive(this);
+ return ret;
+ }
+
/**
* Set this feature as optional.
*/