Lib.hx 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. /*
  2. * Copyright (C)2005-2017 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 python;
  23. import python.internal.AnonObject;
  24. import python.Dict;
  25. import python.NativeStringTools;
  26. typedef PySys = python.lib.Sys;
  27. /**
  28. Platform-specific Python Library. Provides some platform-specific functions
  29. for the Python target, such as conversion from Haxe types to native types
  30. and vice-versa.
  31. **/
  32. class Lib {
  33. /**
  34. Print the specified value on the default output.
  35. **/
  36. public static function print(v:Dynamic):Void {
  37. var str = Std.string(v);
  38. PySys.stdout.buffer.write( NativeStringTools.encode(str, "utf-8"));
  39. PySys.stdout.flush();
  40. }
  41. /**
  42. Print the specified value on the default output followed by a newline character.
  43. **/
  44. public static function println(v:Dynamic):Void {
  45. var str = Std.string(v);
  46. PySys.stdout.buffer.write( NativeStringTools.encode('$str\n', "utf-8"));
  47. PySys.stdout.flush();
  48. }
  49. /**
  50. Returns an anonymous Object which holds the same data as the Dictionary `v`.
  51. **/
  52. public static function dictToAnon (v:Dict<String, Dynamic>):Dynamic {
  53. return new AnonObject(v.copy());
  54. }
  55. /**
  56. Returns a flat copy of the underlying Dictionary of `o`.
  57. **/
  58. @:access(python.Boot.isAnonObject)
  59. public static function anonToDict (o:{}):Dict<String, Dynamic> {
  60. return if (Boot.isAnonObject(o))
  61. {
  62. (Syntax.field(o, "__dict__"):Dict<String,Dynamic>).copy();
  63. }
  64. else null;
  65. }
  66. /**
  67. Returns the underlying Dictionary of the anonymous object `o`.
  68. Modifications to this dictionary are reflected in the anonymous Object too.
  69. **/
  70. @:access(python.Boot.isAnonObject)
  71. public static function anonAsDict (o:{}):Dict<String, Dynamic> {
  72. return if (Boot.isAnonObject(o))
  73. {
  74. (Syntax.field(o, "__dict__"):Dict<String,Dynamic>);
  75. }
  76. else null;
  77. }
  78. /**
  79. Returns the Dictionary `d` as an anonymous Object.
  80. Modifications to the object are reflected in the Dictionary too.
  81. **/
  82. public static function dictAsAnon (d:Dict<String, Dynamic>):Dynamic {
  83. return new AnonObject(d);
  84. }
  85. /**
  86. Return Python native iterable from Haxe iterable.
  87. **/
  88. public static function toPythonIterable <T>(it:Iterable<T>):python.NativeIterable<T> {
  89. return {
  90. __iter__ : function () {
  91. var it1 = it.iterator();
  92. var self:NativeIterator<T> = null;
  93. self = new NativeIterator({
  94. __next__ : function ():T {
  95. if (it1.hasNext()) {
  96. return it1.next();
  97. } else {
  98. throw new python.Exceptions.StopIteration();
  99. }
  100. },
  101. __iter__ : function () return self
  102. });
  103. return self;
  104. }
  105. }
  106. }
  107. /**
  108. Return Haxe iterable from Python native iterable.
  109. **/
  110. public static inline function toHaxeIterable <T>(it:NativeIterable<T>):HaxeIterable<T> {
  111. return new HaxeIterable(it);
  112. }
  113. /**
  114. Return Haxe iterator instance from Python native iterable.
  115. **/
  116. public static inline function toHaxeIterator <T>(it:NativeIterator<T>):HaxeIterator<T> {
  117. return new HaxeIterator(it);
  118. }
  119. }