X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Forg%2Fldk%2Fstructs%2FFallback.java;fp=src%2Fmain%2Fjava%2Forg%2Fldk%2Fstructs%2FFallback.java;h=de5495fe8ac77cef74b544a84b642acec820f04f;hb=b6cc0960eaee5a5bbc7fde79a56152d6dcd649d8;hp=0000000000000000000000000000000000000000;hpb=fb06c6af463da9aa188980c750f787f5e936634a;p=ldk-java diff --git a/src/main/java/org/ldk/structs/Fallback.java b/src/main/java/org/ldk/structs/Fallback.java new file mode 100644 index 00000000..de5495fe --- /dev/null +++ b/src/main/java/org/ldk/structs/Fallback.java @@ -0,0 +1,79 @@ +package org.ldk.structs; + +import org.ldk.impl.bindings; +import org.ldk.enums.*; +import org.ldk.util.*; +import java.util.Arrays; + + +/** + * Fallback address in case no LN payment is possible + */ +@SuppressWarnings("unchecked") // We correctly assign various generic arrays +public class Fallback extends CommonBase { + private Fallback(Object _dummy, long ptr) { super(ptr); } + @Override @SuppressWarnings("deprecation") + protected void finalize() throws Throwable { + super.finalize(); + if (ptr != 0) { bindings.Fallback_free(ptr); } + } + static Fallback constr_from_ptr(long ptr) { + bindings.LDKFallback raw_val = bindings.LDKFallback_ref_from_ptr(ptr); + if (raw_val.getClass() == bindings.LDKFallback.SegWitProgram.class) { + return new SegWitProgram(ptr, (bindings.LDKFallback.SegWitProgram)raw_val); + } + if (raw_val.getClass() == bindings.LDKFallback.PubKeyHash.class) { + return new PubKeyHash(ptr, (bindings.LDKFallback.PubKeyHash)raw_val); + } + if (raw_val.getClass() == bindings.LDKFallback.ScriptHash.class) { + return new ScriptHash(ptr, (bindings.LDKFallback.ScriptHash)raw_val); + } + assert false; return null; // Unreachable without extending the (internal) bindings interface + } + + public final static class SegWitProgram extends Fallback { + public final UInt5 version; + public final byte[] program; + private SegWitProgram(long ptr, bindings.LDKFallback.SegWitProgram obj) { + super(null, ptr); + byte version = obj.version; + UInt5 version_conv = new UInt5(version); + this.version = version_conv; + this.program = obj.program; + } + } + public final static class PubKeyHash extends Fallback { + public final byte[] pub_key_hash; + private PubKeyHash(long ptr, bindings.LDKFallback.PubKeyHash obj) { + super(null, ptr); + this.pub_key_hash = obj.pub_key_hash; + } + } + public final static class ScriptHash extends Fallback { + public final byte[] script_hash; + private ScriptHash(long ptr, bindings.LDKFallback.ScriptHash obj) { + super(null, ptr); + this.script_hash = obj.script_hash; + } + } + /** + * Creates a copy of the Fallback + */ + public Fallback clone() { + long ret = bindings.Fallback_clone(this.ptr); + Fallback ret_hu_conv = Fallback.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(this); + return ret_hu_conv; + } + + /** + * Checks if two Fallbacks contain equal inner contents. + * This ignores pointers and is_owned flags and looks at the values in fields. + */ + public boolean eq(Fallback b) { + boolean ret = bindings.Fallback_eq(this.ptr, b == null ? 0 : b.ptr & ~1); + this.ptrs_to.add(b); + return ret; + } + +}