blob: 75f21693b72fb8252193b13ae52adc222e2e5e97 [file] [log] [blame]
Tim van der Lippe2c891972021-07-29 16:22:50 +01001'use strict';
2exports.__esModule = true;
Tim van der Lippefdbd42e2020-04-07 15:14:36 +01003
Tim van der Lippebc3a0b72021-11-08 15:22:37 +00004const pattern = /(^|;)\s*(export|import)((\s+\w)|(\s*[{*=]))|import\(/m;
Tim van der Lippefdbd42e2020-04-07 15:14:36 +01005/**
6 * detect possible imports/exports without a full parse.
7 *
8 * A negative test means that a file is definitely _not_ a module.
9 * A positive test means it _could_ be.
10 *
11 * Not perfect, just a fast way to disqualify large non-ES6 modules and
12 * avoid a parse.
13 * @type {RegExp}
14 */
15exports.test = function isMaybeUnambiguousModule(content) {
Tim van der Lippe2c891972021-07-29 16:22:50 +010016 return pattern.test(content);
17};
Tim van der Lippefdbd42e2020-04-07 15:14:36 +010018
19// future-/Babel-proof at the expense of being a little loose
Tim van der Lippe2c891972021-07-29 16:22:50 +010020const unambiguousNodeType = /^(?:(?:Exp|Imp)ort.*Declaration|TSExportAssignment)$/;
Tim van der Lippefdbd42e2020-04-07 15:14:36 +010021
22/**
23 * Given an AST, return true if the AST unambiguously represents a module.
24 * @param {Program node} ast
25 * @return {Boolean}
26 */
27exports.isModule = function isUnambiguousModule(ast) {
Tim van der Lippebc3a0b72021-11-08 15:22:37 +000028 return ast.body && ast.body.some(node => unambiguousNodeType.test(node.type));
Tim van der Lippe2c891972021-07-29 16:22:50 +010029};