This commit is contained in:
Dima Granetchi
2015-01-04 15:15:32 +02:00
parent 1b02a0c63b
commit 59f43b07c8
+31 -22
View File
@@ -98,10 +98,12 @@ class BindMacros {
function iter(t:ClassType) { function iter(t:ClassType) {
var meta = t.meta.get(); var meta = t.meta.get();
var m = meta.find(function (it) return it.name == BINDABLE_FIELDS); for (m in meta) if (m.name == BINDABLE_FIELDS) {
if (m != null) for (a in m.params) { for (a in m.params) {
var value = switch a.expr { case EConst(CString(s)): s; case _: null; }; var value = switch a.expr { case EConst(CString(s)): s; case _: null; };
interfaceFields.set(value, t); interfaceFields.set(value, t);
}
break;
} }
for (it in t.interfaces) iter(it.t.get()); for (it in t.interfaces) iter(it.t.get());
} }
@@ -163,13 +165,13 @@ class BindMacros {
case _: case _:
} }
} }
res.push(field); res.push(field);
case FFun(f): case FFun(f):
if (inlineSetter != null) if (inlineSetter != null)
Warn.w('methods doesn\'t support \'$INLINE_SETTER\'', inlineSetter.pos, WarnPriority.INFO); Warn.w('methods doesn\'t support \'$INLINE_SETTER\'', inlineSetter.pos, WarnPriority.INFO);
res.push(field); res.push(field);
} }
} }
static var patchField:Field; static var patchField:Field;
@@ -190,8 +192,8 @@ class BindMacros {
} }
static inline function injectBindableMeta(fields:Array<Field>, meta:MetadataEntry):Void { static inline function injectBindableMeta(fields:Array<Field>, meta:MetadataEntry):Void {
for (f in fields) { for (f in fields) {
if (f.hasBindableMeta()) continue; if (f.hasBindableMeta()) continue;
if (f.access.exists(function (it) return it.equals(APrivate))) continue; if (f.access.exists(function (it) return it.equals(APrivate))) continue;
var forceParam = meta.findParam(FORCE); var forceParam = meta.findParam(FORCE);
@@ -200,29 +202,36 @@ class BindMacros {
case FFun(_): case FFun(_):
case _: f.meta.push({name:MetaUtils.BINDABLE_META, pos:f.pos, params:meta.params}); case _: f.meta.push({name:MetaUtils.BINDABLE_META, pos:f.pos, params:meta.params});
} }
} }
} }
static function isFieldBindable(field:Field, fields:Array<Field>, force = false):Bool { static function isFieldBindable(field:Field, fields:Array<Field>, force = false):Bool {
if (field.name == "new") return false; if (field.name == "new") return false;
if (field.access.exists(function (it) return it.equals(AMacro) || it.equals(ADynamic) || it.equals(AStatic))) return false; for (a in field.access)
if (a.equals(AMacro) || a.equals(ADynamic) || a.equals(AStatic))
return false;
if (field.name.startsWith("set_") || field.name.startsWith("get_")) { if (field.name.startsWith("set_") || field.name.startsWith("get_")) {
var propName = field.name.substr(4); var propName = field.name.substr(4);
if (fields.exists(function(it) return it.name == propName)) return false; for (f in fields) if (f.name == propName) {
} switch (f.kind) {
case FVar(_, _): return false;
case _:
}
}
}
if (!force) { if (!force) {
var meta = field.bindableMeta(); var meta = field.bindableMeta();
var forceParam = meta != null ? meta.findParam(FORCE) : null; var forceParam = meta != null ? meta.findParam(FORCE) : null;
force = forceParam.isNotNullAndTrue(); force = forceParam.isNotNullAndTrue();
} }
if (force)
return switch (field.kind) { if (force) return switch (field.kind) {
case FProp("never", _, _, _): false; case FProp("never", _, _, _): false;
case _: true; case _: true;
} }
return switch (field.kind) { return switch (field.kind) {
case FProp("never", _, _, _) | FProp(_, "never", _, _) | FProp(_, "dynamic", _, _) | FProp(_, "null", _, _): false; case FProp("never", _, _, _) | FProp(_, "never", _, _) | FProp(_, "dynamic", _, _) | FProp(_, "null", _, _): false;