blob: 1446632f39807a9a306e1a7daa2aacc74b8a73f3 [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
4
Tim van der Lippe2c891972021-07-29 16:22:50 +01005const pattern = /(^|;)\s*(export|import)((\s+\w)|(\s*[{*=]))/m;
Tim van der Lippefdbd42e2020-04-07 15:14:36 +01006/**
7 * detect possible imports/exports without a full parse.
8 *
9 * A negative test means that a file is definitely _not_ a module.
10 * A positive test means it _could_ be.
11 *
12 * Not perfect, just a fast way to disqualify large non-ES6 modules and
13 * avoid a parse.
14 * @type {RegExp}
15 */
16exports.test = function isMaybeUnambiguousModule(content) {
Tim van der Lippe2c891972021-07-29 16:22:50 +010017 return pattern.test(content);
18};
Tim van der Lippefdbd42e2020-04-07 15:14:36 +010019
20// future-/Babel-proof at the expense of being a little loose
Tim van der Lippe2c891972021-07-29 16:22:50 +010021const unambiguousNodeType = /^(?:(?:Exp|Imp)ort.*Declaration|TSExportAssignment)$/;
Tim van der Lippefdbd42e2020-04-07 15:14:36 +010022
23/**
24 * Given an AST, return true if the AST unambiguously represents a module.
25 * @param {Program node} ast
26 * @return {Boolean}
27 */
28exports.isModule = function isUnambiguousModule(ast) {
Tim van der Lippe2c891972021-07-29 16:22:50 +010029 return ast.body.some(node => unambiguousNodeType.test(node.type));
30};