From 0200a3e510389a901680dd44ca8ae7bcd1d2e028 Mon Sep 17 00:00:00 2001 From: Justin Ridgewell Date: Fri, 18 May 2018 14:41:19 -0400 Subject: [PATCH] Build InterfaceTypeAnnotation generated type code (#7982) --- .../src/asserts/generated/index.js | 6 ++++++ .../src/builders/generated/index.js | 4 ++++ .../src/validators/generated/index.js | 19 +++++++++++++++++++ 3 files changed, 29 insertions(+) diff --git a/packages/babel-types/src/asserts/generated/index.js b/packages/babel-types/src/asserts/generated/index.js index da4d956f2d67..361f106d4235 100644 --- a/packages/babel-types/src/asserts/generated/index.js +++ b/packages/babel-types/src/asserts/generated/index.js @@ -414,6 +414,12 @@ export function assertInterfaceDeclaration( ): void { assert("InterfaceDeclaration", node, opts); } +export function assertInterfaceTypeAnnotation( + node: Object, + opts?: Object = {}, +): void { + assert("InterfaceTypeAnnotation", node, opts); +} export function assertIntersectionTypeAnnotation( node: Object, opts?: Object = {}, diff --git a/packages/babel-types/src/builders/generated/index.js b/packages/babel-types/src/builders/generated/index.js index ce88f96cf7b5..8015666abe11 100644 --- a/packages/babel-types/src/builders/generated/index.js +++ b/packages/babel-types/src/builders/generated/index.js @@ -393,6 +393,10 @@ export function InterfaceDeclaration(...args: Array): Object { return builder("InterfaceDeclaration", ...args); } export { InterfaceDeclaration as interfaceDeclaration }; +export function InterfaceTypeAnnotation(...args: Array): Object { + return builder("InterfaceTypeAnnotation", ...args); +} +export { InterfaceTypeAnnotation as interfaceTypeAnnotation }; export function IntersectionTypeAnnotation(...args: Array): Object { return builder("IntersectionTypeAnnotation", ...args); } diff --git a/packages/babel-types/src/validators/generated/index.js b/packages/babel-types/src/validators/generated/index.js index 06f1d9b5a03c..63f16c583159 100644 --- a/packages/babel-types/src/validators/generated/index.js +++ b/packages/babel-types/src/validators/generated/index.js @@ -1387,6 +1387,23 @@ export function isInterfaceDeclaration(node: Object, opts?: Object): boolean { return false; } +export function isInterfaceTypeAnnotation( + node: Object, + opts?: Object, +): boolean { + if (!node) return false; + + const nodeType = node.type; + if (nodeType === "InterfaceTypeAnnotation") { + if (typeof opts === "undefined") { + return true; + } else { + return shallowEqual(node, opts); + } + } + + return false; +} export function isIntersectionTypeAnnotation( node: Object, opts?: Object, @@ -3840,6 +3857,7 @@ export function isFlow(node: Object, opts?: Object): boolean { "InferredPredicate" === nodeType || "InterfaceExtends" === nodeType || "InterfaceDeclaration" === nodeType || + "InterfaceTypeAnnotation" === nodeType || "IntersectionTypeAnnotation" === nodeType || "MixedTypeAnnotation" === nodeType || "EmptyTypeAnnotation" === nodeType || @@ -3892,6 +3910,7 @@ export function isFlowType(node: Object, opts?: Object): boolean { "ExistsTypeAnnotation" === nodeType || "FunctionTypeAnnotation" === nodeType || "GenericTypeAnnotation" === nodeType || + "InterfaceTypeAnnotation" === nodeType || "IntersectionTypeAnnotation" === nodeType || "MixedTypeAnnotation" === nodeType || "EmptyTypeAnnotation" === nodeType ||