2008-12-08 Ivan N. Zlatev <contact@i-nz.net>
[mono.git] / mcs / class / corlib / System.Runtime.InteropServices / HandleRef.cs
1 //
2 // System.Runtime.InteropServices.HandleRef
3 //
4 // Author:
5 //   Tim Coleman (tim@timcoleman.com)
6 //
7 // Copyright (C) 2003 Tim Coleman
8
9 //
10 // Copyright (C) 2004 Novell, Inc (http://www.novell.com)
11 //
12 // Permission is hereby granted, free of charge, to any person obtaining
13 // a copy of this software and associated documentation files (the
14 // "Software"), to deal in the Software without restriction, including
15 // without limitation the rights to use, copy, modify, merge, publish,
16 // distribute, sublicense, and/or sell copies of the Software, and to
17 // permit persons to whom the Software is furnished to do so, subject to
18 // the following conditions:
19 // 
20 // The above copyright notice and this permission notice shall be
21 // included in all copies or substantial portions of the Software.
22 // 
23 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
24 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
25 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
26 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
27 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
28 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
29 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
30 //
31
32 using System;
33
34 namespace System.Runtime.InteropServices {
35 #if NET_2_0
36         [ComVisible (true)]
37 #endif
38         public struct HandleRef {
39
40                 #region Fields
41
42                 object wrapper;
43                 IntPtr handle;
44
45                 #endregion // Fields
46
47                 #region Constructors
48
49                 public HandleRef (object wrapper, IntPtr handle)
50                 {
51                         this.wrapper = wrapper;
52                         this.handle = handle;
53                 }
54
55                 #endregion // Constructors
56
57                 #region Properties
58
59                 public IntPtr Handle {
60                         get { return handle; }
61                 }
62
63                 public object Wrapper {
64                         get { return wrapper; }
65                 }
66
67                 #endregion // Properties
68
69                 #region Type Conversions
70
71                 public static explicit operator IntPtr (HandleRef value)
72                 {
73                         return value.Handle;
74                 }
75                 
76                 #endregion // Type Conversions
77 #if NET_2_0
78                 public static IntPtr ToIntPtr(HandleRef value)
79                 {
80                         return value.Handle; 
81                         // Why did MS add a function for this?
82                 }
83 #endif
84         }
85 }