3 import CommonBase from './CommonBase';
4 import * as bindings from '../bindings' // TODO: figure out location
8 export class ChannelManagerPersister extends CommonBase {
10 bindings_instance?: bindings.LDKChannelManagerPersister;
12 constructor(ptr?: number, arg?: bindings.LDKChannelManagerPersister) {
13 if (Number.isFinite(ptr)) {
15 this.bindings_instance = null;
17 // TODO: private constructor instantiation
18 super(bindings.LDKChannelManagerPersister_new(arg));
19 this.ptrs_to.push(arg);
24 protected finalize() {
26 bindings.ChannelManagerPersister_free(this.ptr);
31 static new_impl(arg: ChannelManagerPersisterInterface): ChannelManagerPersister {
32 const impl_holder: LDKChannelManagerPersisterHolder = new LDKChannelManagerPersisterHolder();
33 let structImplementation = <bindings.LDKChannelManagerPersister>{
34 // todo: in-line interface filling
35 persist_manager (channel_manager: number): number {
36 const channel_manager_hu_conv: ChannelManager = new ChannelManager(null, channel_manager);
37 Result_NoneErrorZ ret = arg.persist_manager(channel_manager_hu_conv);
38 result: number = ret == null ? 0 : ret.clone_ptr();
44 impl_holder.held = new ChannelManagerPersister (null, structImplementation);
48 export interface ChannelManagerPersisterInterface {
49 persist_manager(channel_manager: ChannelManager): Result_NoneErrorZ;
53 class LDKChannelManagerPersisterHolder {
54 held: ChannelManagerPersister;
56 public Result_NoneErrorZ persist_manager(ChannelManager channel_manager) {
57 number ret = bindings.ChannelManagerPersister_persist_manager(this.ptr, channel_manager == null ? 0 : channel_manager.ptr & ~1);
58 Result_NoneErrorZ ret_hu_conv = Result_NoneErrorZ.constr_from_ptr(ret);
59 this.ptrs_to.add(channel_manager);