Syntax.hx 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. package python;
  2. #if macro
  3. import haxe.macro.Expr;
  4. import haxe.macro.Context;
  5. import haxe.macro.ExprTools;
  6. #end
  7. extern class Syntax {
  8. #if macro
  9. static var self = macro python.Syntax;
  10. #end
  11. @:noUsing macro public static function importModule (module:String):haxe.macro.Expr {
  12. return macro ($self.pythonCode($v{"import " + module}):Void);
  13. }
  14. @:noUsing macro public static function importAs (module:String, className : String):haxe.macro.Expr
  15. {
  16. var n = className.split(".").join("_");
  17. var e = "import " + module + " as " + n;
  18. var e1 = "_hx_c."+n+" = "+n;
  19. return macro ({
  20. $self.pythonCode($v{e});
  21. $self.pythonCode($v{e1});
  22. }:Void);
  23. }
  24. @:noUsing
  25. macro public static function newInstance (c:Expr, params:Array<Expr>):haxe.macro.Expr {
  26. return macro $self._newInstance($c, $a{params});
  27. }
  28. static function _newInstance(c:Dynamic, args:Array<Dynamic>):Dynamic { return null; }
  29. @:noUsing
  30. public static function isIn(a:Dynamic, b:Dynamic):Bool { return false; }
  31. @:noUsing
  32. public static function delete(a:Dynamic):Void { }
  33. @:noUsing
  34. public static function binop(a:Dynamic, op:String, b:Dynamic):Dynamic { return null; }
  35. @:noUsing
  36. public static function assign(a:Dynamic, b:Dynamic):Void { }
  37. @:noUsing
  38. public static function pythonCode<T>(b:String):T { return null; };
  39. @:noUsing
  40. macro public static function arrayAccess(x:Expr, rest:Array<Expr>):ExprOf<Dynamic> {
  41. return macro $self._arrayAccess($x, $a{rest});
  42. }
  43. @:noUsing
  44. macro public static function arrayAccessWithTrailingColon(x:Expr, rest:Array<Expr>):ExprOf<Dynamic> {
  45. return macro $self._arrayAccess($x, $a{rest}, true);
  46. }
  47. static function _arrayAccess(a:Dynamic, args:Array<Dynamic>, ?trailingColon:Bool = false):Dynamic { return null; }
  48. @:noUsing
  49. public static function arraySet(a:Dynamic, i:Dynamic, v:Dynamic):Dynamic { return null; }
  50. static function _foreach(id:Dynamic, it:Dynamic, block:Dynamic):Dynamic { return null; }
  51. @:noUsing
  52. macro public static function foreach <T>(v:Expr, it:Expr, b:Expr):haxe.macro.Expr
  53. {
  54. var id = switch (v.expr) {
  55. case EConst(CIdent(x)):x;
  56. case _ : Context.error("unexpected " + ExprTools.toString(v) + ": const ident expected", v.pos);
  57. }
  58. var iter = try {
  59. Context.typeof(macro $it.__iter__());
  60. macro $it.__iter__().getNativeIterator();
  61. } catch (e:Dynamic) {
  62. macro $it.getNativeIterator();
  63. };
  64. var res = macro @:pos(it.pos) {
  65. var $id = $iter.__next__();
  66. $it;
  67. $b;
  68. }
  69. try {
  70. Context.typeof(res);
  71. } catch (e:Dynamic) {
  72. Context.error("cannot type the foreach expression", Context.currentPos());
  73. }
  74. return macro {
  75. var $id = null;
  76. $self._foreach($v, $it, $b);
  77. }
  78. }
  79. @:noUsing macro public static function importFromAs (from:String, module:String, className : String):haxe.macro.Expr {
  80. var n = className.split(".").join("_");
  81. var e = "from " + from + " import " + module + " as " + n;
  82. var e1 = "_hx_c."+n+" = " + n;
  83. return macro ({
  84. $self.pythonCode($v{e});
  85. $self.pythonCode($v{e1});
  86. }:Void);
  87. }
  88. @:noUsing
  89. macro public static function callField(o:Expr, field:ExprOf<String>, params:Array<Expr>):haxe.macro.Expr {
  90. return macro @:pos(o.pos) $self.call($self.field($o, $field), $a{params});
  91. }
  92. static function call(e:Dynamic, args:Array<Dynamic>):Dynamic { return null; }
  93. @:noUsing
  94. public static function field (o:Dynamic, field:String):Dynamic { return null; }
  95. @:noUsing
  96. macro public static function tuple(args:Array<Expr>):Dynamic {
  97. var args = macro $a{args};
  98. return macro $self._tuple($args);
  99. }
  100. static function _tuple(args:Array<Dynamic>):Dynamic { return null; }
  101. @:noUsing
  102. public static function varArgs(args:Array<Dynamic>):Dynamic { return null; }
  103. //@:noUsing
  104. //#if !macro macro #end
  105. //public static function callNamed (e:Expr, args:Expr):haxe.macro.Expr {
  106. //
  107. //var fArgs = switch (Context.typeof(e)) {
  108. //case TFun(args, ret): args;
  109. //case _ : haxe.macro.Context.error("e must be of type function", e.pos);
  110. //}
  111. //
  112. //switch (args.expr) {
  113. //case EObjectDecl(fields):
  114. //for (f in fields) {
  115. //var found = false;
  116. //for (a in fArgs) {
  117. //found = a.name == f.field;
  118. //if (found) break;
  119. //}
  120. //if (!found) {
  121. //haxe.macro.Context.error("field " + f.field + " is not a valid argument (valid names " + [for (a in fArgs) a.name].join(",") + ")", args.pos);
  122. //}
  123. //}
  124. //// TODO check at least if fields are valid (maybe if types match);
  125. //case _ : haxe.macro.Context.error("args must be an ObjectDeclaration like { name : 1 }", args.pos);
  126. //}
  127. //return macro @:pos(e.pos) ((untyped __named__)($e, $args):Dynamic);
  128. //}
  129. macro public static function callNamedUntyped (e:Expr, args:Expr):Expr {
  130. return macro @:pos(e.pos) $self._callNamedUntyped($e, $args);
  131. }
  132. static function _callNamedUntyped(e:Dynamic, args:Dynamic):Dynamic { return null; }
  133. public static function opPow(a:Int, b:Int):Int { return 0; }
  134. }