Fix returning traits in trait calls, move towards clone on return
[ldk-java] / src / main / java / org / ldk / structs / SocketDescriptor.java
index 9c4f9e7b251d69148aca10dddf1f0f20f59152c9..f4956896545c94a77f9d217ccdb5d3505b802c5b 100644 (file)
@@ -25,8 +25,10 @@ public class SocketDescriptor extends CommonBase {
                boolean eq(long other_arg);
                long hash();
        }
-       public SocketDescriptor(SocketDescriptorInterface arg) {
-               this(new bindings.LDKSocketDescriptor() {
+       private static class LDKSocketDescriptorHolder { SocketDescriptor held; }
+       public static SocketDescriptor new_impl(SocketDescriptorInterface arg) {
+               final LDKSocketDescriptorHolder impl_holder = new LDKSocketDescriptorHolder();
+               impl_holder.held = new SocketDescriptor(new bindings.LDKSocketDescriptor() {
                        @Override public long send_data(byte[] data, boolean resume_read) {
                                long ret = arg.send_data(data, resume_read);
                                return ret;
@@ -43,6 +45,7 @@ public class SocketDescriptor extends CommonBase {
                                return ret;
                        }
                });
+               return impl_holder.held;
        }
        public long send_data(byte[] data, boolean resume_read) {
                long ret = bindings.SocketDescriptor_send_data(this.ptr, data, resume_read);
@@ -58,4 +61,12 @@ public class SocketDescriptor extends CommonBase {
                return ret;
        }
 
+       public static SocketDescriptor constructor_clone(SocketDescriptor orig) {
+               long ret = bindings.SocketDescriptor_clone(orig == null ? 0 : orig.ptr);
+               SocketDescriptor ret_hu_conv = new SocketDescriptor(null, ret);
+               ret_hu_conv.ptrs_to.add(ret_hu_conv);
+               ret_hu_conv.ptrs_to.add(orig);
+               return ret_hu_conv;
+       }
+
 }