Syntax.hx 4.3 KB

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