X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=c_sharp%2Fsrc%2Forg%2Fldk%2Fstructs%2FOption_BlockHashZ.cs;fp=c_sharp%2Fsrc%2Forg%2Fldk%2Fstructs%2FOption_BlockHashZ.cs;h=bb039db32e203db7a2fc2316945e89758d053dc7;hb=c6777737ea14e7814b0fa7d6fe16536f31d4a82b;hp=0000000000000000000000000000000000000000;hpb=ee72c84d4bf9e2404e02fe20155efb502ceaee1b;p=ldk-java diff --git a/c_sharp/src/org/ldk/structs/Option_BlockHashZ.cs b/c_sharp/src/org/ldk/structs/Option_BlockHashZ.cs new file mode 100644 index 00000000..bb039db3 --- /dev/null +++ b/c_sharp/src/org/ldk/structs/Option_BlockHashZ.cs @@ -0,0 +1,82 @@ +using org.ldk.impl; +using org.ldk.enums; +using org.ldk.util; +using System; + +namespace org { namespace ldk { namespace structs { + +/** + * An enum which can either contain a crate::c_types::ThirtyTwoBytes or not + */ +public class Option_BlockHashZ : CommonBase { + protected Option_BlockHashZ(object _dummy, long ptr) : base(ptr) { } + ~Option_BlockHashZ() { + if (ptr != 0) { bindings.COption_BlockHashZ_free(ptr); } + } + + internal static Option_BlockHashZ constr_from_ptr(long ptr) { + long raw_ty = bindings.LDKCOption_BlockHashZ_ty_from_ptr(ptr); + switch (raw_ty) { + case 0: return new Option_BlockHashZ_Some(ptr); + case 1: return new Option_BlockHashZ_None(ptr); + default: + throw new ArgumentException("Impossible enum variant"); + } + } + + /** A Option_BlockHashZ of type Some */ + public class Option_BlockHashZ_Some : Option_BlockHashZ { + public byte[] some; + internal Option_BlockHashZ_Some(long ptr) : base(null, ptr) { + this.some = bindings.LDKCOption_BlockHashZ_Some_get_some(ptr); + } + } + /** A Option_BlockHashZ of type None */ + public class Option_BlockHashZ_None : Option_BlockHashZ { + internal Option_BlockHashZ_None(long ptr) : base(null, ptr) { + } + } + /** + * Constructs a new COption_BlockHashZ containing a crate::c_types::ThirtyTwoBytes + */ + public static Option_BlockHashZ some(byte[] o) { + long ret = bindings.COption_BlockHashZ_some(InternalUtils.check_arr_len(o, 32)); + GC.KeepAlive(o); + if (ret >= 0 && ret <= 4096) { return null; } + org.ldk.structs.Option_BlockHashZ ret_hu_conv = org.ldk.structs.Option_BlockHashZ.constr_from_ptr(ret); + if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(ret_hu_conv); }; + return ret_hu_conv; + } + + /** + * Constructs a new COption_BlockHashZ containing nothing + */ + public static Option_BlockHashZ none() { + long ret = bindings.COption_BlockHashZ_none(); + if (ret >= 0 && ret <= 4096) { return null; } + org.ldk.structs.Option_BlockHashZ ret_hu_conv = org.ldk.structs.Option_BlockHashZ.constr_from_ptr(ret); + if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(ret_hu_conv); }; + return ret_hu_conv; + } + + internal long clone_ptr() { + long ret = bindings.COption_BlockHashZ_clone_ptr(this.ptr); + GC.KeepAlive(this); + return ret; + } + + /** + * Creates a new COption_BlockHashZ which has the same data as `orig` + * but with all dynamically-allocated buffers duplicated in new buffers. + */ + public Option_BlockHashZ clone() { + long ret = bindings.COption_BlockHashZ_clone(this.ptr); + GC.KeepAlive(this); + if (ret >= 0 && ret <= 4096) { return null; } + org.ldk.structs.Option_BlockHashZ ret_hu_conv = org.ldk.structs.Option_BlockHashZ.constr_from_ptr(ret); + if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(this); }; + return ret_hu_conv; + } + +} +} } }