Lib.hx 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. /*
  2. * Copyright (C)2005-2019 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) {
  62. return "%" + c;
  63. });
  64. }
  65. /**
  66. Fills an array with the result of a simple iterator.
  67. **/
  68. public static function fillArray<T>(itr:Void->T):Array<T> {
  69. var i:T = null;
  70. var ret:Array<T> = [];
  71. while ({
  72. i = itr();
  73. i != null;
  74. }) {
  75. ret.push(i);
  76. }
  77. return ret;
  78. }
  79. /**
  80. Simple test for the presence of an available shell.
  81. **/
  82. public static function isShellAvailable():Bool {
  83. var ret:Dynamic = Os.execute();
  84. if (Lua.type(ret) == "bool") {
  85. return ret;
  86. } else {
  87. return ret != 0;
  88. }
  89. }
  90. }