- public static interface WatchInterface {
- Result_NoneChannelMonitorUpdateErrZ watch_channel(OutPoint funding_txo, ChannelMonitor monitor);
- Result_NoneChannelMonitorUpdateErrZ update_channel(OutPoint funding_txo, ChannelMonitorUpdate update);
- MonitorEvent[] release_pending_monitor_events();
- }
- private static class LDKWatchHolder { Watch held; }
- public static Watch new_impl(WatchInterface arg) {
- final LDKWatchHolder impl_holder = new LDKWatchHolder();
- impl_holder.held = new Watch(new bindings.LDKWatch() {
- @Override public uint32_t watch_channel(uint32_t funding_txo, uint32_t monitor) {
- OutPoint funding_txo_hu_conv = new OutPoint(null, funding_txo);
- ChannelMonitor monitor_hu_conv = new ChannelMonitor(null, monitor);
- Result_NoneChannelMonitorUpdateErrZ ret = arg.watch_channel(funding_txo_hu_conv, monitor_hu_conv);
- uint32_t result = ret != null ? ret.ptr : 0;
- ret.ptr = 0;
+
+ export class Watch extends CommonBase {
+
+ bindings_instance?: bindings.LDKWatch;
+
+ constructor(ptr?: number, arg?: bindings.LDKWatch) {
+ if (Number.isFinite(ptr)) {
+ super(ptr);
+ this.bindings_instance = null;
+ } else {
+ // TODO: private constructor instantiation
+ super(bindings.LDKWatch_new(arg));
+ this.ptrs_to.push(arg);
+
+ }
+ }
+
+ protected finalize() {
+ if (this.ptr != 0) {
+ bindings.Watch_free(this.ptr);
+ }
+ super.finalize();
+ }
+
+ static new_impl(arg: WatchInterface): Watch {
+ const impl_holder: LDKWatchHolder = new LDKWatchHolder();
+ let structImplementation = <bindings.LDKWatch>{
+ // todo: in-line interface filling
+ watch_channel (funding_txo: number, monitor: number): number {
+ const funding_txo_hu_conv: OutPoint = new OutPoint(null, funding_txo);
+ const monitor_hu_conv: ChannelMonitor = new ChannelMonitor(null, monitor);
+ Result_NoneChannelMonitorUpdateErrZ ret = arg.watch_channel(funding_txo_hu_conv, monitor_hu_conv);
+ result: number = ret != null ? ret.ptr : 0;