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 * Features used within an `init` message.
14 @SuppressWarnings("unchecked") // We correctly assign various generic arrays
15 public class InitFeatures extends CommonBase {
16 InitFeatures(Object _dummy, long ptr) { super(ptr); }
17 @Override @SuppressWarnings("deprecation")
18 protected void finalize() throws Throwable {
20 if (ptr != 0) { bindings.InitFeatures_free(ptr); }
24 * Checks if two InitFeaturess contain equal inner contents.
25 * This ignores pointers and is_owned flags and looks at the values in fields.
26 * Two objects with NULL inner values will be considered "equal" here.
28 public boolean eq(InitFeatures b) {
29 boolean ret = bindings.InitFeatures_eq(this.ptr, b == null ? 0 : b.ptr);
30 Reference.reachabilityFence(this);
31 Reference.reachabilityFence(b);
32 if (this != null) { this.ptrs_to.add(b); };
36 @Override public boolean equals(Object o) {
37 if (!(o instanceof InitFeatures)) return false;
38 return this.eq((InitFeatures)o);
41 long ret = bindings.InitFeatures_clone_ptr(this.ptr);
42 Reference.reachabilityFence(this);
47 * Creates a copy of the InitFeatures
49 public InitFeatures clone() {
50 long ret = bindings.InitFeatures_clone(this.ptr);
51 Reference.reachabilityFence(this);
52 if (ret >= 0 && ret <= 4096) { return null; }
53 org.ldk.structs.InitFeatures ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.InitFeatures(null, ret); }
54 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.add(this); };
59 * Create a blank Features with no features set
61 public static InitFeatures empty() {
62 long ret = bindings.InitFeatures_empty();
63 if (ret >= 0 && ret <= 4096) { return null; }
64 org.ldk.structs.InitFeatures ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.InitFeatures(null, ret); }
65 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.add(ret_hu_conv); };
70 * Returns true if this `Features` object contains unknown feature flags which are set as
73 public boolean requires_unknown_bits() {
74 boolean ret = bindings.InitFeatures_requires_unknown_bits(this.ptr);
75 Reference.reachabilityFence(this);
80 * Serialize the InitFeatures object into a byte array which can be read by InitFeatures_read
82 public byte[] write() {
83 byte[] ret = bindings.InitFeatures_write(this.ptr);
84 Reference.reachabilityFence(this);
89 * Read a InitFeatures from a byte array, created by InitFeatures_write
91 public static Result_InitFeaturesDecodeErrorZ read(byte[] ser) {
92 long ret = bindings.InitFeatures_read(ser);
93 Reference.reachabilityFence(ser);
94 if (ret >= 0 && ret <= 4096) { return null; }
95 Result_InitFeaturesDecodeErrorZ ret_hu_conv = Result_InitFeaturesDecodeErrorZ.constr_from_ptr(ret);
100 * Set this feature as optional.
102 public void set_data_loss_protect_optional() {
103 bindings.InitFeatures_set_data_loss_protect_optional(this.ptr);
104 Reference.reachabilityFence(this);
108 * Set this feature as required.
110 public void set_data_loss_protect_required() {
111 bindings.InitFeatures_set_data_loss_protect_required(this.ptr);
112 Reference.reachabilityFence(this);
116 * Checks if this feature is supported.
118 public boolean supports_data_loss_protect() {
119 boolean ret = bindings.InitFeatures_supports_data_loss_protect(this.ptr);
120 Reference.reachabilityFence(this);
125 * Checks if this feature is required.
127 public boolean requires_data_loss_protect() {
128 boolean ret = bindings.InitFeatures_requires_data_loss_protect(this.ptr);
129 Reference.reachabilityFence(this);
134 * Set this feature as optional.
136 public void set_initial_routing_sync_optional() {
137 bindings.InitFeatures_set_initial_routing_sync_optional(this.ptr);
138 Reference.reachabilityFence(this);
142 * Set this feature as required.
144 public void set_initial_routing_sync_required() {
145 bindings.InitFeatures_set_initial_routing_sync_required(this.ptr);
146 Reference.reachabilityFence(this);
150 * Checks if this feature is supported.
152 public boolean initial_routing_sync() {
153 boolean ret = bindings.InitFeatures_initial_routing_sync(this.ptr);
154 Reference.reachabilityFence(this);
159 * Set this feature as optional.
161 public void set_upfront_shutdown_script_optional() {
162 bindings.InitFeatures_set_upfront_shutdown_script_optional(this.ptr);
163 Reference.reachabilityFence(this);
167 * Set this feature as required.
169 public void set_upfront_shutdown_script_required() {
170 bindings.InitFeatures_set_upfront_shutdown_script_required(this.ptr);
171 Reference.reachabilityFence(this);
175 * Checks if this feature is supported.
177 public boolean supports_upfront_shutdown_script() {
178 boolean ret = bindings.InitFeatures_supports_upfront_shutdown_script(this.ptr);
179 Reference.reachabilityFence(this);
184 * Checks if this feature is required.
186 public boolean requires_upfront_shutdown_script() {
187 boolean ret = bindings.InitFeatures_requires_upfront_shutdown_script(this.ptr);
188 Reference.reachabilityFence(this);
193 * Set this feature as optional.
195 public void set_gossip_queries_optional() {
196 bindings.InitFeatures_set_gossip_queries_optional(this.ptr);
197 Reference.reachabilityFence(this);
201 * Set this feature as required.
203 public void set_gossip_queries_required() {
204 bindings.InitFeatures_set_gossip_queries_required(this.ptr);
205 Reference.reachabilityFence(this);
209 * Checks if this feature is supported.
211 public boolean supports_gossip_queries() {
212 boolean ret = bindings.InitFeatures_supports_gossip_queries(this.ptr);
213 Reference.reachabilityFence(this);
218 * Checks if this feature is required.
220 public boolean requires_gossip_queries() {
221 boolean ret = bindings.InitFeatures_requires_gossip_queries(this.ptr);
222 Reference.reachabilityFence(this);
227 * Set this feature as optional.
229 public void set_variable_length_onion_optional() {
230 bindings.InitFeatures_set_variable_length_onion_optional(this.ptr);
231 Reference.reachabilityFence(this);
235 * Set this feature as required.
237 public void set_variable_length_onion_required() {
238 bindings.InitFeatures_set_variable_length_onion_required(this.ptr);
239 Reference.reachabilityFence(this);
243 * Checks if this feature is supported.
245 public boolean supports_variable_length_onion() {
246 boolean ret = bindings.InitFeatures_supports_variable_length_onion(this.ptr);
247 Reference.reachabilityFence(this);
252 * Checks if this feature is required.
254 public boolean requires_variable_length_onion() {
255 boolean ret = bindings.InitFeatures_requires_variable_length_onion(this.ptr);
256 Reference.reachabilityFence(this);
261 * Set this feature as optional.
263 public void set_static_remote_key_optional() {
264 bindings.InitFeatures_set_static_remote_key_optional(this.ptr);
265 Reference.reachabilityFence(this);
269 * Set this feature as required.
271 public void set_static_remote_key_required() {
272 bindings.InitFeatures_set_static_remote_key_required(this.ptr);
273 Reference.reachabilityFence(this);
277 * Checks if this feature is supported.
279 public boolean supports_static_remote_key() {
280 boolean ret = bindings.InitFeatures_supports_static_remote_key(this.ptr);
281 Reference.reachabilityFence(this);
286 * Checks if this feature is required.
288 public boolean requires_static_remote_key() {
289 boolean ret = bindings.InitFeatures_requires_static_remote_key(this.ptr);
290 Reference.reachabilityFence(this);
295 * Set this feature as optional.
297 public void set_payment_secret_optional() {
298 bindings.InitFeatures_set_payment_secret_optional(this.ptr);
299 Reference.reachabilityFence(this);
303 * Set this feature as required.
305 public void set_payment_secret_required() {
306 bindings.InitFeatures_set_payment_secret_required(this.ptr);
307 Reference.reachabilityFence(this);
311 * Checks if this feature is supported.
313 public boolean supports_payment_secret() {
314 boolean ret = bindings.InitFeatures_supports_payment_secret(this.ptr);
315 Reference.reachabilityFence(this);
320 * Checks if this feature is required.
322 public boolean requires_payment_secret() {
323 boolean ret = bindings.InitFeatures_requires_payment_secret(this.ptr);
324 Reference.reachabilityFence(this);
329 * Set this feature as optional.
331 public void set_basic_mpp_optional() {
332 bindings.InitFeatures_set_basic_mpp_optional(this.ptr);
333 Reference.reachabilityFence(this);
337 * Set this feature as required.
339 public void set_basic_mpp_required() {
340 bindings.InitFeatures_set_basic_mpp_required(this.ptr);
341 Reference.reachabilityFence(this);
345 * Checks if this feature is supported.
347 public boolean supports_basic_mpp() {
348 boolean ret = bindings.InitFeatures_supports_basic_mpp(this.ptr);
349 Reference.reachabilityFence(this);
354 * Checks if this feature is required.
356 public boolean requires_basic_mpp() {
357 boolean ret = bindings.InitFeatures_requires_basic_mpp(this.ptr);
358 Reference.reachabilityFence(this);
363 * Set this feature as optional.
365 public void set_wumbo_optional() {
366 bindings.InitFeatures_set_wumbo_optional(this.ptr);
367 Reference.reachabilityFence(this);
371 * Set this feature as required.
373 public void set_wumbo_required() {
374 bindings.InitFeatures_set_wumbo_required(this.ptr);
375 Reference.reachabilityFence(this);
379 * Checks if this feature is supported.
381 public boolean supports_wumbo() {
382 boolean ret = bindings.InitFeatures_supports_wumbo(this.ptr);
383 Reference.reachabilityFence(this);
388 * Checks if this feature is required.
390 public boolean requires_wumbo() {
391 boolean ret = bindings.InitFeatures_requires_wumbo(this.ptr);
392 Reference.reachabilityFence(this);
397 * Set this feature as optional.
399 public void set_shutdown_any_segwit_optional() {
400 bindings.InitFeatures_set_shutdown_any_segwit_optional(this.ptr);
401 Reference.reachabilityFence(this);
405 * Set this feature as required.
407 public void set_shutdown_any_segwit_required() {
408 bindings.InitFeatures_set_shutdown_any_segwit_required(this.ptr);
409 Reference.reachabilityFence(this);
413 * Checks if this feature is supported.
415 public boolean supports_shutdown_anysegwit() {
416 boolean ret = bindings.InitFeatures_supports_shutdown_anysegwit(this.ptr);
417 Reference.reachabilityFence(this);
422 * Checks if this feature is required.
424 public boolean requires_shutdown_anysegwit() {
425 boolean ret = bindings.InitFeatures_requires_shutdown_anysegwit(this.ptr);
426 Reference.reachabilityFence(this);
431 * Set this feature as optional.
433 public void set_onion_messages_optional() {
434 bindings.InitFeatures_set_onion_messages_optional(this.ptr);
435 Reference.reachabilityFence(this);
439 * Set this feature as required.
441 public void set_onion_messages_required() {
442 bindings.InitFeatures_set_onion_messages_required(this.ptr);
443 Reference.reachabilityFence(this);
447 * Checks if this feature is supported.
449 public boolean supports_onion_messages() {
450 boolean ret = bindings.InitFeatures_supports_onion_messages(this.ptr);
451 Reference.reachabilityFence(this);
456 * Checks if this feature is required.
458 public boolean requires_onion_messages() {
459 boolean ret = bindings.InitFeatures_requires_onion_messages(this.ptr);
460 Reference.reachabilityFence(this);
465 * Set this feature as optional.
467 public void set_channel_type_optional() {
468 bindings.InitFeatures_set_channel_type_optional(this.ptr);
469 Reference.reachabilityFence(this);
473 * Set this feature as required.
475 public void set_channel_type_required() {
476 bindings.InitFeatures_set_channel_type_required(this.ptr);
477 Reference.reachabilityFence(this);
481 * Checks if this feature is supported.
483 public boolean supports_channel_type() {
484 boolean ret = bindings.InitFeatures_supports_channel_type(this.ptr);
485 Reference.reachabilityFence(this);
490 * Checks if this feature is required.
492 public boolean requires_channel_type() {
493 boolean ret = bindings.InitFeatures_requires_channel_type(this.ptr);
494 Reference.reachabilityFence(this);
499 * Set this feature as optional.
501 public void set_scid_privacy_optional() {
502 bindings.InitFeatures_set_scid_privacy_optional(this.ptr);
503 Reference.reachabilityFence(this);
507 * Set this feature as required.
509 public void set_scid_privacy_required() {
510 bindings.InitFeatures_set_scid_privacy_required(this.ptr);
511 Reference.reachabilityFence(this);
515 * Checks if this feature is supported.
517 public boolean supports_scid_privacy() {
518 boolean ret = bindings.InitFeatures_supports_scid_privacy(this.ptr);
519 Reference.reachabilityFence(this);
524 * Checks if this feature is required.
526 public boolean requires_scid_privacy() {
527 boolean ret = bindings.InitFeatures_requires_scid_privacy(this.ptr);
528 Reference.reachabilityFence(this);
533 * Set this feature as optional.
535 public void set_zero_conf_optional() {
536 bindings.InitFeatures_set_zero_conf_optional(this.ptr);
537 Reference.reachabilityFence(this);
541 * Set this feature as required.
543 public void set_zero_conf_required() {
544 bindings.InitFeatures_set_zero_conf_required(this.ptr);
545 Reference.reachabilityFence(this);
549 * Checks if this feature is supported.
551 public boolean supports_zero_conf() {
552 boolean ret = bindings.InitFeatures_supports_zero_conf(this.ptr);
553 Reference.reachabilityFence(this);
558 * Checks if this feature is required.
560 public boolean requires_zero_conf() {
561 boolean ret = bindings.InitFeatures_requires_zero_conf(this.ptr);
562 Reference.reachabilityFence(this);