summaryrefslogtreecommitdiffstats
path: root/bindings/csharp/SafeObject.cs
diff options
context:
space:
mode:
authorMamadou DIOP <bossiel@yahoo.fr>2015-08-17 01:56:35 +0200
committerMamadou DIOP <bossiel@yahoo.fr>2015-08-17 01:56:35 +0200
commit631fffee8a28b1bec5ed1f1d26a20e0135967f99 (patch)
tree74afe3bf3efe15aa82bcd0272b2b0f4d48c2d837 /bindings/csharp/SafeObject.cs
parent7908865936604036e6f200f1b5e069f8752f3a3a (diff)
downloaddoubango-631fffee8a28b1bec5ed1f1d26a20e0135967f99.zip
doubango-631fffee8a28b1bec5ed1f1d26a20e0135967f99.tar.gz
-
Diffstat (limited to 'bindings/csharp/SafeObject.cs')
-rw-r--r--bindings/csharp/SafeObject.cs59
1 files changed, 59 insertions, 0 deletions
diff --git a/bindings/csharp/SafeObject.cs b/bindings/csharp/SafeObject.cs
new file mode 100644
index 0000000..ead0333
--- /dev/null
+++ b/bindings/csharp/SafeObject.cs
@@ -0,0 +1,59 @@
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 2.0.9
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace org.doubango.tinyWRAP {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SafeObject : IDisposable {
+ private HandleRef swigCPtr;
+ protected bool swigCMemOwn;
+
+ internal SafeObject(IntPtr cPtr, bool cMemoryOwn) {
+ swigCMemOwn = cMemoryOwn;
+ swigCPtr = new HandleRef(this, cPtr);
+ }
+
+ internal static HandleRef getCPtr(SafeObject obj) {
+ return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+ }
+
+ ~SafeObject() {
+ Dispose();
+ }
+
+ public virtual void Dispose() {
+ lock(this) {
+ if (swigCPtr.Handle != IntPtr.Zero) {
+ if (swigCMemOwn) {
+ swigCMemOwn = false;
+ tinyWRAPPINVOKE.delete_SafeObject(swigCPtr);
+ }
+ swigCPtr = new HandleRef(null, IntPtr.Zero);
+ }
+ GC.SuppressFinalize(this);
+ }
+ }
+
+ public SafeObject() : this(tinyWRAPPINVOKE.new_SafeObject(), true) {
+ }
+
+ public int Lock() {
+ int ret = tinyWRAPPINVOKE.SafeObject_Lock(swigCPtr);
+ return ret;
+ }
+
+ public int UnLock() {
+ int ret = tinyWRAPPINVOKE.SafeObject_UnLock(swigCPtr);
+ return ret;
+ }
+
+}
+
+}
OpenPOWER on IntegriCloud