Make genbindings.sh only build one of java/wasm, test wasm in CI
[ldk-java] / ts / structs / MessageSendEventsProvider.ts
index a787a1ba90df8f36d89a41aa1c669ac6842b97ec..d4cb29a32d587aaee16bd07a704bb32640f4a504 100644 (file)
@@ -1,46 +1,67 @@
 
+            
 import CommonBase from './CommonBase';
 import * as bindings from '../bindings' // TODO: figure out location
 
-public class MessageSendEventsProvider extends CommonBase {
-       final bindings.LDKMessageSendEventsProvider bindings_instance;
-       MessageSendEventsProvider(Object _dummy, long ptr) { super(ptr); bindings_instance = null; }
-       private MessageSendEventsProvider(bindings.LDKMessageSendEventsProvider arg) {
-               super(bindings.LDKMessageSendEventsProvider_new(arg));
-               this.ptrs_to.add(arg);
-               this.bindings_instance = arg;
-       }
-       @Override @SuppressWarnings("deprecation")
-       protected void finalize() throws Throwable {
-               if (ptr != 0) { bindings.MessageSendEventsProvider_free(ptr); } super.finalize();
-       }
 
-       public static interface MessageSendEventsProviderInterface {
-               MessageSendEvent[] get_and_clear_pending_msg_events();
-       }
-       private static class LDKMessageSendEventsProviderHolder { MessageSendEventsProvider held; }
-       public static MessageSendEventsProvider new_impl(MessageSendEventsProviderInterface arg) {
-               final LDKMessageSendEventsProviderHolder impl_holder = new LDKMessageSendEventsProviderHolder();
-               impl_holder.held = new MessageSendEventsProvider(new bindings.LDKMessageSendEventsProvider() {
-                       @Override public uint32_t[] get_and_clear_pending_msg_events() {
-                               MessageSendEvent[] ret = arg.get_and_clear_pending_msg_events();
-                               uint32_t[] result = (uint32_t[])Arrays.stream(ret).map(arr_conv_18 -> arr_conv_18.ptr).toArray();
-                               /* TODO 2 MessageSendEvent  */;
+
+            export class MessageSendEventsProvider extends CommonBase {
+
+                bindings_instance?: bindings.LDKMessageSendEventsProvider;
+
+                constructor(ptr?: number, arg?: bindings.LDKMessageSendEventsProvider) {
+                    if (Number.isFinite(ptr)) {
+                                       super(ptr);
+                                       this.bindings_instance = null;
+                                   } else {
+                                       // TODO: private constructor instantiation
+                                       super(bindings.LDKMessageSendEventsProvider_new(arg));
+                                       this.ptrs_to.push(arg);
+                                       
+                                   }
+                }
+
+                protected finalize() {
+                    if (this.ptr != 0) {
+                        bindings.MessageSendEventsProvider_free(this.ptr);
+                    }
+                    super.finalize();
+                }
+
+                static new_impl(arg: MessageSendEventsProviderInterface): MessageSendEventsProvider {
+                    const impl_holder: LDKMessageSendEventsProviderHolder = new LDKMessageSendEventsProviderHolder();
+                    let structImplementation = <bindings.LDKMessageSendEventsProvider>{
+                        // todo: in-line interface filling
+                        get_and_clear_pending_msg_events (): number[] {
+                                                       MessageSendEvent[] ret = arg.get_and_clear_pending_msg_events();
+                               result: number[] = ret != null ? Arrays.stream(ret).map(ret_conv_18 -> ret_conv_18 == null ? 0 : ret_conv_18.clone_ptr()).toArray(number[]::new) : null;
                                return result;
-                       }
-               });
-               return impl_holder.held;
-       }
+                                               },
+
+                                               
+                    };
+                    impl_holder.held = new MessageSendEventsProvider (null, structImplementation);
+                }
+            }
+
+            export interface MessageSendEventsProviderInterface {
+                get_and_clear_pending_msg_events(): MessageSendEvent[];
+                               
+            }
+
+            class LDKMessageSendEventsProviderHolder {
+                held: MessageSendEventsProvider;
+            }
        public MessageSendEvent[] get_and_clear_pending_msg_events() {
-               uint32_t[] ret = bindings.MessageSendEventsProvider_get_and_clear_pending_msg_events(this.ptr);
-               MessageSendEvent[] arr_conv_18_arr = new MessageSendEvent[ret.length];
+               number[] ret = bindings.MessageSendEventsProvider_get_and_clear_pending_msg_events(this.ptr);
+               MessageSendEvent[] ret_conv_18_arr = new MessageSendEvent[ret.length];
                for (int s = 0; s < ret.length; s++) {
-                       uint32_t arr_conv_18 = ret[s];
-                       MessageSendEvent arr_conv_18_hu_conv = MessageSendEvent.constr_from_ptr(arr_conv_18);
-                       arr_conv_18_hu_conv.ptrs_to.add(this);
-                       arr_conv_18_arr[s] = arr_conv_18_hu_conv;
+                       number ret_conv_18 = ret[s];
+                       MessageSendEvent ret_conv_18_hu_conv = MessageSendEvent.constr_from_ptr(ret_conv_18);
+                       ret_conv_18_hu_conv.ptrs_to.add(this);
+                       ret_conv_18_arr[s] = ret_conv_18_hu_conv;
                }
-               return arr_conv_18_arr;
+               return ret_conv_18_arr;
        }
 
 }