2002-06-27 Martin Baulig <martin@gnome.org>
[mono.git] / mcs / class / corlib / System / Char.cs
index 826cecf4a163b6591524388d9cd58a2716011d71..58e5dc33ab6b007959447b33e2e86857f7ff2914 100644 (file)
 // doesn't list this class as implementing IFormattable.
 
 using System.Globalization;
+using System.Runtime.CompilerServices;
 
 namespace System {
        
-       public struct Char : IComparable { //, IFormattable, IConvertible {
+       [Serializable]
+       public struct Char : IComparable, IConvertible { //, IFormattable {
                public const char MaxValue = (char) 0xffff;
                public const char MinValue = (char) 0;
                
@@ -57,12 +59,8 @@ namespace System {
                        return value;
                }
 
-               public static double GetNumericValue (char c)
-               {
-                       if ((c >= 48) && (c <= 57))
-                               return (double) (c - '0');
-                       return -1;
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern double GetNumericValue (char c);
 
                public static double GetNumericValue (string str, int index)
                {
@@ -77,27 +75,22 @@ namespace System {
                        return GetNumericValue (str[index]);
                }
 
-               public static UnicodeCategory GetUnicodeCategory (char c) 
-               { 
-                       // TODO: Implement me
-                       return UnicodeCategory.OtherSymbol;
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern UnicodeCategory GetUnicodeCategory (char c); 
 
                public static UnicodeCategory GetUnicodeCategory (string str, int index) {
                        if (str == null) 
                                throw new ArgumentNullException (Locale.GetText ("str is a null reference"));
                        
                        if (index < 0 || index >= str.Length)
-                               throw new ArgumentOutOfRangeException (Locale.GetText ("The value of index is less than zero, or greater than or equal to the length of str"));
+                               throw new ArgumentOutOfRangeException (Locale.GetText ("The value of index is less "+
+                                                         "than zero, or greater than or equal to the length of str"));
                        
                        return GetUnicodeCategory (str[index]);
                }
 
-               public static bool IsControl (char c)
-               {
-                       // TODO: Make me Unicode aware
-                       return ((c > 1) && (c < 32));
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern bool IsControl (char c);
 
                public static bool IsControl (string str, int index)
                {
@@ -111,10 +104,8 @@ namespace System {
                        return IsControl (str[index]);
                }
                
-               public static bool IsDigit (char c)
-               {
-                       return ((c >= '0') && (c <= '9'));
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern bool IsDigit (char c);
 
                public static bool IsDigit (string str, int index)
                {
@@ -123,16 +114,13 @@ namespace System {
                        
                        if (index < 0 || index >= str.Length)
                                throw new ArgumentOutOfRangeException (Locale.GetText (
-                                       "The value of index is less than zero, or greater than or equal to the length of str"));
+                                "The value of index is less than zero, or greater than or equal to the length of str"));
                        
                        return IsDigit (str[index]);
                }
 
-               public static bool IsLetter (char c)
-               {
-                       // TODO: Make me Unicode aware
-                       return (((c >= 'A') && (c <= 'Z')) || ((c >= 'a') && (c <= 'z')));
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern bool IsLetter (char c);
 
                public static bool IsLetter (string str, int index)
                {
@@ -141,7 +129,7 @@ namespace System {
                        
                        if (index < 0 || index >= str.Length)
                                throw new ArgumentOutOfRangeException (Locale.GetText (
-                                       "The value of index is less than zero, or greater than or equal to the length of str"));
+                                "The value of index is less than zero, or greater than or equal to the length of str"));
                        
                        return IsLetter (str[index]);
                }
@@ -161,16 +149,13 @@ namespace System {
                        
                        if (index < 0 || index >= str.Length)
                                throw new ArgumentOutOfRangeException (Locale.GetText (
-                                       "The value of index is less than zero, or greater than or equal to the length of str"));
+                                "The value of index is less than zero, or greater than or equal to the length of str"));
                        
                        return IsLetterOrDigit (str[index]);
                }
-               
-               public static bool IsLower (char c)
-               {
-                       // TODO: Make me Unicode aware.
-                       return ((c >= 97) && (c <= 126));
-               }
+
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern bool IsLower (char c);
                
                public static bool IsLower (string str, int index)
                {
@@ -179,15 +164,13 @@ namespace System {
                        
                        if (index < 0 || index >= str.Length)
                                throw new ArgumentOutOfRangeException (Locale.GetText (
-                                       "The value of index is less than zero, or greater than or equal to the length of str"));
+                                "The value of index is less than zero, or greater than or equal to the length of str"));
                        
                        return IsLower (str[index]);
                }
 
-               public static bool IsNumber (char c)
-               {
-                       return ((c >= 48) && (c <= 57));
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern bool IsNumber (char c);
                
                public static bool IsNumber (string str, int index)
                {
@@ -196,20 +179,13 @@ namespace System {
                        
                        if (index < 0 || index >= str.Length)
                                throw new ArgumentOutOfRangeException (Locale.GetText (
-                                       "The value of index is less than zero, or greater than or equal to the length of str"));
+                               "The value of index is less than zero, or greater than or equal to the length of str"));
                        
                        return IsNumber (str[index]);
                }
 
-               public static bool IsPunctuation (char c)
-               {
-                       if (c == ',' || c == '.' || c == ';' || c == ':' ||
-                           c == '\'' || c == '\"' || c == '(' || c == ')' ||
-                           c == ')')
-                               return true;
-                       else
-                               return false;
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern bool IsPunctuation (char c);
                
                public static bool IsPunctuation (string str, int index)
                {
@@ -218,16 +194,13 @@ namespace System {
                        
                        if (index < 0 || index >= str.Length)
                                throw new ArgumentOutOfRangeException (Locale.GetText (
-                                       "The value of index is less than zero, or greater than or equal to the length of str"));
+                                "The value of index is less than zero, or greater than or equal to the length of str"));
                        
                        return IsPunctuation (str[index]);
                }
 
-               public static bool IsSeparator (char c)
-               {
-                       // TODO: Implement me
-                       return false;
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern bool IsSeparator (char c);
                
                public static bool IsSeparator (string str, int index)
                {
@@ -236,16 +209,13 @@ namespace System {
                        
                        if (index < 0 || index >= str.Length)
                                throw new ArgumentOutOfRangeException (Locale.GetText (
-                                       "The value of index is less than zero, or greater than or equal to the length of str"));
+                                "The value of index is less than zero, or greater than or equal to the length of str"));
                        
                        return IsSeparator (str[index]);
                }
 
-               public static bool IsSurrogate (char c)
-               {
-                       // TODO: Implement me
-                       return false;
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern bool IsSurrogate (char c);
                
                public static bool IsSurrogate (string str, int index)
                {
@@ -254,16 +224,13 @@ namespace System {
                        
                        if (index < 0 || index >= str.Length)
                                throw new ArgumentOutOfRangeException (Locale.GetText (
-                                       "The value of index is less than zero, or greater than or equal to the length of str"));
+                                "The value of index is less than zero, or greater than or equal to the length of str"));
                        
                        return IsSurrogate (str[index]);
                }
 
-               public static bool IsSymbol (char c)
-               {
-                       // TODO: Implement me
-                       return false;
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern bool IsSymbol (char c);
                
                public static bool IsSymbol (string str, int index)
                {
@@ -277,11 +244,8 @@ namespace System {
                        return IsSymbol (str[index]);
                }
 
-               public static bool IsUpper (char c)
-               {
-                       // TODO : Make me Unicode aware
-                       return ((c >= 65) && (c <= 90));
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern bool IsUpper (char c);
                
                public static bool IsUpper (string str, int index)
                {
@@ -290,18 +254,13 @@ namespace System {
                        
                        if (index < 0 || index >= str.Length)
                                throw new ArgumentOutOfRangeException (Locale.GetText (
-                                       "The value of index is less than zero, or greater than or equal to the length of str"));
+                                "The value of index is less than zero, or greater than or equal to the length of str"));
                        
                        return IsUpper (str[index]);
                }
 
-               public static bool IsWhiteSpace (char c)
-               {
-                       if (c == ' ' || c == '\n' || c == '\t' || c == '\r')
-                               return true;
-                       else
-                               return false;
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern bool IsWhiteSpace (char c);
                
                public static bool IsWhiteSpace (string str, int index)
                {
@@ -317,33 +276,32 @@ namespace System {
 
                public static char Parse (string str)
                {
-                       // TODO: Implement me
-                       return (char) 0;
-               }
+                       if (str == null)
+                               throw new ArgumentNullException (Locale.GetText ("str is a null reference"));
 
-               public static char ToLower (char c)
-               {
-                       // TODO: make me unicode aware
-                       return (c >= 'A' && c <= 'Z') ? (char) (c + 32) : c;
+                       if (str.Length != 1)
+                               throw new FormatException ("string contains more than one character.");
+                       
+                       return str [0];
                }
 
-               public static char ToUpper (char c)
-               {
-                       // TODO: make me unicode aware
-                       return (char) ((c >= 'a' && c <= 'z') ? c - 32 : c);
-               }
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern char ToLower (char c);
+
+               [MethodImplAttribute(System.Runtime.CompilerServices.MethodImplOptions.InternalCall)]
+               public static extern char ToUpper (char c);
 
                public override string ToString ()
                {
                        // LAMESPEC: ECMA draft lists this as returning ToString (null), 
                        // However it doesn't list another ToString() method.
-                       return ToString (null);
+                       return new String (value, 1);
                }
 
                public string ToString (IFormatProvider fp)
                {
                        // LAMESPEC: ECMA draft doesn't say Char implements IFormattable
-                       return "";
+                       return new String (value, 1);
                }
 
                // =========== IConvertible Methods =========== //
@@ -352,5 +310,90 @@ namespace System {
                {
                        return TypeCode.Char;
                }         
+
+               object IConvertible.ToType (Type conversionType, IFormatProvider provider)
+               {
+                       return System.Convert.ToType(value, conversionType, provider);
+               }
+               
+               bool IConvertible.ToBoolean (IFormatProvider provider)
+               {
+                       throw new InvalidCastException();
+               }
+               
+               byte IConvertible.ToByte (IFormatProvider provider)
+               {
+                       return System.Convert.ToByte(value);
+               }
+               
+               char IConvertible.ToChar (IFormatProvider provider)
+               {
+                       return value;
+               }
+               
+               [CLSCompliant(false)]
+               DateTime IConvertible.ToDateTime (IFormatProvider provider)
+               {
+                       throw new InvalidCastException();
+               }
+               
+               decimal IConvertible.ToDecimal (IFormatProvider provider)
+               {
+                       throw new InvalidCastException();
+               }
+               
+               double IConvertible.ToDouble (IFormatProvider provider)
+               {
+                       throw new InvalidCastException();
+               }
+               
+               short IConvertible.ToInt16 (IFormatProvider provider)
+               {
+                       return System.Convert.ToInt16(value);
+               }
+               
+               int IConvertible.ToInt32 (IFormatProvider provider)
+               {
+                       return System.Convert.ToInt32(value);
+               }
+               
+               long IConvertible.ToInt64 (IFormatProvider provider)
+               {
+                       return System.Convert.ToInt64(value);
+               }
+               
+               [CLSCompliant(false)] 
+               sbyte IConvertible.ToSByte (IFormatProvider provider)
+               {
+                       return System.Convert.ToSByte(value);
+               }
+               
+               float IConvertible.ToSingle (IFormatProvider provider)
+               {
+                       throw new InvalidCastException();
+               }
+               
+               string IConvertible.ToString (IFormatProvider provider)
+               {
+                       return ToString(provider);
+               }
+
+               [CLSCompliant(false)]
+               ushort IConvertible.ToUInt16 (IFormatProvider provider)
+               {
+                       return System.Convert.ToUInt16(value);
+               }
+               
+               [CLSCompliant(false)]
+               uint IConvertible.ToUInt32 (IFormatProvider provider)
+               {
+                       return System.Convert.ToUInt32(value);
+               }
+               
+               [CLSCompliant(false)]
+               ulong IConvertible.ToUInt64 (IFormatProvider provider)
+               {
+                       return System.Convert.ToUInt64(value);
+               }
        }
 }