1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- /**
- * @author Toru Nagashima <https://github.com/mysticatea>
- * See LICENSE file in root directory for full license.
- */
- "use strict"
- const { RegExpValidator } = require("regexpp")
- const { getRegExpCalls } = require("../utils")
- /**
- * Verify a given regular expression.
- * @param {RuleContext} context The rule context to report.
- * @param {Node} node The AST node to report.
- * @param {string} pattern The pattern part of a RegExp.
- * @param {string} flags The flags part of a RegExp.
- * @returns {void}
- */
- function verify(context, node, pattern, flags) {
- try {
- let found = false
- new RegExpValidator({
- onLookaroundAssertionEnter(_start, kind) {
- if (kind === "lookbehind") {
- found = true
- }
- },
- }).validatePattern(pattern, 0, pattern.length, flags.includes("u"))
- if (found) {
- context.report({ node, messageId: "forbidden" })
- }
- } catch (error) {
- //istanbul ignore else
- if (error.message.startsWith("Invalid regular expression:")) {
- return
- }
- //istanbul ignore next
- throw error
- }
- }
- module.exports = {
- meta: {
- docs: {
- description: "disallow RegExp lookbehind assertions.",
- category: "ES2018",
- recommended: false,
- url:
- "http://mysticatea.github.io/eslint-plugin-es/rules/no-regexp-lookbehind-assertions.html",
- },
- fixable: null,
- messages: {
- forbidden: "ES2018 RegExp lookbehind assertions are forbidden.",
- },
- schema: [],
- type: "problem",
- },
- create(context) {
- return {
- "Literal[regex]"(node) {
- const { pattern, flags } = node.regex
- verify(context, node, pattern || "", flags || "")
- },
- "Program:exit"() {
- const scope = context.getScope()
- for (const { node, pattern, flags } of getRegExpCalls(scope)) {
- verify(context, node, pattern || "", flags || "")
- }
- },
- }
- },
- }
|