Skip to content

Commit 6099321

Browse files
committed
cache isInterpretedAsRegExp
1 parent 01e345c commit 6099321

File tree

2 files changed

+5
-0
lines changed

2 files changed

+5
-0
lines changed

javascript/ql/lib/semmle/javascript/Regexp.qll

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@
77

88
import javascript
99
private import semmle.javascript.dataflow.InferredTypes
10+
private import semmle.javascript.internal.CachedStages
1011

1112
/**
1213
* An element containing a regular expression term, that is, either
@@ -955,7 +956,9 @@ private predicate isUsedAsNonMatchObject(DataFlow::MethodCallNode call) {
955956
/**
956957
* Holds if `source` may be interpreted as a regular expression.
957958
*/
959+
cached
958960
predicate isInterpretedAsRegExp(DataFlow::Node source) {
961+
Stages::Taint::ref() and
959962
source.analyze().getAType() = TTString() and
960963
(
961964
// The first argument to an invocation of `RegExp` (with or without `new`).

javascript/ql/lib/semmle/javascript/internal/CachedStages.qll

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -260,6 +260,8 @@ module Stages {
260260
exists(RemoteFlowSource r)
261261
or
262262
exists(Exports::getALibraryInputParameter())
263+
or
264+
any(RegExpTerm t).isUsedAsRegExp()
263265
}
264266
}
265267
}

0 commit comments

Comments
 (0)