X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=c_sharp%2Fsrc%2Forg%2Fldk%2Fstructs%2FLogger.cs;h=309fa883f852fc295062db6397491dba5f24a4c8;hb=8de7213fbf663ff60322896282dad51e8ab2f001;hp=8c1dd74176d6f4504124496d8e088e680dc5912f;hpb=afc50e5d491a11364849383b75a8f939df703bac;p=ldk-java diff --git a/c_sharp/src/org/ldk/structs/Logger.cs b/c_sharp/src/org/ldk/structs/Logger.cs index 8c1dd741..309fa883 100644 --- a/c_sharp/src/org/ldk/structs/Logger.cs +++ b/c_sharp/src/org/ldk/structs/Logger.cs @@ -1,3 +1,4 @@ + using org.ldk.impl; using org.ldk.enums; using org.ldk.util; @@ -5,26 +6,27 @@ using System; namespace org { namespace ldk { namespace structs { + + +/** An implementation of Logger */ +public interface LoggerInterface { + /**Logs the `Record` + */ + void log(Record record); +} + /** * A trait encapsulating the operations required of a logger */ public class Logger : CommonBase { - internal readonly bindings.LDKLogger bindings_instance; + internal bindings.LDKLogger bindings_instance; + internal long instance_idx; + internal Logger(object _dummy, long ptr) : base(ptr) { bindings_instance = null; } - private Logger(bindings.LDKLogger arg) : base(bindings.LDKLogger_new(arg)) { - this.ptrs_to.AddLast(arg); - this.bindings_instance = arg; - } ~Logger() { if (ptr != 0) { bindings.Logger_free(ptr); } } - public interface LoggerInterface { - /** - * Logs the `Record` - */ - void log(Record _record); - } private class LDKLoggerHolder { internal Logger held; } private class LDKLoggerImpl : bindings.LDKLogger { internal LDKLoggerImpl(LoggerInterface arg, LDKLoggerHolder impl_holder) { this.arg = arg; this.impl_holder = impl_holder; } @@ -36,10 +38,18 @@ public class Logger : CommonBase { GC.KeepAlive(arg); } } + + /** Creates a new instance of Logger from a given implementation */ public static Logger new_impl(LoggerInterface arg) { LDKLoggerHolder impl_holder = new LDKLoggerHolder(); - impl_holder.held = new Logger(new LDKLoggerImpl(arg, impl_holder)); + LDKLoggerImpl impl = new LDKLoggerImpl(arg, impl_holder); + long[] ptr_idx = bindings.LDKLogger_new(impl); + + impl_holder.held = new Logger(null, ptr_idx[0]); + impl_holder.held.instance_idx = ptr_idx[1]; + impl_holder.held.bindings_instance = impl; return impl_holder.held; } + } } } }