- public static interface PersistInterface {
- Result_NoneChannelMonitorUpdateErrZ persist_new_channel(OutPoint id, ChannelMonitor data);
- Result_NoneChannelMonitorUpdateErrZ update_persisted_channel(OutPoint id, ChannelMonitorUpdate update, ChannelMonitor data);
- }
- private static class LDKPersistHolder { Persist held; }
- public static Persist new_impl(PersistInterface arg) {
- final LDKPersistHolder impl_holder = new LDKPersistHolder();
- impl_holder.held = new Persist(new bindings.LDKPersist() {
- @Override public uint32_t persist_new_channel(uint32_t id, uint32_t data) {
- OutPoint id_hu_conv = new OutPoint(null, id);
- ChannelMonitor data_hu_conv = new ChannelMonitor(null, data);
- Result_NoneChannelMonitorUpdateErrZ ret = arg.persist_new_channel(id_hu_conv, data_hu_conv);
- uint32_t result = ret != null ? ret.ptr : 0;
- ret.ptr = 0;
+
+ export class Persist extends CommonBase {
+
+ bindings_instance?: bindings.LDKPersist;
+
+ constructor(ptr?: number, arg?: bindings.LDKPersist) {
+ if (Number.isFinite(ptr)) {
+ super(ptr);
+ this.bindings_instance = null;
+ } else {
+ // TODO: private constructor instantiation
+ super(bindings.LDKPersist_new(arg));
+ this.ptrs_to.push(arg);
+
+ }
+ }
+
+ protected finalize() {
+ if (this.ptr != 0) {
+ bindings.Persist_free(this.ptr);
+ }
+ super.finalize();
+ }
+
+ static new_impl(arg: PersistInterface): Persist {
+ const impl_holder: LDKPersistHolder = new LDKPersistHolder();
+ let structImplementation = <bindings.LDKPersist>{
+ // todo: in-line interface filling
+ persist_new_channel (id: number, data: number): number {
+ const id_hu_conv: OutPoint = new OutPoint(null, id);
+ id_hu_conv.ptrs_to.add(this);
+ const data_hu_conv: ChannelMonitor = new ChannelMonitor(null, data);
+ Result_NoneChannelMonitorUpdateErrZ ret = arg.persist_new_channel(id_hu_conv, data_hu_conv);
+ result: number = ret != null ? ret.ptr : 0;