Attempt 1
[mono.git] / mcs / class / corlib / System.Threading / Mutex.cs
index 423b59d926a7acaa423c1561a07e08cd822f7291..cd14807281cae5ae85dd5766e9150215e560bd6d 100644 (file)
 using System.Runtime.CompilerServices;
 using System.Security.Permissions;
 
-#if NET_2_0
 using System.Runtime.ConstrainedExecution;
-using System.Security.AccessControl;
 using System.IO;
+using System.Runtime.InteropServices;
+#if !NET_2_1
+using System.Security.AccessControl;
 #endif
 
 namespace System.Threading
 {
+       [ComVisible (true)]
        public sealed class Mutex : WaitHandle 
        {
                [MethodImplAttribute(MethodImplOptions.InternalCall)]
@@ -48,9 +50,9 @@ namespace System.Threading
                                                         out bool created);
 
                [MethodImplAttribute(MethodImplOptions.InternalCall)]
-               private static extern void ReleaseMutex_internal(IntPtr handle);
+               private static extern bool ReleaseMutex_internal(IntPtr handle);
 
-#if NET_2_0
+#if !NET_2_1
                [MethodImplAttribute (MethodImplOptions.InternalCall)]
                private static extern IntPtr OpenMutex_internal (string name, MutexRights rights, out MonoIOError error);
                
@@ -60,18 +62,14 @@ namespace System.Threading
                }
 #endif
                
-#if NET_2_0
                [ReliabilityContractAttribute (Consistency.WillNotCorruptState, Cer.MayFail)]
-#endif
                public Mutex() {
                        bool created;
                        
                        Handle=CreateMutex_internal(false, null, out created);
                }
                
-#if NET_2_0
                [ReliabilityContractAttribute (Consistency.WillNotCorruptState, Cer.MayFail)]
-#endif
                public Mutex(bool initiallyOwned) {
                        bool created;
                        
@@ -79,9 +77,7 @@ namespace System.Threading
                                                    out created);
                }
 
-#if NET_2_0
                [ReliabilityContractAttribute (Consistency.WillNotCorruptState, Cer.MayFail)]
-#endif
                [SecurityPermission (SecurityAction.LinkDemand, UnmanagedCode = true)]
                public Mutex (bool initiallyOwned, string name)
                {
@@ -89,16 +85,14 @@ namespace System.Threading
                        Handle = CreateMutex_internal (initiallyOwned, name, out created);
                }
 
-#if NET_2_0
                [ReliabilityContractAttribute (Consistency.WillNotCorruptState, Cer.MayFail)]
-#endif
                [SecurityPermission (SecurityAction.LinkDemand, UnmanagedCode = true)]
                public Mutex (bool initiallyOwned, string name, out bool createdNew)
                {
                        Handle = CreateMutex_internal (initiallyOwned, name, out createdNew);
                }
 
-#if NET_2_0
+#if !NET_2_1
                [MonoTODO ("Implement MutexSecurity")]
                [ReliabilityContractAttribute (Consistency.WillNotCorruptState, Cer.MayFail)]
                public Mutex (bool initiallyOwned, string name, out bool createdNew, MutexSecurity mutexSecurity)
@@ -106,6 +100,11 @@ namespace System.Threading
                        Handle = CreateMutex_internal (initiallyOwned, name, out createdNew);
                }
 
+               public MutexSecurity GetAccessControl ()
+               {
+                       throw new NotImplementedException ();
+               }
+
                public static Mutex OpenExisting (string name)
                {
                        return(OpenExisting (name, MutexRights.Synchronize |
@@ -140,11 +139,19 @@ namespace System.Threading
                }
 #endif
 
-#if NET_2_0
                [ReliabilityContractAttribute (Consistency.WillNotCorruptState, Cer.MayFail)]
-#endif 
                public void ReleaseMutex() {
-                       ReleaseMutex_internal(Handle);
+                       bool success = ReleaseMutex_internal(Handle);
+                       if (!success) {
+                               throw new ApplicationException ("Mutex is not owned");
+                       }
                }
+
+#if !NET_2_1
+               public void SetAccessControl (MutexSecurity mutexSecurity)
+               {
+                       throw new NotImplementedException ();
+               }
+#endif
        }
 }