String.hx 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  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. /**
  26. The basic String class.
  27. **/
  28. extern class String {
  29. /**
  30. The number of characters in the String.
  31. **/
  32. var length(default,null) : Int;
  33. /**
  34. Creates a copy from a given String.
  35. **/
  36. @:overload(function(b:haxe.io.BytesData, offset:Int, length:Int, charsetName:String):Void { })
  37. @:overload(function(b:haxe.io.BytesData, offset:Int, length:Int):Void { })
  38. function new(string:String) : Void;
  39. /**
  40. Returns an String where all characters have been uppercased.
  41. **/
  42. function toUpperCase() : String;
  43. /**
  44. Returns an String where all characters have been lowercased.
  45. **/
  46. function toLowerCase() : String;
  47. /**
  48. Returns the character at the given position.
  49. Returns the empty String if outside of String bounds.
  50. **/
  51. function charAt( index : Int) : String;
  52. /**
  53. Returns the character code at the given position.
  54. Returns [null] if outside of String bounds.
  55. **/
  56. function charCodeAt( index : Int) : Null<Int>;
  57. /**
  58. Returns the index of first occurence of [value]
  59. Returns [1-1] if [value] is not found.
  60. The optional [startIndex] parameter allows you to specify at which character to start searching.
  61. The position returned is still relative to the beginning of the string.
  62. **/
  63. function indexOf( str : String, ?startIndex : Int ) : Int;
  64. /**
  65. Similar to [indexOf] but returns the latest index.
  66. **/
  67. function lastIndexOf( str : String, ?startIndex : Int ) : Int;
  68. /**
  69. Split the string using the specified delimiter.
  70. **/
  71. function split( delimiter : String ) : Array<String>;
  72. /**
  73. Returns a part of the String, taking [len] characters starting from [pos].
  74. If [len] is not specified, it takes all the remaining characters.
  75. **/
  76. function substr( pos : Int, ?len : Int ) : String;
  77. /**
  78. Returns a part of the String, taking from [startIndex] to [endIndex] - 1.
  79. If [endIndex] is not specified, length is used.
  80. If [startIndex] or [endIndex] is smaller than 0, than 0 is used.
  81. If [startIndex] > [endIndex] then they are swaped.
  82. **/
  83. function substring( startIndex : Int, ?endIndex : Int ) : String;
  84. /**
  85. Returns the String itself.
  86. **/
  87. function toString() : String;
  88. private function compareTo( anotherString : String ) : Int;
  89. private function codePointAt( idx : Int ) : Int;
  90. private function getBytes(encoding:String) : haxe.io.BytesData;
  91. static function fromCharCode( code : Int ) : String;
  92. }