add type inferrence for template literals
This commit is contained in:
parent
b0e58f9770
commit
bc4258eca9
@ -190,6 +190,10 @@ export function _inferTypeAnnotation(force?: boolean): ?Object {
|
|||||||
return t.genericTypeAnnotation(t.identifier("Function"));
|
return t.genericTypeAnnotation(t.identifier("Function"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (path.isTemplateLiteral()) {
|
||||||
|
return t.stringTypeAnnotation();
|
||||||
|
}
|
||||||
|
|
||||||
if (path.isUnaryExpression()) {
|
if (path.isUnaryExpression()) {
|
||||||
let operator = node.operator;
|
let operator = node.operator;
|
||||||
|
|
||||||
@ -273,10 +277,13 @@ export function _inferTypeAnnotation(force?: boolean): ?Object {
|
|||||||
if (node.regex) return t.genericTypeAnnotation(t.identifier("RegExp"));
|
if (node.regex) return t.genericTypeAnnotation(t.identifier("RegExp"));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (path.isCallExpression()) {
|
var callPath;
|
||||||
var callee = path.get("callee").resolve();
|
if (path.isCallExpression()) callPath = path.get("callee");
|
||||||
|
if (path.isTaggedTemplateExpression()) callPath = path.get("tag");
|
||||||
|
if (callPath) {
|
||||||
|
callPath = callPath.resolve();
|
||||||
// todo: read typescript/flow interfaces
|
// todo: read typescript/flow interfaces
|
||||||
if (callee.isNodeType("Function")) return callee.node.returnType;
|
if (callPath.isNodeType("Function")) return callee.node.returnType;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user