Minor API improvement.
This commit is contained in:
@@ -5,6 +5,13 @@ import haxe.macro.Expr;
|
|||||||
import haxe.macro.Type;
|
import haxe.macro.Type;
|
||||||
import tink.macro.TypeMap;
|
import tink.macro.TypeMap;
|
||||||
|
|
||||||
|
typedef BuildContext = {
|
||||||
|
pos:Position,
|
||||||
|
type:Type,
|
||||||
|
usings:Array<TypePath>,
|
||||||
|
name:String,
|
||||||
|
}
|
||||||
|
|
||||||
class BuildCache {
|
class BuildCache {
|
||||||
|
|
||||||
static var cache = init();
|
static var cache = init();
|
||||||
@@ -22,7 +29,7 @@ class BuildCache {
|
|||||||
return cache;
|
return cache;
|
||||||
}
|
}
|
||||||
|
|
||||||
static public function getType(name, ?type, ?pos:Position, build:Position->Type->Array<TypePath>->String->TypeDefinition) {
|
static public function getType(name, ?type, ?pos:Position, build:BuildContext->TypeDefinition) {
|
||||||
|
|
||||||
if (pos == null)
|
if (pos == null)
|
||||||
pos = Context.currentPos();
|
pos = Context.currentPos();
|
||||||
@@ -45,7 +52,12 @@ class BuildCache {
|
|||||||
var path = '$name${Lambda.count(forName)}',
|
var path = '$name${Lambda.count(forName)}',
|
||||||
usings = [];
|
usings = [];
|
||||||
|
|
||||||
var def = build(pos, type, usings, path.split('.').pop());
|
var def = build({
|
||||||
|
pos: pos,
|
||||||
|
type: type,
|
||||||
|
usings: usings,
|
||||||
|
name: path.split('.').pop()
|
||||||
|
});
|
||||||
|
|
||||||
Context.defineModule(path, [def], usings);
|
Context.defineModule(path, [def], usings);
|
||||||
forName.set(type, Context.getType(path));
|
forName.set(type, Context.getType(path));
|
||||||
|
|||||||
Reference in New Issue
Block a user