Merge branch 'master' of github.com:mono/mono
[mono.git] / mcs / class / corlib / System.Threading / AutoResetEvent.cs
old mode 100755 (executable)
new mode 100644 (file)
index 3b5d71e..589693d
@@ -8,28 +8,64 @@
 // (C) Ximian, Inc.  http://www.ximian.com
 //
 
+//
+// Copyright (C) 2004, 2005 Novell, Inc (http://www.novell.com)
+//
+// Permission is hereby granted, free of charge, to any person obtaining
+// a copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to
+// permit persons to whom the Software is furnished to do so, subject to
+// the following conditions:
+// 
+// The above copyright notice and this permission notice shall be
+// included in all copies or substantial portions of the Software.
+// 
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+//
+
 using System;
 using System.Runtime.CompilerServices;
 
+using System.Runtime.InteropServices;
+
 namespace System.Threading 
 {
 
-       public sealed class AutoResetEvent : WaitHandle 
+       [ComVisible (true)]
+       public sealed class AutoResetEvent : EventWaitHandle
        {
                // Constructor
-               public AutoResetEvent(bool initialState) {
-                       os_handle = NativeEventCalls.CreateEvent_internal(false,initialState,null);
+               public AutoResetEvent (bool initialState)
+                       : base(initialState, EventResetMode.AutoReset)
+               {
                }
 
                // Methods
 
+/* Need BOOTSTRAP_NET_2_0 because System.Threading.Timer wants to use
+ * the Set and Reset methods that have moved to EventWaitHandle in the
+ * 2.0 profile
+ */
+#if BOOTSTRAP_NET_2_0
                public bool Set() {
-                       return(NativeEventCalls.SetEvent_internal(os_handle));
+                       CheckDisposed ();
+                       
+                       return(NativeEventCalls.SetEvent_internal(Handle));
                }
 
                public bool Reset() {
-                       return(NativeEventCalls.ResetEvent_internal(os_handle));
+                       CheckDisposed ();
+                       
+                       return(NativeEventCalls.ResetEvent_internal(Handle));
                }
-
+#endif
        }
 }