[C#] Check in initial auto-generated C# bindings
[ldk-java] / c_sharp / src / org / ldk / structs / EffectiveCapacity.cs
diff --git a/c_sharp/src/org/ldk/structs/EffectiveCapacity.cs b/c_sharp/src/org/ldk/structs/EffectiveCapacity.cs
new file mode 100644 (file)
index 0000000..c7aa0e4
--- /dev/null
@@ -0,0 +1,166 @@
+using org.ldk.impl;
+using org.ldk.enums;
+using org.ldk.util;
+using System;
+
+namespace org { namespace ldk { namespace structs {
+
+/**
+ * The effective capacity of a channel for routing purposes.
+ * 
+ * While this may be smaller than the actual channel capacity, amounts greater than
+ * [`Self::as_msat`] should not be routed through the channel.
+ */
+public class EffectiveCapacity : CommonBase {
+       protected EffectiveCapacity(object _dummy, long ptr) : base(ptr) { }
+       ~EffectiveCapacity() {
+               if (ptr != 0) { bindings.EffectiveCapacity_free(ptr); }
+       }
+
+       internal static EffectiveCapacity constr_from_ptr(long ptr) {
+               long raw_ty = bindings.LDKEffectiveCapacity_ty_from_ptr(ptr);
+               switch (raw_ty) {
+                       case 0: return new EffectiveCapacity_ExactLiquidity(ptr);
+                       case 1: return new EffectiveCapacity_MaximumHTLC(ptr);
+                       case 2: return new EffectiveCapacity_Total(ptr);
+                       case 3: return new EffectiveCapacity_Infinite(ptr);
+                       case 4: return new EffectiveCapacity_Unknown(ptr);
+                       default:
+                               throw new ArgumentException("Impossible enum variant");
+               }
+       }
+
+       /** A EffectiveCapacity of type ExactLiquidity */
+       public class EffectiveCapacity_ExactLiquidity : EffectiveCapacity {
+               /**
+                * Either the inbound or outbound liquidity depending on the direction, denominated in
+                * millisatoshi.
+                */
+               public long liquidity_msat;
+               internal EffectiveCapacity_ExactLiquidity(long ptr) : base(null, ptr) {
+                       this.liquidity_msat = bindings.LDKEffectiveCapacity_ExactLiquidity_get_liquidity_msat(ptr);
+               }
+       }
+       /** A EffectiveCapacity of type MaximumHTLC */
+       public class EffectiveCapacity_MaximumHTLC : EffectiveCapacity {
+               /**
+                * The maximum HTLC amount denominated in millisatoshi.
+                */
+               public long amount_msat;
+               internal EffectiveCapacity_MaximumHTLC(long ptr) : base(null, ptr) {
+                       this.amount_msat = bindings.LDKEffectiveCapacity_MaximumHTLC_get_amount_msat(ptr);
+               }
+       }
+       /** A EffectiveCapacity of type Total */
+       public class EffectiveCapacity_Total : EffectiveCapacity {
+               /**
+                * The funding amount denominated in millisatoshi.
+                */
+               public long capacity_msat;
+               /**
+                * The maximum HTLC amount denominated in millisatoshi.
+                */
+               public long htlc_maximum_msat;
+               internal EffectiveCapacity_Total(long ptr) : base(null, ptr) {
+                       this.capacity_msat = bindings.LDKEffectiveCapacity_Total_get_capacity_msat(ptr);
+                       this.htlc_maximum_msat = bindings.LDKEffectiveCapacity_Total_get_htlc_maximum_msat(ptr);
+               }
+       }
+       /** A EffectiveCapacity of type Infinite */
+       public class EffectiveCapacity_Infinite : EffectiveCapacity {
+               internal EffectiveCapacity_Infinite(long ptr) : base(null, ptr) {
+               }
+       }
+       /** A EffectiveCapacity of type Unknown */
+       public class EffectiveCapacity_Unknown : EffectiveCapacity {
+               internal EffectiveCapacity_Unknown(long ptr) : base(null, ptr) {
+               }
+       }
+       internal long clone_ptr() {
+               long ret = bindings.EffectiveCapacity_clone_ptr(this.ptr);
+               GC.KeepAlive(this);
+               return ret;
+       }
+
+       /**
+        * Creates a copy of the EffectiveCapacity
+        */
+       public EffectiveCapacity clone() {
+               long ret = bindings.EffectiveCapacity_clone(this.ptr);
+               GC.KeepAlive(this);
+               if (ret >= 0 && ret <= 4096) { return null; }
+               org.ldk.structs.EffectiveCapacity ret_hu_conv = org.ldk.structs.EffectiveCapacity.constr_from_ptr(ret);
+               if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(this); };
+               return ret_hu_conv;
+       }
+
+       /**
+        * Utility method to constructs a new ExactLiquidity-variant EffectiveCapacity
+        */
+       public static EffectiveCapacity exact_liquidity(long liquidity_msat) {
+               long ret = bindings.EffectiveCapacity_exact_liquidity(liquidity_msat);
+               GC.KeepAlive(liquidity_msat);
+               if (ret >= 0 && ret <= 4096) { return null; }
+               org.ldk.structs.EffectiveCapacity ret_hu_conv = org.ldk.structs.EffectiveCapacity.constr_from_ptr(ret);
+               if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(ret_hu_conv); };
+               return ret_hu_conv;
+       }
+
+       /**
+        * Utility method to constructs a new MaximumHTLC-variant EffectiveCapacity
+        */
+       public static EffectiveCapacity maximum_htlc(long amount_msat) {
+               long ret = bindings.EffectiveCapacity_maximum_htlc(amount_msat);
+               GC.KeepAlive(amount_msat);
+               if (ret >= 0 && ret <= 4096) { return null; }
+               org.ldk.structs.EffectiveCapacity ret_hu_conv = org.ldk.structs.EffectiveCapacity.constr_from_ptr(ret);
+               if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(ret_hu_conv); };
+               return ret_hu_conv;
+       }
+
+       /**
+        * Utility method to constructs a new Total-variant EffectiveCapacity
+        */
+       public static EffectiveCapacity total(long capacity_msat, long htlc_maximum_msat) {
+               long ret = bindings.EffectiveCapacity_total(capacity_msat, htlc_maximum_msat);
+               GC.KeepAlive(capacity_msat);
+               GC.KeepAlive(htlc_maximum_msat);
+               if (ret >= 0 && ret <= 4096) { return null; }
+               org.ldk.structs.EffectiveCapacity ret_hu_conv = org.ldk.structs.EffectiveCapacity.constr_from_ptr(ret);
+               if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(ret_hu_conv); };
+               return ret_hu_conv;
+       }
+
+       /**
+        * Utility method to constructs a new Infinite-variant EffectiveCapacity
+        */
+       public static EffectiveCapacity infinite() {
+               long ret = bindings.EffectiveCapacity_infinite();
+               if (ret >= 0 && ret <= 4096) { return null; }
+               org.ldk.structs.EffectiveCapacity ret_hu_conv = org.ldk.structs.EffectiveCapacity.constr_from_ptr(ret);
+               if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(ret_hu_conv); };
+               return ret_hu_conv;
+       }
+
+       /**
+        * Utility method to constructs a new Unknown-variant EffectiveCapacity
+        */
+       public static EffectiveCapacity unknown() {
+               long ret = bindings.EffectiveCapacity_unknown();
+               if (ret >= 0 && ret <= 4096) { return null; }
+               org.ldk.structs.EffectiveCapacity ret_hu_conv = org.ldk.structs.EffectiveCapacity.constr_from_ptr(ret);
+               if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(ret_hu_conv); };
+               return ret_hu_conv;
+       }
+
+       /**
+        * Returns the effective capacity denominated in millisatoshi.
+        */
+       public long as_msat() {
+               long ret = bindings.EffectiveCapacity_as_msat(this.ptr);
+               GC.KeepAlive(this);
+               return ret;
+       }
+
+}
+} } }