**** Merged from MCS ****
[mono-project.git] / mcs / class / Microsoft.VisualBasic / Microsoft.VisualBasic / Microsoft.VisualBasic.CompilerServices / CharArrayType.cs
blobf90f32fb5069dd2d57225314c6ff3aa4f45494bd
1 //
2 // CharArrayType.cs
3 //
4 // Author:
5 // Chris J Breisch (cjbreisch@altavista.net)
6 // Dennis Hayes (dennish@raytek.com)
7 //
8 // (C) 2002 Chris J Breisch
9 //
11 * Copyright (c) 2002-2003 Mainsoft Corporation.
12 * Copyright (C) 2004 Novell, Inc (http://www.novell.com)
14 * Permission is hereby granted, free of charge, to any person obtaining a
15 * copy of this software and associated documentation files (the "Software"),
16 * to deal in the Software without restriction, including without limitation
17 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
18 * and/or sell copies of the Software, and to permit persons to whom the
19 * Software is furnished to do so, subject to the following conditions:
21 * The above copyright notice and this permission notice shall be included in
22 * all copies or substantial portions of the Software.
24 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
25 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
26 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
27 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
28 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
29 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
30 * DEALINGS IN THE SOFTWARE.
32 using System;
33 using System.ComponentModel;
35 namespace Microsoft.VisualBasic.CompilerServices
37 [StandardModule, EditorBrowsable(EditorBrowsableState.Never)]
38 sealed public class CharArrayType {
39 private CharArrayType () {}
41 /**
42 * The method converts given object to char[] by the following logic:
43 * 1. If input object is null - return empty char array
44 * 2. If input object is char array - return this object
45 * 3. If input object is String - return char array representing this String
46 * @param value - The object that going to be converted
47 * @return char[] The char array that converted from the source object
48 * @exception InvalidCastException - in case if value is not String or char[].
50 public static char[] FromObject(object Value) {
51 if (Value == null)
52 return new char[]{};
54 if (Value is char[])
55 return (char[])Value;
57 if (Value is string)
58 return FromString((string)Value);// could be replaced with Value.ToCharArray();, but spec says make the call.
60 throw new InvalidCastException("InvalidCast_From " + Value.GetType().Name + " To char");
63 /**
64 * The method converts given string to byte of chars:
65 * @param str - The string that converted to char array
66 * @return char[] The value that extracted from the input string.
68 public static char[] FromString(string Value) {
69 if (Value == null)return new char[]{};
70 return Value.ToCharArray();