Lib.hx 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. /*
  2. * Copyright (C)2005-2018 Haxe Foundation
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a
  5. * copy of this software and associated documentation files (the "Software"),
  6. * to deal in the Software without restriction, including without limitation
  7. * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  8. * and/or sell copies of the Software, and to permit persons to whom the
  9. * Software is furnished to do so, subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in
  12. * all copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  19. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  20. * DEALINGS IN THE SOFTWARE.
  21. */
  22. package lua;
  23. import lua.Lua;
  24. import lua.Io;
  25. import lua.NativeStringTools;
  26. /**
  27. Platform-specific Lua Library. Provides some platform-specific functions
  28. for the Lua target, such as conversion from Haxe types to native types
  29. and vice-versa.
  30. **/
  31. class Lib {
  32. /**
  33. Print the specified value on the default output followed by a newline character.
  34. **/
  35. public static inline function println( v : Dynamic ) : Void {
  36. Lua.print(Std.string(v));
  37. }
  38. /**
  39. Print the specified value on the default output.
  40. **/
  41. public static inline function print(v:Dynamic) : Void {
  42. Io.write(Std.string(v));
  43. Io.flush();
  44. }
  45. /**
  46. Copies the table argument and converts it to an Array
  47. **/
  48. public inline static function tableToArray<T>(t:Table<Int,T>, ?length:Int) : Array<T> {
  49. return Boot.defArray(PairTools.copy(t), length);
  50. }
  51. /**
  52. Copies the table argument and converts it to an Object.
  53. **/
  54. public inline static function tableToObject<T>(t:Table<String,T>) : Dynamic<T> {
  55. return Boot.tableToObject(PairTools.copy(t));
  56. }
  57. /**
  58. Perform Lua-style pattern quoting on a given string.
  59. **/
  60. public inline static function patternQuote(str:String) : String {
  61. return NativeStringTools.gsub(str, "[%(%)%.%%%+%-%*%?%[%]%^%$]", function(c:String){ return "%" + c; });
  62. }
  63. /**
  64. Fills an array with the result of a simple iterator.
  65. **/
  66. public static function fillArray<T>(itr:Void->T) : Array<T> {
  67. var i: T = null;
  68. var ret : Array<T> = [];
  69. while({i = itr(); i != null;}){
  70. ret.push(i);
  71. }
  72. return ret;
  73. }
  74. /**
  75. Simple test for the presence of an available shell.
  76. **/
  77. public static function isShellAvailable() : Bool {
  78. var ret : Dynamic = Os.execute();
  79. if (Lua.type(ret) == "bool"){
  80. return ret;
  81. } else {
  82. return ret != 0;
  83. }
  84. }
  85. }