Syntax.hx 4.8 KB

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