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.length > this.length) {
364 return (0 == Compare(this, length - value.length, value, 0, value.length));
367 public int IndexOfAny(char [] arr) {
369 throw new ArgumentNullException();
371 return InternalIndexOfAny(arr, 0, this.length);
374 public int IndexOfAny(char [] arr, int sindex) {
376 throw new ArgumentNullException();
377 if (sindex < 0 || sindex >= this.length)
378 throw new ArgumentOutOfRangeException();
380 return InternalIndexOfAny(arr, sindex, this.length - sindex);
383 public int IndexOfAny(char [] arr, int sindex, int count) {
385 throw new ArgumentNullException();
386 if (sindex < 0 || count < 0 || sindex + count > this.length)
387 throw new ArgumentOutOfRangeException ();
389 return InternalIndexOfAny(arr, sindex, count);
392 public int IndexOf(char value) {
393 return(IndexOf(value, 0, this.length));
396 public int IndexOf(String value) {
397 return(IndexOf(value, 0, this.length));
400 public int IndexOf(char value, int sindex) {
401 return(IndexOf(value, sindex, this.length - sindex));
404 public int IndexOf(String value, int sindex) {
405 return(IndexOf(value, sindex, this.length - sindex));
408 /* This method is culture-insensitive */
409 public int IndexOf(char value, int sindex, int count) {
410 if (sindex < 0 || count < 0 ||
411 sindex + count > this.length) {
412 throw new ArgumentOutOfRangeException ();
415 if ((sindex == 0 && this.length == 0) ||
416 (sindex == this.length) ||
421 for(int pos=sindex; pos < sindex + count; pos++) {
422 if(this[pos]==value) {
430 /* But this one is culture-sensitive */
431 public int IndexOf(String value, int sindex, int count) {
433 throw new ArgumentNullException();
436 if (sindex < 0 || count < 0 ||
437 sindex + count > this.length) {
438 throw new ArgumentOutOfRangeException ();
441 if (value.length == 0) {
445 if (sindex == 0 && this.length == 0) {
453 return(CultureInfo.CurrentCulture.CompareInfo.IndexOf (this, value, sindex, count));
456 public int LastIndexOfAny(char [] arr) {
458 throw new ArgumentNullException();
460 return InternalLastIndexOfAny(arr, this.length - 1, this.length);
463 public int LastIndexOfAny(char [] arr, int sindex) {
465 throw new ArgumentNullException();
467 if (sindex < 0 || sindex > this.length)
468 throw new ArgumentOutOfRangeException();
470 if (this.length == 0)
473 return InternalLastIndexOfAny(arr, sindex, sindex + 1);
476 public int LastIndexOfAny(char [] arr, int sindex, int count) {
478 throw new ArgumentNullException();
480 if (sindex < 0 || count < 0 || sindex > this.length || sindex - count < -1)
481 throw new ArgumentOutOfRangeException();
483 if (this.length == 0)
486 return InternalLastIndexOfAny(arr, sindex, count);
489 public int LastIndexOf(char value) {
493 return(LastIndexOf(value, this.length - 1,
499 public int LastIndexOf(String value) {
501 /* This overload does additional checking */
502 return(LastIndexOf(value, 0, 0));
504 return(LastIndexOf(value, this.length - 1,
509 public int LastIndexOf(char value, int sindex){
510 return(LastIndexOf(value, sindex, sindex + 1));
513 public int LastIndexOf(String value, int sindex) {
514 return(LastIndexOf(value, sindex, sindex + 1));
517 /* This method is culture-insensitive */
518 public int LastIndexOf(char value, int sindex, int count) {
519 if (sindex == 0 && this.length == 0) {
523 if (sindex < 0 || count < 0) {
524 throw new ArgumentOutOfRangeException ();
527 if (sindex >= this.length || sindex - count + 1 < 0) {
528 throw new ArgumentOutOfRangeException ();
531 for(int pos=sindex; pos > sindex - count; pos--) {
532 if(this[pos]==value) {
540 /* But this one is culture-sensitive */
541 public int LastIndexOf(String value, int sindex, int count) {
543 throw new ArgumentNullException();
546 if (value == String.Empty) {
550 if (sindex == 0 && this.length == 0) {
554 // This check is needed to match undocumented MS behaviour
555 if (this.length == 0 && value.length > 0) {
559 if (value.length > sindex) {
567 if (sindex < 0 || sindex > this.length) {
568 throw new ArgumentOutOfRangeException ();
571 if (count < 0 || sindex - count + 1 < 0) {
572 throw new ArgumentOutOfRangeException ();
575 return(CultureInfo.CurrentCulture.CompareInfo.LastIndexOf (this, value, sindex, count));
578 public String PadLeft(int width) {
579 return PadLeft(width, ' ');
582 public String PadLeft(int width, char chr) {
584 throw new ArgumentException();
586 if (width < this.length)
587 return String.Copy(this);
589 return InternalPad(width, chr, false);
592 public String PadRight(int width) {
593 return PadRight(width, ' ');
596 public String PadRight(int width, char chr) {
598 throw new ArgumentException();
600 if (width < this.length)
601 return String.Copy(this);
603 return InternalPad(width, chr, true);
606 public bool StartsWith(String value) {
608 throw new ArgumentNullException("value");
611 if (this.length < value.length) {
615 return (0 == Compare(this, 0, value, 0 , value.length));
619 /* This method is culture insensitive */
620 public String Replace (char oldChar, char newChar) {
621 return(InternalReplace(oldChar, newChar));
624 /* This method is culture sensitive */
625 public String Replace(String oldValue, String newValue) {
627 throw new ArgumentNullException ("oldValue");
629 if(oldValue==String.Empty) {
630 throw new ArgumentException ("oldValue is the empty string.");
633 if(this==String.Empty) {
638 newValue=String.Empty;
641 return(InternalReplace (oldValue, newValue, CultureInfo.CurrentCulture.CompareInfo));
644 public String Remove(int sindex, int count) {
645 if (sindex < 0 || count < 0 || sindex + count > this.length)
646 throw new ArgumentOutOfRangeException ();
648 return InternalRemove(sindex, count);
651 public String ToLower() {
652 return(InternalToLower(CultureInfo.CurrentCulture));
655 public String ToLower(CultureInfo culture) {
656 return(InternalToLower(culture));
659 public String ToUpper() {
660 return(InternalToUpper(CultureInfo.CurrentCulture));
663 public String ToUpper(CultureInfo culture) {
664 return(InternalToUpper(culture));
667 public override String ToString() {
671 public String ToString(IFormatProvider provider) {
675 public String Trim() {
679 public static String Format(String format, Object arg0) {
680 return Format(null, format, new Object[] {arg0});
683 public static String Format(String format, Object arg0, Object arg1) {
684 return Format(null, format, new Object[] {arg0, arg1});
687 public static String Format(String format, Object arg0, Object arg1, Object arg2) {
688 return Format(null, format, new Object[] {arg0, arg1, arg2});
691 public static string Format (string format, params object[] args) {
692 return Format (null, format, args);
695 public static string Format (IFormatProvider provider, string format, params object[] args) {
696 StringBuilder b = new StringBuilder ();
697 FormatHelper (b, provider, format, args);
698 return b.ToString ();
701 internal static void FormatHelper (StringBuilder result, IFormatProvider provider, string format, params object[] args) {
702 if (format == null || args == null)
703 throw new ArgumentNullException ();
707 while (ptr < format.length) {
708 char c = format[ptr ++];
711 result.Append (format, start, ptr - start - 1);
713 // check for escaped open bracket
715 if (format[ptr] == '{') {
726 ParseFormatSpecifier (format, ref ptr, out n, out width, out left_align, out arg_format);
727 if (n >= args.Length)
728 throw new FormatException ("Index (zero based) must be greater than or equal to zero and less than the size of the argument list.");
732 object arg = args[n];
737 else if (arg is IFormattable)
738 str = ((IFormattable)arg).ToString (arg_format, provider);
740 str = arg.ToString ();
742 // pad formatted string and append to result
744 if (width > str.length) {
745 string pad = new String (' ', width - str.length);
761 else if (c == '}' && ptr < format.length && format[ptr] == '}') {
762 result.Append (format, start, ptr - start - 1);
766 throw new FormatException ("Input string was not in a correct format.");
770 if (start < format.length)
771 result.Append (format.Substring (start));
774 public static String Copy (String str) {
776 throw new ArgumentNullException ();
778 int length = str.length;
780 String tmp = InternalAllocateStr(length);
781 InternalStrcpy(tmp, 0, str);
785 public static String Concat(Object obj) {
789 return obj.ToString();
792 public static String Concat(Object obj1, Object obj2)
800 return obj2.ToString ();
801 } else if (obj2 == null)
802 return obj1.ToString ();
804 s1 = obj1.ToString ();
805 s2 = obj2.ToString ();
806 String tmp = InternalAllocateStr (s1.Length + s2.Length);
807 InternalStrcpy (tmp, 0, s1);
808 InternalStrcpy (tmp, s1.length, s2);
813 public static String Concat(Object obj1, Object obj2, Object obj3)
819 s1 = obj1.ToString ();
824 s2 = obj2.ToString ();
829 s3 = obj3.ToString ();
831 return Concat (s1, s2, s3);
834 public static String Concat (Object obj1, Object obj2, Object obj3, Object obj4)
836 string s1, s2, s3, s4;
841 s1 = obj1.ToString ();
846 s2 = obj2.ToString ();
851 s3 = obj3.ToString ();
856 s4 = obj4.ToString ();
858 return Concat (s1, s2, s3, s4);
862 public static String Concat(String s1, String s2)
873 String tmp = InternalAllocateStr(s1.length + s2.length);
875 InternalStrcpy(tmp, 0, s1);
876 InternalStrcpy(tmp, s1.length, s2);
881 public static String Concat(String s1, String s2, String s3)
905 String tmp = InternalAllocateStr(s1.length + s2.length + s3.length);
907 InternalStrcpy(tmp, 0, s1);
908 InternalStrcpy(tmp, s1.length, s2);
909 InternalStrcpy(tmp, s1.length + s2.length, s3);
914 public static String Concat(String s1, String s2, String s3, String s4) {
915 if (null == s1 && null == s2 && null == s3 && null == s4) {
919 if (null == s1) { s1 = String.Empty; }
920 if (null == s2) { s2 = String.Empty; }
921 if (null == s3) { s3 = String.Empty; }
922 if (null == s4) { s4 = String.Empty; }
924 String tmp = InternalAllocateStr(s1.length + s2.length + s3.length + s4.length);
926 InternalStrcpy(tmp, 0, s1);
927 InternalStrcpy(tmp, s1.length, s2);
928 InternalStrcpy(tmp, s1.length + s2.length, s3);
929 InternalStrcpy(tmp, s1.length + s2.length + s3.length, s4);
934 public static String Concat(params Object[] args) {
936 int len, i, currentpos;
939 throw new ArgumentNullException ();
941 strings = new string [args.Length];
944 foreach (object arg in args) {
945 /* use Empty for each null argument */
947 strings[i] = String.Empty;
949 strings[i] = arg.ToString ();
950 len += strings[i].length;
959 String tmp = InternalAllocateStr(len);
960 for (i = 0; i < strings.Length; i++) {
961 InternalStrcpy(tmp, currentpos, strings[i]);
962 currentpos += strings[i].length;
968 public static String Concat(params String[] values) {
969 int len, i, currentpos;
972 throw new ArgumentNullException ();
975 foreach (string value in values)
976 len += value != null ? value.length : 0;
983 String tmp = InternalAllocateStr(len);
984 for (i = 0; i < values.Length; i++) {
985 if (values[i] == null)
988 InternalStrcpy(tmp, currentpos, values[i]);
989 currentpos += values[i].length;
995 public String Insert(int sindex, String value) {
997 throw new ArgumentNullException();
999 if (sindex < 0 || sindex > this.length)
1000 throw new ArgumentOutOfRangeException();
1002 return InternalInsert(sindex, value);
1006 public static string Intern (string str) {
1008 throw new ArgumentNullException ();
1010 return InternalIntern(str);
1013 public static string IsInterned (string str) {
1015 throw new ArgumentNullException();
1017 return InternalIsInterned(str);
1020 public static string Join (string separator, string [] value) {
1022 throw new ArgumentNullException ();
1024 return Join(separator, value, 0, value.Length);
1027 public static string Join(string separator, string[] value, int sindex, int count) {
1029 throw new ArgumentNullException ();
1031 if (sindex + count > value.Length)
1032 throw new ArgumentOutOfRangeException ();
1034 if (sindex == value.Length)
1035 return String.Empty;
1037 return InternalJoin(separator, value, sindex, count);
1040 bool IConvertible.ToBoolean (IFormatProvider provider) {
1041 return Convert.ToBoolean (this);
1044 byte IConvertible.ToByte (IFormatProvider provider) {
1045 return Convert.ToByte (this);
1048 char IConvertible.ToChar (IFormatProvider provider) {
1049 return Convert.ToChar (this);
1052 DateTime IConvertible.ToDateTime (IFormatProvider provider) {
1053 return Convert.ToDateTime (this);
1056 decimal IConvertible.ToDecimal (IFormatProvider provider) {
1057 return Convert.ToDecimal (this);
1060 double IConvertible.ToDouble (IFormatProvider provider) {
1061 return Convert.ToDouble (this);
1064 short IConvertible.ToInt16 (IFormatProvider provider) {
1065 return Convert.ToInt16 (this);
1068 int IConvertible.ToInt32 (IFormatProvider provider) {
1069 return Convert.ToInt32 (this);
1072 long IConvertible.ToInt64 (IFormatProvider provider) {
1073 return Convert.ToInt64 (this);
1076 [CLSCompliant(false)]
1077 sbyte IConvertible.ToSByte (IFormatProvider provider) {
1078 return Convert.ToSByte (this);
1081 float IConvertible.ToSingle (IFormatProvider provider) {
1082 return Convert.ToSingle (this);
1084 string IConvertible.ToString (IFormatProvider format) {
1088 object IConvertible.ToType (Type conversionType, IFormatProvider provider) {
1089 return Convert.ToType (this, conversionType, provider);
1092 [CLSCompliant(false)]
1093 ushort IConvertible.ToUInt16 (IFormatProvider provider) {
1094 return Convert.ToUInt16 (this);
1097 [CLSCompliant(false)]
1098 uint IConvertible.ToUInt32 (IFormatProvider provider) {
1099 return Convert.ToUInt32 (this);
1102 [CLSCompliant(false)]
1103 ulong IConvertible.ToUInt64 (IFormatProvider provider) {
1104 return Convert.ToUInt64 (this);
1107 TypeCode IConvertible.GetTypeCode () {
1108 return TypeCode.String;
1117 public CharEnumerator GetEnumerator () {
1118 return new CharEnumerator (this);
1121 IEnumerator IEnumerable.GetEnumerator () {
1122 return new CharEnumerator (this);
1125 private static void ParseFormatSpecifier (string str, ref int ptr, out int n, out int width, out bool left_align, out string format) {
1126 // parses format specifier of form:
1132 // N = argument number (non-negative integer)
1134 n = ParseDecimal (str, ref ptr);
1136 throw new FormatException ("Input string was not in a correct format.");
1138 // M = width (non-negative integer)
1140 if (str[ptr] == ',') {
1141 // White space between ',' and number or sign.
1143 while (Char.IsWhiteSpace (str [ptr]))
1146 format = str.Substring (start, ptr - start);
1148 left_align = (str [ptr] == '-');
1152 width = ParseDecimal (str, ref ptr);
1154 throw new FormatException ("Input string was not in a correct format.");
1162 // F = argument format (string)
1164 if (str[ptr] == ':') {
1166 while (str[ptr] != '}')
1169 format += str.Substring (start, ptr - start);
1174 if (str[ptr ++] != '}')
1175 throw new FormatException ("Input string was not in a correct format.");
1177 catch (IndexOutOfRangeException) {
1178 throw new FormatException ("Input string was not in a correct format.");
1182 private static int ParseDecimal (string str, ref int ptr) {
1187 if (c < '0' || '9' < c)
1190 n = n * 10 + c - '0';
1201 [CLSCompliant(false), MethodImplAttribute(MethodImplOptions.InternalCall)]
1202 unsafe public extern String(char *value);
1204 [CLSCompliant(false), MethodImplAttribute(MethodImplOptions.InternalCall)]
1205 unsafe public extern String(char *value, int sindex, int length);
1207 [CLSCompliant(false), MethodImplAttribute(MethodImplOptions.InternalCall)]
1208 unsafe public extern String(sbyte *value);
1210 [CLSCompliant(false), MethodImplAttribute(MethodImplOptions.InternalCall)]
1211 unsafe public extern String(sbyte *value, int sindex, int length);
1213 [CLSCompliant(false), MethodImplAttribute(MethodImplOptions.InternalCall)]
1214 unsafe public extern String(sbyte *value, int sindex, int length, Encoding enc);
1216 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1217 public extern String(char [] val, int sindex, int length);
1219 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1220 public extern String(char [] val);
1222 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1223 public extern String(char c, int count);
1225 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1226 public extern override int GetHashCode();
1228 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1229 private extern static string InternalJoin(string separator, string[] value, int sindex, int count);
1231 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1232 private extern String InternalInsert(int sindex, String value);
1234 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1235 private extern String InternalReplace(char oldChar, char newChar);
1237 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1238 private extern String InternalReplace(String oldValue, string newValue, CompareInfo comp);
1240 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1241 private extern String InternalRemove(int sindex, int count);
1243 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1244 private extern void InternalCopyTo(int sindex, char[] dest, int dindex, int count);
1246 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1247 private extern String[] InternalSplit(char[] separator, int count);
1249 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1250 private extern String InternalTrim(char[] chars, int typ);
1252 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1253 private extern int InternalIndexOfAny(char [] arr, int sindex, int count);
1255 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1256 private extern int InternalLastIndexOfAny(char [] anyOf, int sindex, int count);
1258 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1259 private extern String InternalPad(int width, char chr, bool right);
1261 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1262 private extern String InternalToLower(CultureInfo culture);
1264 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1265 private extern String InternalToUpper(CultureInfo culture);
1267 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1268 private extern static String InternalAllocateStr(int length);
1270 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1271 private extern static void InternalStrcpy(String dest, int destPos, String src);
1273 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1274 private extern static void InternalStrcpy(String dest, int destPos, String src, int startPos, int count);
1276 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1277 private extern static string InternalIntern(string str);
1279 [MethodImplAttribute(MethodImplOptions.InternalCall)]
1280 private extern static string InternalIsInterned(string str);