Syntax.hx 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  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. #if macro
  24. import haxe.macro.Expr;
  25. import haxe.macro.Context;
  26. import haxe.macro.ExprTools;
  27. #end
  28. @:noPackageRestrict
  29. extern class Syntax {
  30. #if macro
  31. static var self = macro python.Syntax;
  32. #end
  33. @:noUsing macro public static function importModule (module:String):haxe.macro.Expr {
  34. return macro ($self.pythonCode($v{"import " + module}):Void);
  35. }
  36. @:noUsing macro public static function importAs (module:String, className : String):haxe.macro.Expr {
  37. var n = className.split(".").join("_");
  38. var e = "import " + module + " as " + n;
  39. return macro ($self.pythonCode($v{e}):Void);
  40. }
  41. @:noUsing
  42. macro public static function newInstance (c:Expr, params:Array<Expr>):haxe.macro.Expr {
  43. return macro $self._newInstance($c, $a{params});
  44. }
  45. static function _newInstance(c:Dynamic, args:Array<Dynamic>):Dynamic { return null; }
  46. @:noUsing
  47. public static function isIn(a:Dynamic, b:Dynamic):Bool { return false; }
  48. @:noUsing
  49. public static function delete(a:Dynamic):Void { }
  50. @:noUsing
  51. public static function binop(a:Dynamic, op:String, b:Dynamic):Dynamic { return null; }
  52. @:noUsing
  53. public static function assign(a:Dynamic, b:Dynamic):Void { }
  54. @:noUsing
  55. macro public static function pythonCode(b:ExprOf<String>, rest:Array<Expr>):Expr {
  56. if (rest == null) rest = [];
  57. return macro @:pos(Context.currentPos()) untyped $self._pythonCode($b, $a{rest});
  58. };
  59. #if !macro
  60. @:noUsing
  61. public static function _pythonCode<T>(b:String, args:Array<Dynamic>):T { return null; };
  62. #end
  63. @:noUsing
  64. macro public static function arrayAccess(x:Expr, rest:Array<Expr>):ExprOf<Dynamic> {
  65. return macro $self._arrayAccess($x, $a{rest});
  66. }
  67. @:noUsing
  68. macro public static function arrayAccessWithTrailingColon(x:Expr, rest:Array<Expr>):ExprOf<Dynamic> {
  69. return macro $self._arrayAccess($x, $a{rest}, true);
  70. }
  71. static function _arrayAccess(a:Dynamic, args:Array<Dynamic>, ?trailingColon:Bool = false):Dynamic { return null; }
  72. @:noUsing
  73. public static function arraySet(a:Dynamic, i:Dynamic, v:Dynamic):Dynamic { return null; }
  74. static function _foreach(id:Dynamic, it:Dynamic, block:Dynamic):Dynamic { return null; }
  75. @:noUsing
  76. macro public static function foreach<T>(v:Expr, it:Expr, b:Expr):haxe.macro.Expr {
  77. var id = switch (v.expr) {
  78. case EConst(CIdent(x)): x;
  79. case _ : Context.error("unexpected " + ExprTools.toString(v) + ": const ident expected", v.pos);
  80. }
  81. var iter = try {
  82. var it = macro ($it.__iter__() : python.NativeIterator.NativeIteratorRaw<T>);
  83. Context.typeof(it);
  84. it;
  85. } catch (e:Dynamic) {
  86. macro ($it : python.NativeIterable.NativeIterableRaw<T>);
  87. }
  88. return macro {
  89. var $id = null;
  90. $self._foreach($v, $it, cast $b);
  91. }
  92. }
  93. @:noUsing macro public static function importFromAs (from:String, module:String, className : String):haxe.macro.Expr {
  94. var n = className.split(".").join("_");
  95. var e = "from " + from + " import " + module + " as " + n;
  96. return macro ($self.pythonCode($v{e}):Void);
  97. }
  98. @:noUsing
  99. macro public static function callField(o:Expr, field:ExprOf<String>, params:Array<Expr>):haxe.macro.Expr {
  100. return macro @:pos(o.pos) $self.call($self.field($o, $field), $a{params});
  101. }
  102. static function call(e:Dynamic, args:Array<Dynamic>):Dynamic { return null; }
  103. @:noUsing
  104. public static function field (o:Dynamic, field:String):Dynamic { return null; }
  105. @:noUsing
  106. macro public static function tuple(args:Array<Expr>):Dynamic {
  107. var args = macro $a{args};
  108. return macro $self._tuple($args);
  109. }
  110. static function _tuple(args:Array<Dynamic>):Dynamic { return null; }
  111. @:noUsing
  112. public static function varArgs(args:Array<Dynamic>):Dynamic { return null; }
  113. macro public static function callNamedUntyped (e:Expr, args:Expr):Expr {
  114. return macro @:pos(e.pos) $self._callNamedUntyped($e, $args);
  115. }
  116. static function _callNamedUntyped(e:Dynamic, args:Dynamic):Dynamic { return null; }
  117. public static function opPow(a:Int, b:Int):Int { return 0; }
  118. }