X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Forg%2Fldk%2Fstructs%2FAPIError.java;h=d82d0a5aea1ba3d623ee4e745ad6a4324dbd3707;hb=32692e00046b7ec16b6a2e20bd54800b2b48d4c0;hp=61a7a4a5137d8b1910f39aad86fc7babebbce3b8;hpb=110f2f104ba8fc34caa7e34e04737f36f064b050;p=ldk-java diff --git a/src/main/java/org/ldk/structs/APIError.java b/src/main/java/org/ldk/structs/APIError.java index 61a7a4a5..d82d0a5a 100644 --- a/src/main/java/org/ldk/structs/APIError.java +++ b/src/main/java/org/ldk/structs/APIError.java @@ -4,54 +4,182 @@ import org.ldk.impl.bindings; import org.ldk.enums.*; import org.ldk.util.*; import java.util.Arrays; +import javax.annotation.Nullable; + +/** + * Indicates an error on the client's part (usually some variant of attempting to use too-low or + * too-high values) + */ @SuppressWarnings("unchecked") // We correctly assign various generic arrays public class APIError extends CommonBase { private APIError(Object _dummy, long ptr) { super(ptr); } - long conv_to_c() { assert false; return 0; /* Should only be called on subclasses */ } + @Override @SuppressWarnings("deprecation") + protected void finalize() throws Throwable { + super.finalize(); + if (ptr != 0) { bindings.APIError_free(ptr); } + } static APIError constr_from_ptr(long ptr) { bindings.LDKAPIError raw_val = bindings.LDKAPIError_ref_from_ptr(ptr); if (raw_val.getClass() == bindings.LDKAPIError.APIMisuseError.class) { - return new APIMisuseError(null, ptr); + return new APIMisuseError(ptr, (bindings.LDKAPIError.APIMisuseError)raw_val); } if (raw_val.getClass() == bindings.LDKAPIError.FeeRateTooHigh.class) { - return new FeeRateTooHigh(null, ptr); + return new FeeRateTooHigh(ptr, (bindings.LDKAPIError.FeeRateTooHigh)raw_val); } if (raw_val.getClass() == bindings.LDKAPIError.RouteError.class) { - return new RouteError(null, ptr); + return new RouteError(ptr, (bindings.LDKAPIError.RouteError)raw_val); } if (raw_val.getClass() == bindings.LDKAPIError.ChannelUnavailable.class) { - return new ChannelUnavailable(null, ptr); + return new ChannelUnavailable(ptr, (bindings.LDKAPIError.ChannelUnavailable)raw_val); } if (raw_val.getClass() == bindings.LDKAPIError.MonitorUpdateFailed.class) { - return new MonitorUpdateFailed(null, ptr); + return new MonitorUpdateFailed(ptr, (bindings.LDKAPIError.MonitorUpdateFailed)raw_val); + } + if (raw_val.getClass() == bindings.LDKAPIError.IncompatibleShutdownScript.class) { + return new IncompatibleShutdownScript(ptr, (bindings.LDKAPIError.IncompatibleShutdownScript)raw_val); } assert false; return null; // Unreachable without extending the (internal) bindings interface } public final static class APIMisuseError extends APIError { - public byte[] err; - private APIMisuseError(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + /** + * A human-readable error message + */ + public final String err; + private APIMisuseError(long ptr, bindings.LDKAPIError.APIMisuseError obj) { + super(null, ptr); + this.err = obj.err; + } } public final static class FeeRateTooHigh extends APIError { - public byte[] err; - public int feerate; - private FeeRateTooHigh(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + /** + * A human-readable error message + */ + public final String err; + /** + * The feerate which was too high. + */ + public final int feerate; + private FeeRateTooHigh(long ptr, bindings.LDKAPIError.FeeRateTooHigh obj) { + super(null, ptr); + this.err = obj.err; + this.feerate = obj.feerate; + } } public final static class RouteError extends APIError { - public String err; - private RouteError(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + /** + * A human-readable error message + */ + public final String err; + private RouteError(long ptr, bindings.LDKAPIError.RouteError obj) { + super(null, ptr); + this.err = obj.err; + } } public final static class ChannelUnavailable extends APIError { - public byte[] err; - private ChannelUnavailable(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + /** + * A human-readable error message + */ + public final String err; + private ChannelUnavailable(long ptr, bindings.LDKAPIError.ChannelUnavailable obj) { + super(null, ptr); + this.err = obj.err; + } } public final static class MonitorUpdateFailed extends APIError { - private MonitorUpdateFailed(Object _dummy, long ptr) { super(null, ptr); } - @Override long conv_to_c() { return 0; /*XXX*/ } + private MonitorUpdateFailed(long ptr, bindings.LDKAPIError.MonitorUpdateFailed obj) { + super(null, ptr); + } + } + public final static class IncompatibleShutdownScript extends APIError { + /** + * The incompatible shutdown script. + */ + public final ShutdownScript script; + private IncompatibleShutdownScript(long ptr, bindings.LDKAPIError.IncompatibleShutdownScript obj) { + super(null, ptr); + long script = obj.script; + ShutdownScript script_hu_conv = new ShutdownScript(null, script); + script_hu_conv.ptrs_to.add(this); + this.script = script_hu_conv; + } + } + /** + * Creates a copy of the APIError + */ + public APIError clone() { + long ret = bindings.APIError_clone(this.ptr); + if (ret >= 0 && ret < 1024) { return null; } + APIError ret_hu_conv = APIError.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(this); + return ret_hu_conv; + } + + /** + * Utility method to constructs a new APIMisuseError-variant APIError + */ + public static APIError apimisuse_error(java.lang.String err) { + long ret = bindings.APIError_apimisuse_error(err); + if (ret >= 0 && ret < 1024) { return null; } + APIError ret_hu_conv = APIError.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(ret_hu_conv); + return ret_hu_conv; + } + + /** + * Utility method to constructs a new FeeRateTooHigh-variant APIError + */ + public static APIError fee_rate_too_high(java.lang.String err, int feerate) { + long ret = bindings.APIError_fee_rate_too_high(err, feerate); + if (ret >= 0 && ret < 1024) { return null; } + APIError ret_hu_conv = APIError.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(ret_hu_conv); + return ret_hu_conv; + } + + /** + * Utility method to constructs a new RouteError-variant APIError + */ + public static APIError route_error(java.lang.String err) { + long ret = bindings.APIError_route_error(err); + if (ret >= 0 && ret < 1024) { return null; } + APIError ret_hu_conv = APIError.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(ret_hu_conv); + return ret_hu_conv; + } + + /** + * Utility method to constructs a new ChannelUnavailable-variant APIError + */ + public static APIError channel_unavailable(java.lang.String err) { + long ret = bindings.APIError_channel_unavailable(err); + if (ret >= 0 && ret < 1024) { return null; } + APIError ret_hu_conv = APIError.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(ret_hu_conv); + return ret_hu_conv; + } + + /** + * Utility method to constructs a new MonitorUpdateFailed-variant APIError + */ + public static APIError monitor_update_failed() { + long ret = bindings.APIError_monitor_update_failed(); + if (ret >= 0 && ret < 1024) { return null; } + APIError ret_hu_conv = APIError.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(ret_hu_conv); + return ret_hu_conv; } + + /** + * Utility method to constructs a new IncompatibleShutdownScript-variant APIError + */ + public static APIError incompatible_shutdown_script(ShutdownScript script) { + long ret = bindings.APIError_incompatible_shutdown_script(script == null ? 0 : script.ptr & ~1); + if (ret >= 0 && ret < 1024) { return null; } + APIError ret_hu_conv = APIError.constr_from_ptr(ret); + ret_hu_conv.ptrs_to.add(ret_hu_conv); + return ret_hu_conv; + } + }