5 // Patrik Torstensson (patrik.torstensson@labs2.com)
6 // Jeffrey Stedfast (fejj@ximian.com)
7 // Dan Lewis (dihlewis@yahoo.co.uk)
9 // (C) 2001 Ximian, Inc. http://www.ximian.com
14 using System.Collections;
15 using System.Globalization;
16 using System.Runtime.CompilerServices;
20 public sealed class String : IConvertible, IComparable, ICloneable, IEnumerable {
24 private const int COMPARE_CASE = 0;
25 private const int COMPARE_INCASE = 1;
26 private const int COMPARE_ORDINAL = 2;
28 public static readonly String Empty = "";
30 public static bool Equals(String str1, String str2) {
31 if ((str1 as object) == (str2 as object))
34 if (null == str1 || null == str2)
37 int len = str1.length;
39 if (len != str2.length)
42 for (int i = 0; i < len; i++)
43 if (str1 [i] != str2 [i])
49 public static bool operator == (String str1, String str2) {
50 return Equals(str1, str2);
53 public static bool operator != (String str1, String str2) {
54 return !Equals(str1, str2);
57 public override bool Equals(Object obj) {
58 return Equals (this, obj as String);
61 public bool Equals(String value) {
62 return Equals (this, value);
65 [IndexerName("Chars")]
66 public extern char this[int index] {
67 [MethodImplAttribute(MethodImplOptions.InternalCall)]
71 public Object Clone() {
75 public TypeCode GetTypeCode () {
76 return TypeCode.String;
79 public void CopyTo(int sindex, char[] dest, int dindex, int count) {
80 // LAMESPEC: should I null-terminate?
83 throw new ArgumentNullException();
85 if (sindex < 0 || dindex < 0 || count < 0)
86 throw new ArgumentOutOfRangeException ();
88 if (sindex + count > Length)
89 throw new ArgumentOutOfRangeException ();
91 if (dindex + count > dest.Length)
92 throw new ArgumentOutOfRangeException ();
94 InternalCopyTo(sindex, dest, dindex, count);
97 public char[] ToCharArray() {
98 return ToCharArray(0, length);
101 public char[] ToCharArray(int sindex, int length) {
102 if (sindex < 0 || length < 0 || sindex + length > this.length)
103 throw new ArgumentOutOfRangeException ();
105 char [] tmp = new char[length];
107 InternalCopyTo(sindex, tmp, 0, length);
112 public String [] Split(params char [] separator) {
113 return Split(separator, Int32.MaxValue);
116 public String[] Split(char[] separator, int count) {
117 if (null == separator || separator.Length == 0) {
118 separator = WhiteChars;
122 throw new ArgumentOutOfRangeException ();
125 return new String[0];
128 return new String[1] { ToString() };
130 return InternalSplit(separator, count);
133 public String Substring (int sindex) {
134 if (sindex < 0 || sindex > this.length) {
135 throw new ArgumentOutOfRangeException();
138 string tmp = InternalAllocateStr(this.length - sindex);
139 InternalStrcpy(tmp, 0, this, sindex, length - sindex);
144 public String Substring (int sindex, int length) {
145 if (length < 0 || sindex < 0 || sindex + length > this.length) {
146 throw new ArgumentOutOfRangeException();
152 string tmp = InternalAllocateStr(length);
153 InternalStrcpy(tmp, 0, this, sindex, length);
158 private static readonly char[] WhiteChars = { (char) 0x9, (char) 0xA, (char) 0xB, (char) 0xC, (char) 0xD, (char) 0x20, (char) 0xA0, (char) 0x2000, (char) 0x2001, (char) 0x2002, (char) 0x2003, (char) 0x2004, (char) 0x2005,
159 (char) 0x2006, (char) 0x2007, (char) 0x2008, (char) 0x2009, (char) 0x200A, (char) 0x200B, (char) 0x3000, (char) 0xFEFF };
161 public String Trim(params char[] chars) {
162 if (null == chars || chars.Length == 0)
165 return InternalTrim(chars, 0);
168 public String TrimStart(params char[] chars) {
169 if (null == chars || chars.Length == 0)
172 return InternalTrim(chars, 1);
175 public String TrimEnd(params char[] chars) {
176 if (null == chars || chars.Length == 0)
179 return InternalTrim(chars, 2);
182 public static int Compare(String s1, String s2) {
183 return(Compare(s1, s2, false,
184 CultureInfo.CurrentCulture));
187 public static int Compare(String s1, String s2, bool inCase) {
188 return(Compare (s1, s2, inCase,
189 CultureInfo.CurrentCulture));
192 public static int Compare(String s1, String s2, bool inCase,
193 CultureInfo culture) {
194 if (culture == null) {
195 throw new ArgumentNullException ("culture");
204 } else if (s2 == null) {
208 CompareOptions compopts;
211 compopts=CompareOptions.IgnoreCase;
213 compopts=CompareOptions.None;
216 return(culture.CompareInfo.Compare (s1, s2, compopts));
219 public static int Compare(String s1, int i1, String s2, int i2,
221 return(Compare(s1, i1, s2, i2, length, false,
222 CultureInfo.CurrentCulture));
225 public static int Compare(String s1, int i1, String s2, int i2,
226 int length, bool inCase) {
227 return(Compare (s1, i1, s2, i2, length, inCase,
228 CultureInfo.CurrentCulture));
231 public static int Compare(String s1, int i1, String s2, int i2,
232 int length, bool inCase,
233 CultureInfo culture) {
235 throw new ArgumentNullException ("culture");
238 if((i1 > s1.Length) ||
240 (i1 < 0) || (i2 < 0) || (length < 0)) {
241 throw new ArgumentOutOfRangeException ();
250 } else if (s2 == null) {
254 CompareOptions compopts;
257 compopts=CompareOptions.IgnoreCase;
259 compopts=CompareOptions.None;
262 /* Need to cap the requested length to the
263 * length of the string, because
264 * CompareInfo.Compare will insist that length
265 * <= (string.Length - offset)
270 if(length > (s1.Length - i1)) {
274 if(length > (s2.Length - i2)) {
278 return(culture.CompareInfo.Compare(s1, i1, len1,
283 public int CompareTo(Object value) {
287 if (!(value is String))
288 throw new ArgumentException();
290 return String.Compare(this, (String) value, false);
293 public int CompareTo(String str) {
297 return Compare(this, str, false);
300 public static int CompareOrdinal(String s1, String s2) {
307 } else if (s2 == null) {
311 /* Invariant, because that is cheaper to
312 * instantiate (and chances are it already has
315 return(CultureInfo.InvariantCulture.CompareInfo.Compare (s1, s2, CompareOptions.Ordinal));
318 public static int CompareOrdinal(String s1, int i1, String s2,
321 if ((i1 > s1.Length) ||
323 (i1 < 0) || (i2 < 0) || (length < 0)) {
324 throw new ArgumentOutOfRangeException ();
333 } else if (s2 == null) {
337 /* Need to cap the requested length to the
338 * length of the string, because
339 * CompareInfo.Compare will insist that length
340 * <= (string.Length - offset)
345 if(length > (s1.Length - i1)) {
349 if(length > (s2.Length - i2)) {
353 return(CultureInfo.InvariantCulture.CompareInfo.Compare(s1, i1, len1, s2, i2, len2, CompareOptions.Ordinal));
356 public bool EndsWith(String value) {
358 throw new ArgumentNullException();
360 if (value == String.Empty) {
364 if (value.length > this.length) {
368 return (0 == Compare(this, length - value.length, value, 0, value.length));
371 public int IndexOfAny(char [] arr) {
373 throw new ArgumentNullException();
375 return InternalIndexOfAny(arr, 0, this.length);
378 public int IndexOfAny(char [] arr, int sindex) {
380 throw new ArgumentNullException();
381 if (sindex < 0 || sindex >= this.length)
382 throw new ArgumentOutOfRangeException();
384 return InternalIndexOfAny(arr, sindex, this.length - sindex);
387 public int IndexOfAny(char [] arr, int sindex, int count) {
389 throw new ArgumentNullException();
390 if (sindex < 0 || count < 0 || sindex + count > this.length)
391 throw new ArgumentOutOfRangeException ();
393 return InternalIndexOfAny(arr, sindex, count);
396 public int IndexOf(char value) {
397 return(IndexOf(value, 0, this.length));
400 public int IndexOf(String value) {
401 return(IndexOf(value, 0, this.length));
404 public int IndexOf(char value, int sindex) {
405 return(IndexOf(value, sindex, this.length - sindex));
408 public int IndexOf(String value, int sindex) {
409 return(IndexOf(value, sindex, this.length - sindex));
412 /* This method is culture-insensitive */
413 public int IndexOf(char value, int sindex, int count) {
414 if (sindex < 0 || count < 0 ||
415 sindex + count > this.length) {
416 throw new ArgumentOutOfRangeException ();
419 if ((sindex == 0 && this.length == 0) ||
420 (sindex == this.length) ||
425 for(int pos=sindex; pos < sindex + count; pos++) {
426 if(this[pos]==value) {
434 /* But this one is culture-sensitive */
435 public int IndexOf(String value, int sindex, int count) {
437 throw new ArgumentNullException();
440 if (sindex < 0 || count < 0 ||
441 sindex + count > this.length) {
442 throw new ArgumentOutOfRangeException ();
445 if (value.length == 0) {
449 if (sindex == 0 && this.length == 0) {
457 return(CultureInfo.CurrentCulture.CompareInfo.IndexOf (this, value, sindex, count));
460 public int LastIndexOfAny(char [] arr) {
462 throw new ArgumentNullException();
464 return InternalLastIndexOfAny(arr, this.length - 1, this.length);
467 public int LastIndexOfAny(char [] arr, int sindex) {
469 throw new ArgumentNullException();
471 if (sindex < 0 || sindex > this.length)
472 throw new ArgumentOutOfRangeException();
474 if (this.length == 0)
477 return InternalLastIndexOfAny(arr, sindex, sindex + 1);
480 public int LastIndexOfAny(char [] arr, int sindex, int count) {
482 throw new ArgumentNullException();
484 if (sindex < 0 || count < 0 || sindex > this.length || sindex - count < -1)
485 throw new ArgumentOutOfRangeException();
487 if (this.length == 0)
490 return InternalLastIndexOfAny(arr, sindex, count);
493 public int LastIndexOf(char value) {
497 return(LastIndexOf(value, this.length - 1,
503 public int LastIndexOf(String value) {
505 /* This overload does additional checking */
506 return(LastIndexOf(value, 0, 0));
508 return(LastIndexOf(value, this.length - 1,
513 public int LastIndexOf(char value, int sindex){
514 return(LastIndexOf(value, sindex, sindex + 1));
517 public int LastIndexOf(String value, int sindex) {
518 return(LastIndexOf(value, sindex, sindex + 1));
521 /* This method is culture-insensitive */
522 public int LastIndexOf(char value, int sindex, int count) {
523 if (sindex == 0 && this.length == 0) {
527 if (sindex < 0 || count < 0) {
528 throw new ArgumentOutOfRangeException ();
531 if (sindex >= this.length || sindex - count + 1 < 0) {
532 throw new ArgumentOutOfRangeException ();
535 for(int pos=sindex; pos > sindex - count; pos--) {
536 if(this[pos]==value) {
544 /* But this one is culture-sensitive */
545 public int LastIndexOf(String value, int sindex, int count) {
547 throw new ArgumentNullException();
550 if (value == String.Empty) {
554 if (sindex == 0 && this.length == 0) {
558 // This check is needed to match undocumented MS behaviour
559 if (this.length == 0 && value.length > 0) {
563 if (value.length > sindex) {
571 if (sindex < 0 || sindex > this.length) {
572 throw new ArgumentOutOfRangeException ();
575 if (count < 0 || sindex - count + 1 < 0) {
576 throw new ArgumentOutOfRangeException ();
579 return(CultureInfo.CurrentCulture.CompareInfo.LastIndexOf (this, value, sindex, count));
582 public String PadLeft(int width) {
583 return PadLeft(width, ' ');
586 public String PadLeft(int width, char chr) {
588 throw new ArgumentException();
590 if (width < this.length)
591 return String.Copy(this);
593 return InternalPad(width, chr, false);
596 public String PadRight(int width) {
597 return PadRight(width, ' ');
600 public String PadRight(int width, char chr) {
602 throw new ArgumentException();
604 if (width < this.length)
605 return String.Copy(this);
607 return InternalPad(width, chr, true);
610 public bool StartsWith(String value) {
612 throw new ArgumentNullException("value");
615 if (value == String.Empty) {
619 if (this.length < value.length) {
623 return (0 == Compare(this, 0, value, 0 , value.length));
627 /* This method is culture insensitive */
628 public String Replace (char oldChar, char newChar) {
629 return(InternalReplace(oldChar, newChar));
632 /* This method is culture sensitive */
633 public String Replace(String oldValue, String newValue) {
635 throw new ArgumentNullException ("oldValue");
637 if(oldValue==String.Empty) {
638 throw new ArgumentException ("oldValue is the empty string.");
641 if(this==String.Empty) {
646 newValue=String.Empty;
649 return(InternalReplace (oldValue, newValue, CultureInfo.CurrentCulture.CompareInfo));
652 public String Remove(int sindex, int count) {
653 if (sindex < 0 || count < 0 || sindex + count > this.length)
654 throw new ArgumentOutOfRangeException ();
656 return InternalRemove(sindex, count);
659 public String ToLower() {
660 return(InternalToLower(CultureInfo.CurrentCulture));
663 public String ToLower(CultureInfo culture) {
664 return(InternalToLower(culture));
667 public String ToUpper() {
668 return(InternalToUpper(CultureInfo.CurrentCulture));
671 public String ToUpper(CultureInfo culture) {
672 return(InternalToUpper(culture));
675 public override String ToString() {
679 public String ToString(IFormatProvider provider) {
683 public String Trim() {
687 public static String Format(String format, Object arg0) {
688 return Format(null, format, new Object[] {arg0});
691 public static String Format(String format, Object arg0, Object arg1) {
692 return Format(null, format, new Object[] {arg0, arg1});
695 public static String Format(String format, Object arg0, Object arg1, Object arg2) {
696 return Format(null, format, new Object[] {arg0, arg1, arg2});
699 public static string Format (string format, params object[] args) {
700 return Format (null, format, args);
703 public static string Format (IFormatProvider provider, string format, params object[] args) {
704 StringBuilder b = new StringBuilder ();
705 FormatHelper (b, provider, format, args);
706 return b.ToString ();
709 internal static void FormatHelper (StringBuilder result, IFormatProvider provider, string format, params object[] args) {
710 if (format == null || args == null)
711 throw new ArgumentNullException ();
715 while (ptr < format.length) {
716 char c = format[ptr ++];
719 result.Append (format, start, ptr - start - 1);
721 // check for escaped open bracket
723 if (format[ptr] == '{') {
734 ParseFormatSpecifier (format, ref ptr, out n, out width, out left_align, out arg_format);
735 if (n >= args.Length)
736 throw new FormatException ("Index (zero based) must be greater than or equal to zero and less than the size of the argument list.");
740 object arg = args[n];
745 else if (arg is IFormattable)
746 str = ((IFormattable)arg).ToString (arg_format, provider);
748 str = arg.ToString ();
750 // pad formatted string and append to result
752 if (width > str.length) {
753 string pad = new String (' ', width - str.length);
769 else if (c == '}' && ptr < format.length && format[ptr] == '}') {
770 result.Append (format, start, ptr - start - 1);
774 throw new FormatException ("Input string was not in a correct format.");
778 if (start < format.length)
779 result.Append (format.Substring (start));
782 public static String Copy (String str) {
784 throw new ArgumentNullException ();
786 int length = str.length;
788 String tmp = InternalAllocateStr(length);
789 InternalStrcpy(tmp, 0, str);
793 public static String Concat(Object obj) {
797 return obj.ToString();
800 public static String Concat(Object obj1, Object obj2)
808 return obj2.ToString ();
809 } else if (obj2 == null)
810 return obj1.ToString ();
812 s1 = obj1.ToString ();
813 s2 = obj2.ToString ();
814 String tmp = InternalAllocateStr (s1.Length + s2.Length);
815 InternalStrcpy (tmp, 0, s1);
816 InternalStrcpy (tmp, s1.length, s2);
821 public static String Concat(Object obj1, Object obj2, Object obj3)
827 s1 = obj1.ToString ();
832 s2 = obj2.ToString ();
837 s3 = obj3.ToString ();
839 return Concat (s1, s2, s3);
842 public static String Concat (Object obj1, Object obj2, Object obj3, Object obj4)
844 string s1, s2, s3, s4;
849 s1 = obj1.ToString ();
854 s2 = obj2.ToString ();
859 s3 = obj3.ToString ();
864 s4 = obj4.ToString ();
866 return Concat (s1, s2, s3, s4);
870 public static String Concat(String s1, String s2)
881 String tmp = InternalAllocateStr(s1.length + s2.length);
883 InternalStrcpy(tmp, 0, s1);
884 InternalStrcpy(tmp, s1.length, s2);
889 public static String Concat(String s1, String s2, String s3)
913 String tmp = InternalAllocateStr(s1.length + s2.length + s3.length);
915 InternalStrcpy(tmp, 0, s1);
916 InternalStrcpy(tmp, s1.length, s2);
917 InternalStrcpy(tmp, s1.length + s2.length, s3);
922 public static String Concat(String s1, String s2, String s3, String s4) {
923 if (null == s1 && null == s2 && null == s3 && null == s4) {
927 if (null == s1) { s1 = String.Empty; }
928 if (null == s2) { s2 = String.Empty; }
929 if (null == s3) { s3 = String.Empty; }
930 if (null == s4) { s4 = String.Empty; }
932 String tmp = InternalAllocateStr(s1.length + s2.length + s3.length + s4.length);
934 InternalStrcpy(tmp, 0, s1);
935 InternalStrcpy(tmp, s1.length, s2);
936 InternalStrcpy(tmp, s1.length + s2.length, s3);
937 InternalStrcpy(tmp, s1.length + s2.length + s3.length, s4);
942 public static String Concat(params Object[] args) {
944 int len, i, currentpos;
947 throw new ArgumentNullException ();
949 strings = new string [args.Length];
952 foreach (object arg in args) {
953 /* use Empty for each null argument */
955 strings[i] = String.Empty;
957 strings[i] = arg.ToString ();
958 len += strings[i].length;
967 String tmp = InternalAllocateStr(len);
968 for (i = 0; i < strings.Length; i++) {
969 InternalStrcpy(tmp, currentpos, strings[i]);
970 currentpos += strings[i].length;
976 public static String Concat(params String[] values) {
977 int len, i, currentpos;
980 throw new ArgumentNullException ();
983 foreach (string value in values)
984 len += value != null ? value.length : 0;
991 String tmp = InternalAllocateStr(len);
992 for (i = 0; i < values.Length; i++) {
993 if (values[i] == null)
996 InternalStrcpy(tmp, currentpos, values[i]);
997 currentpos += values[i].length;
1003 public String Insert(int sindex, String value) {
1005 throw new ArgumentNullException();
1007 if (sindex < 0 || sindex > this.length)
1008 throw new ArgumentOutOfRangeException();
1010 return InternalInsert(sindex, value);
1014 public static string Intern (string str) {
1016 throw new ArgumentNullException ();
1018 return InternalIntern(str);
1021 public static string IsInterned (string str) {
1023 throw new ArgumentNullException();
1025 return InternalIsInterned(str);
1028 public static string Join (string separator, string [] value) {
1030 throw new ArgumentNullException ();
1032 return Join(separator, value, 0, value.Length);
1035 public static string Join(string separator, string[] value, int sindex, int count) {
1037 throw new ArgumentNullException ();
1039 if (sindex + count > value.Length)
1040 throw new ArgumentOutOfRangeException ();
1042 if (sindex == value.Length)
1043 return String.Empty;
1045 return InternalJoin(separator, value, sindex, count);
1048 bool IConvertible.ToBoolean (IFormatProvider provider) {
1049 return Convert.ToBoolean (this);
1052 byte IConvertible.ToByte (IFormatProvider provider) {
1053 return Convert.ToByte (this);
1056 char IConvertible.ToChar (IFormatProvider provider) {
1057 return Convert.ToChar (this);
1060 DateTime IConvertible.ToDateTime (IFormatProvider provider) {
1061 return Convert.ToDateTime (this);
1064 decimal IConvertible.ToDecimal (IFormatProvider provider) {
1065 return Convert.ToDecimal (this);
1068 double IConvertible.ToDouble (IFormatProvider provider) {
1069 return Convert.ToDouble (this);
1072 short IConvertible.ToInt16 (IFormatProvider provider) {
1073 return Convert.ToInt16 (this);
1076 int IConvertible.ToInt32 (IFormatProvider provider) {
1077 return Convert.ToInt32 (this);
1080 long IConvertible.ToInt64 (IFormatProvider provider) {
1081 return Convert.ToInt64 (this);
1084 [CLSCompliant(false)]
1085 sbyte IConvertible.ToSByte (IFormatProvider provider) {
1086 return Convert.ToSByte (this);
1089 float IConvertible.ToSingle (IFormatProvider provider) {
1090 return Convert.ToSingle (this);
1092 string IConvertible.ToString (IFormatProvider format) {
1096 object IConvertible.ToType (Type conversionType, IFormatProvider provider) {
1097 return Convert.ToType (this, conversionType, provider);
1100 [CLSCompliant(false)]
1101 ushort IConvertible.ToUInt16 (IFormatProvider provider) {
1102 return Convert.ToUInt16 (this);
1105 [CLSCompliant(false)]
1106 uint IConvertible.ToUInt32 (IFormatProvider provider) {
1107 return Convert.ToUInt32 (this);
1110 [CLSCompliant(false)]
1111 ulong IConvertible.ToUInt64 (IFormatProvider provider) {
1112 return Convert.ToUInt64 (this);
1115 TypeCode IConvertible.GetTypeCode () {
1116 return TypeCode.String;
1125 public CharEnumerator GetEnumerator () {
1126 return new CharEnumerator (this);
1129 IEnumerator IEnumerable.GetEnumerator () {
1130 return new CharEnumerator (this);
1133 private static void ParseFormatSpecifier (string str, ref int ptr, out int n, out int width, out bool left_align, out string format) {
1134 // parses format specifier of form:
1140 // N = argument number (non-negative integer)
1142 n = ParseDecimal (str, ref ptr);
1144 throw new FormatException ("Input string was not in a correct format.");
1146 // M = width (non-negative integer)
1148 if (str[ptr] == ',') {
1149 // White space between ',' and number or sign.
1151 while (Char.IsWhiteSpace (str [ptr]))
1154 format = str.Substring (start, ptr - start);
1156 left_align = (str [ptr] == '-');
1160 width = ParseDecimal (str, ref ptr);
1162 throw new FormatException ("Input string was not in a correct format.");
1170 // F = argument format (string)
1172 if (str[ptr] == ':') {
1174 while (str[ptr] != '}')
1177 format += str.Substring (start, ptr - start);
1182 if (str[ptr ++] != '}')
1183 throw new FormatException ("Input string was not in a correct format.");
1185 catch (IndexOutOfRangeException) {
1186 throw new FormatException ("Input string was not in a correct format.");
1190 private static int ParseDecimal (string str, ref int ptr) {
1195 if (c < '0' || '9' < c)
1198 n = n * 10 + c - '0';
1209 [CLSCompliant(false), MethodImplAttribute(MethodImplOptions.InternalCall)]
1210 unsafe public extern String(char *value);
1212 [CLSCompliant(false), MethodImplAttribute(MethodImplOptions.InternalCall)]
1213 unsafe public extern String(char *value, int sindex, int length);
1215 [CLSCompliant(false), MethodImplAttribute(MethodImplOptions.InternalCall)]
1216 unsafe public extern String(sbyte *value);
1218 [CLSCompliant(false), MethodImplAttribute(MethodImplOptions.InternalCall)]
1219 unsafe public extern String(sbyte *value, int sindex, int length);
1221 [CLSCompliant(false), MethodImplAttribute(MethodImplOptions.InternalCall)]
1222 unsafe public extern String(sbyte *value, int sindex, int length, Encoding enc);
1224 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1225 public extern String(char [] val, int sindex, int length);
1227 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1228 public extern String(char [] val);
1230 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1231 public extern String(char c, int count);
1233 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1234 public extern override int GetHashCode();
1236 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1237 private extern static string InternalJoin(string separator, string[] value, int sindex, int count);
1239 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1240 private extern String InternalInsert(int sindex, String value);
1242 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1243 private extern String InternalReplace(char oldChar, char newChar);
1245 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1246 private extern String InternalReplace(String oldValue, string newValue, CompareInfo comp);
1248 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1249 private extern String InternalRemove(int sindex, int count);
1251 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1252 private extern void InternalCopyTo(int sindex, char[] dest, int dindex, int count);
1254 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1255 private extern String[] InternalSplit(char[] separator, int count);
1257 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1258 private extern String InternalTrim(char[] chars, int typ);
1260 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1261 private extern int InternalIndexOfAny(char [] arr, int sindex, int count);
1263 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1264 private extern int InternalLastIndexOfAny(char [] anyOf, int sindex, int count);
1266 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1267 private extern String InternalPad(int width, char chr, bool right);
1269 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1270 private extern String InternalToLower(CultureInfo culture);
1272 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1273 private extern String InternalToUpper(CultureInfo culture);
1275 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1276 private extern static String InternalAllocateStr(int length);
1278 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1279 private extern static void InternalStrcpy(String dest, int destPos, String src);
1281 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1282 private extern static void InternalStrcpy(String dest, int destPos, String src, int startPos, int count);
1284 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1285 private extern static string InternalIntern(string str);
1287 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1288 private extern static string InternalIsInterned(string str);