我使用haxe宏将getter和setter添加到变量中,现在我试图从新生成的setter中调用静态函数:
public static function build():Array<Field> {
//.........
// create setter
var setterBody = macro {
$variableRef = v;
// mypackage.MyClass.myFunc(this) <-------- DOES NOT WORK!!
return $variableRef;
};
newFields.push({
pos: Context.currentPos(),
name: "set_" + field.name,
meta: [],
kind: FieldType.FFun({
ret: readType,
params: [],
expr: setterBody,
args: [{
value: null,
type: readType,
opt: false,
name: "v"
}]
}),
doc: "",
access: []
});
在上面的代码中,我找不到调用MyClass.myFun(this)
的方法,我不知道如何为setter生成代码,this
指的是实例调用setter的对象。
非常感谢。
答案 0 :(得分:3)
如果没有更完整的例子,很难知道出了什么问题。我能做的就是向你展示有效的代码:
<强> TiagoLrMacroTest.hx 强>:
@:build( TiagoLrMacro.build() )
class TiagoLrMacroTest {
public static function main() {
var test = new TiagoLrMacroTest();
test.name = "hello";
}
function new() {}
public var name(default,set):String;
}
class MyStaticClass {
public static function staticMethod( a:TiagoLrMacroTest ) {
trace( a.name );
}
}
<强> TiagoLrMacro.hx 强>
import haxe.macro.Expr;
import haxe.macro.Context;
class TiagoLrMacro {
public static function build():Array<Field> {
var fields = Context.getBuildFields();
var setterBody = macro {
name = v;
TiagoLrMacroTest.MyStaticClass.staticMethod( this );
return name;
};
fields.push({
pos: Context.currentPos(),
name: "set_name",
meta: [],
kind: FieldType.FFun({
ret: macro :String,
params: [],
expr: setterBody,
args: [{
value: null,
type: macro :String,
opt: false,
name: "v"
}]
}),
doc: "",
access: []
});
return fields;
}
}
结果(Haxe 3.1.3):
TiagoLrMacroTest.hx:15: hello
我在宏中调用静态方法遇到的一个常见问题是导入不受尊重,所以你必须使用像mypackage.MyClass.myFunc(this)
这样的完整类型路径,但是你已经这样做了,所以错误必须是你代码中的其他地方。快乐宏观:)