From 5f0f03ebd4c7618b9410c31827c2361d8f6a4eb0 Mon Sep 17 00:00:00 2001 From: Ed Sanders Date: Tue, 18 Jun 2024 18:00:00 +0100 Subject: [PATCH] code: Make isHtmlString a util --- src/rules/no-parse-html-literal.js | 7 ++----- src/utils.js | 11 ++++++++++- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/src/rules/no-parse-html-literal.js b/src/rules/no-parse-html-literal.js index c70c50f..5bea2aa 100644 --- a/src/rules/no-parse-html-literal.js +++ b/src/rules/no-parse-html-literal.js @@ -2,8 +2,6 @@ const utils = require( '../utils.js' ); -// HTML regex (modified from jQuery) -const rquickExpr = /^(?:\s*(<[\w\W]+>)[^>]*)$/; // Single tag regex (from jQuery) const rsingleTag = /^<([a-z][^/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i; const rsingleTagMinimal = /^<([a-z][^/\0>:\x20\t\r\n\f]*)>$/i; @@ -74,11 +72,10 @@ module.exports = { let expectedTag; const arg = node.arguments[ 0 ]; if ( allowSingle ) { - const value = arg && utils.allLiteral( arg ) && utils.joinLiterals( arg ); - if ( !( typeof value === 'string' && value ) || !rquickExpr.exec( value ) ) { - // Empty or non-string, or non-HTML + if ( !utils.isHtmlString( arg ) ) { return; } + const value = utils.joinLiterals( arg ); let match; if ( ( match = rsingleTag.exec( value ) ) ) { // Single tag diff --git a/src/utils.js b/src/utils.js index 029c271..1ae1d07 100644 --- a/src/utils.js +++ b/src/utils.js @@ -562,6 +562,14 @@ function joinLiterals( node ) { } } +// HTML regex (modified from jQuery) +const rquickExpr = /^(?:\s*(<[\w\W]+>)[^>]*)$/; + +function isHtmlString( arg ) { + const value = arg && allLiteral( arg ) && joinLiterals( arg ); + return typeof value === 'string' && value && rquickExpr.exec( value ); +} + module.exports = { isjQuery, isjQueryConstructor, @@ -575,5 +583,6 @@ module.exports = { jQueryCollectionLink, jQueryGlobalLink, allLiteral, - joinLiterals + joinLiterals, + isHtmlString };