Bindings updates
[ldk-java] / src / main / java / org / ldk / structs / ErrorAction.java
index 642fb0a4594a041068c01b5c106fa1b954ed5307..f5d1f0fb8949f9865bfb5f68039d7116f6d8de4b 100644 (file)
@@ -8,33 +8,48 @@ import java.util.Arrays;
 @SuppressWarnings("unchecked") // We correctly assign various generic arrays
 public class ErrorAction extends CommonBase {
        private ErrorAction(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.ErrorAction_free(ptr); }
+       }
        static ErrorAction constr_from_ptr(long ptr) {
                bindings.LDKErrorAction raw_val = bindings.LDKErrorAction_ref_from_ptr(ptr);
                if (raw_val.getClass() == bindings.LDKErrorAction.DisconnectPeer.class) {
-                       return new DisconnectPeer(null, ptr);
+                       return new DisconnectPeer(ptr, (bindings.LDKErrorAction.DisconnectPeer)raw_val);
                }
                if (raw_val.getClass() == bindings.LDKErrorAction.IgnoreError.class) {
-                       return new IgnoreError(null, ptr);
+                       return new IgnoreError(ptr, (bindings.LDKErrorAction.IgnoreError)raw_val);
                }
                if (raw_val.getClass() == bindings.LDKErrorAction.SendErrorMessage.class) {
-                       return new SendErrorMessage(null, ptr);
+                       return new SendErrorMessage(ptr, (bindings.LDKErrorAction.SendErrorMessage)raw_val);
                }
                assert false; return null; // Unreachable without extending the (internal) bindings interface
        }
 
        public final static class DisconnectPeer extends ErrorAction {
-               public ErrorMessage msg;
-               private DisconnectPeer(Object _dummy, long ptr) { super(null, ptr); }
-               @Override long conv_to_c() { return 0; /*XXX*/ }
+               public final ErrorMessage msg;
+               private DisconnectPeer(long ptr, bindings.LDKErrorAction.DisconnectPeer obj) {
+                       super(null, ptr);
+                       long msg = obj.msg;
+                       ErrorMessage msg_hu_conv = new ErrorMessage(null, msg);
+                       msg_hu_conv.ptrs_to.add(this);
+                       this.msg = msg_hu_conv;
+               }
        }
        public final static class IgnoreError extends ErrorAction {
-               private IgnoreError(Object _dummy, long ptr) { super(null, ptr); }
-               @Override long conv_to_c() { return 0; /*XXX*/ }
+               private IgnoreError(long ptr, bindings.LDKErrorAction.IgnoreError obj) {
+                       super(null, ptr);
+               }
        }
        public final static class SendErrorMessage extends ErrorAction {
-               public ErrorMessage msg;
-               private SendErrorMessage(Object _dummy, long ptr) { super(null, ptr); }
-               @Override long conv_to_c() { return 0; /*XXX*/ }
+               public final ErrorMessage msg;
+               private SendErrorMessage(long ptr, bindings.LDKErrorAction.SendErrorMessage obj) {
+                       super(null, ptr);
+                       long msg = obj.msg;
+                       ErrorMessage msg_hu_conv = new ErrorMessage(null, msg);
+                       msg_hu_conv.ptrs_to.add(this);
+                       this.msg = msg_hu_conv;
+               }
        }
 }