String.hx 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. /*
  2. * Copyright (c) 2005, The haXe Project Contributors
  3. * All rights reserved.
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions are met:
  6. *
  7. * - Redistributions of source code must retain the above copyright
  8. * notice, this list of conditions and the following disclaimer.
  9. * - Redistributions in binary form must reproduce the above copyright
  10. * notice, this list of conditions and the following disclaimer in the
  11. * documentation and/or other materials provided with the distribution.
  12. *
  13. * THIS SOFTWARE IS PROVIDED BY THE HAXE PROJECT CONTRIBUTORS "AS IS" AND ANY
  14. * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  15. * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  16. * DISCLAIMED. IN NO EVENT SHALL THE HAXE PROJECT CONTRIBUTORS BE LIABLE FOR
  17. * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  18. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  19. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  20. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  21. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  22. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
  23. * DAMAGE.
  24. */
  25. import cs.StdTypes;
  26. /**
  27. The basic String class.
  28. **/
  29. extern class String implements ArrayAccess<Char16> {
  30. /**
  31. The number of characters in the String.
  32. **/
  33. var length(default,null) : Int;
  34. /**
  35. Creates a copy from a given String.
  36. **/
  37. function new(string:String) : Void;
  38. /**
  39. Returns an String where all characters have been uppercased.
  40. **/
  41. function toUpperCase() : String;
  42. /**
  43. Returns an String where all characters have been lowercased.
  44. **/
  45. function toLowerCase() : String;
  46. /**
  47. Returns the character at the given position.
  48. Returns the empty String if outside of String bounds.
  49. **/
  50. function charAt( index : Int) : String;
  51. /**
  52. Returns the character code at the given position.
  53. Returns [null] if outside of String bounds.
  54. **/
  55. function charCodeAt( index : Int) : Null<Int>;
  56. /**
  57. Returns the index of first occurence of [value]
  58. Returns [1-1] if [value] is not found.
  59. The optional [startIndex] parameter allows you to specify at which character to start searching.
  60. The position returned is still relative to the beginning of the string.
  61. **/
  62. function indexOf( str : String, ?startIndex : Int ) : Int;
  63. /**
  64. Similar to [indexOf] but returns the latest index.
  65. **/
  66. function lastIndexOf( str : String, ?startIndex : Int ) : Int;
  67. /**
  68. Split the string using the specified delimiter.
  69. **/
  70. function split( delimiter : String ) : Array<String>;
  71. /**
  72. Returns a part of the String, taking [len] characters starting from [pos].
  73. If [len] is not specified, it takes all the remaining characters.
  74. **/
  75. function substr( pos : Int, ?len : Int ) : String;
  76. /**
  77. Returns a part of the String, taking from [startIndex] to [endIndex] - 1.
  78. If [endIndex] is not specified, length is used.
  79. If [startIndex] or [endIndex] is smaller than 0, than 0 is used.
  80. If [startIndex] > [endIndex] then they are swaped.
  81. **/
  82. function substring( startIndex : Int, ?endIndex : Int ) : String;
  83. /**
  84. Returns the String itself.
  85. **/
  86. function toString() : String;
  87. static function fromCharCode( code : Int ) : String;
  88. private function Replace(oldValue:String, newValue:String):String;
  89. private function StartsWith(value:String):Bool;
  90. private function EndsWith(value:String):Bool;
  91. private function TrimStart():String;
  92. private function TrimEnd():String;
  93. private function CompareTo(obj:Dynamic):Int;
  94. @:overload(function(startIndex:Int):String {})
  95. private function Substring(startIndex:Int, length:Int):String;
  96. }