svn path=/branches/mono-1-1-9/mcs/; revision=51212
[mono.git] / mcs / class / System / System.CodeDom / CodeTypeReference.cs
index 2f66b0933330ba51f28dcfc27fd91f58c0c534ec..f76e0c1751d3a756f36c1ade78192d6f365781fd 100644 (file)
@@ -3,10 +3,32 @@
 //
 // Author:
 //   Daniel Stodden (stodden@in.tum.de)
+//   Marek Safar (marek.safar@seznam.cz)
 //
 // (C) 2001 Ximian, Inc.
 //
 
+//
+// 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.Runtime.InteropServices;
 
 namespace System.CodeDom
@@ -19,45 +41,101 @@ namespace System.CodeDom
        {
                private string baseType;
                private CodeTypeReference arrayType;
-               private int rank;
+               private int rank;\r
+               private bool isInterface;
+
+#if NET_2_0
+               CodeTypeReferenceCollection typeArguments;
+               CodeTypeReferenceOptions codeTypeReferenceOption;
+#endif
 
                //
                // Constructors
                //
                public CodeTypeReference( string baseType )
                {
-                       this.baseType = baseType;
+                       if (baseType == null || baseType.Length == 0) {
+                               this.baseType = typeof (void).FullName;
+                               return;
+                       }
+
+                       int array_start = baseType.LastIndexOf ('[');
+                       if (array_start == -1) {
+                               this.baseType = baseType;
+                               return;
+                       }
+                       string[] args = baseType.Split (',');
+
+#if NET_2_0
+                       int array_end = baseType.LastIndexOf (']');
+
+                       if ((array_end - array_start) != args.Length) {
+                               arrayType = new CodeTypeReference (baseType.Substring (0, array_start));
+                               array_start++;
+                               TypeArguments.Add (new CodeTypeReference (baseType.Substring (array_start, array_end - array_start)));
+                       } else
+#endif
+                               arrayType = new CodeTypeReference (baseType.Substring (0, array_start), args.Length);
                }
                
                public CodeTypeReference( Type baseType )
                {
-                       this.baseType = baseType.FullName;
+#if NET_2_0
+                       if (baseType == null) {
+                               throw new ArgumentNullException ("baseType");
+                       }
+#endif\r
+                       if (baseType.IsArray) {\r
+                               this.rank = baseType.GetArrayRank ();\r
+                               this.arrayType = new CodeTypeReference (baseType.GetElementType ());\r
+                               this.baseType = arrayType.BaseType;\r
+                       } else {\r
+                               this.baseType = baseType.FullName;\r
+                       }\r
+                       this.isInterface = baseType.IsInterface;
                }
 
-               // FIXME: probably broken
-               [MonoTODO]
                public CodeTypeReference( CodeTypeReference arrayType, int rank )
                {
-                       this.arrayType = arrayType;
-                       this.baseType = arrayType.BaseType;
+                       this.baseType = null;
                        this.rank = rank;
+                       this.arrayType = arrayType;
                }
 
-               // FIXME: probably broken
-               [MonoTODO]
                public CodeTypeReference( string baseType, int rank )
+                       : this (new CodeTypeReference (baseType), rank)
                {
-                       this.baseType = baseType;
-                       this.rank = rank;
                }
                        
+#if NET_2_0
+               public CodeTypeReference( CodeTypeParameter typeParameter ) :
+                       this (typeParameter.Name)
+               {
+               }
+
+               public CodeTypeReference( string typeName, CodeTypeReferenceOptions codeTypeReferenceOption ) :
+                       this (typeName)
+               {
+                       this.codeTypeReferenceOption = codeTypeReferenceOption;
+               }
+
+               public CodeTypeReference( Type type, CodeTypeReferenceOptions codeTypeReferenceOption ) :
+                       this (type)
+               {
+                       this.codeTypeReferenceOption = codeTypeReferenceOption;
+               }
+
+               public CodeTypeReference( string typeName, params CodeTypeReference[] typeArguments ) :
+                       this (typeName)
+               {
+                       TypeArguments.AddRange (typeArguments);
+               }
+#endif
 
                //
                // Properties
                //
 
-               // FIXME: probably broken
-               [MonoTODO]
                public CodeTypeReference ArrayElementType
                {
                        get {
@@ -68,8 +146,6 @@ namespace System.CodeDom
                        }
                }
                
-               // FIXME: probably broken
-               [MonoTODO]
                public int ArrayRank {
                        get {
                                return rank;
@@ -81,11 +157,39 @@ namespace System.CodeDom
 
                public string BaseType {
                        get {
+                               if (baseType == null)
+                                       return String.Empty;
+
                                return baseType;
                        }
                        set {
                                baseType = value;
                        }
+               }\r
+\r
+               internal bool IsInterface {\r
+                       get { return isInterface; }\r
+               }
+
+#if NET_2_0
+               [ComVisible (false)]
+               public CodeTypeReferenceOptions Options {
+                       get {
+                               return codeTypeReferenceOption;
+                       }
+                       set {
+                               codeTypeReferenceOption = value;
+                       }
+               }
+
+               [ComVisible (false)]
+               public CodeTypeReferenceCollection TypeArguments {
+                       get {
+                               if (typeArguments == null)
+                                       typeArguments = new CodeTypeReferenceCollection ();
+                               return typeArguments;
+                       }
                }
+#endif
        }
 }