[ruby-dev:50031] [Ruby trunk Bug#13352] RegExp infinite looping

From: duerst@...
Date: 2017-03-22 10:55:17 UTC
List: ruby-dev #50031
Issue #13352 has been updated by duerst (Martin D=C3=BCrst).


I haven't yet had time to analyze the regular expression in detail. Are you=
 sure this is really an infinite loop, and not just a case of exponentially=
 slow processing (e.g. similar to stackoverflow.com/questions/16580665/node=
-js-regex-engine-fails-on-large-input)?

----------------------------------------
Bug #13352: RegExp infinite looping
https://bugs.ruby-lang.org/issues/13352#change-63729

* Author: jumnichi_kose (=E5=B0=8F=E7=80=AC =E6=B7=B3=E4=B8=80)
* Status: Open
* Priority: Normal
* Assignee:=20
* Target version:=20
* ruby -v: 2.3.3p222 (2016-11-21 revision 56859) [x64-mingw32],  ruby 2.2.4=
p230 (2015-12-16 revision 53155) [i386-mingw32]
* Backport: 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: UNKNOWN
----------------------------------------
ruby entered an infinite loop with the following three steps.

~~~ ruby
r =3D /(?=3D\W)\W?(?:(?:(?:\/\*<)?[\'\"]?([\w_\$]+)[\'\"]?(?:>\*\/\s+this)?=
|(this))\.(\$scope|json)|([\'\"](?:\$scope|json)[\'\"]))((\.)(inputObjects)=
|(\.)(spreadSheets)(?:\.[\'\"]?([^\.\'\"\|\s,]+)[\'\"]?|\[[\'\"]?((?:[^\'\"=
\]\[]*|\[[^\]]*\])*)[\'\"]?\])(\.)(model))\s*(?:\.[\'\"]?([^\.\'\"\|\s,]+)[=
\'\"]?|\[[\'\"]?((?:[^\'\"\]\[]*|\[[^\]]*\])*)[\'\"]?\])/
txt =3D ".model |,| 'anController'.$scope.inputObjects['fieldName .../* !! =
comment ...*/"
txt.scan r
~~~

Node.js also falls into an infinite loop.
~~~ javascript
var r =3D /(?=3D\W)\W?(?:(?:(?:\/\*<)?[\'\"]?([\w_\$]+)[\'\"]?(?:>\*\/\s+th=
is)?|(this))\.(\$scope|json)|([\'\"](?:\$scope|json)[\'\"]))((\.)(inputObje=
cts)|(\.)(spreadSheets)(?:\.[\'\"]?([^\.\'\"\|\s,]+)[\'\"]?|\[[\'\"]?((?:[^=
\'\"\]\[]*|\[[^\]]*\])*)[\'\"]?\])(\.)(model))\s*(?:\.[\'\"]?([^\.\'\"\|\s,=
]+)[\'\"]?|\[[\'\"]?((?:[^\'\"\]\[]*|\[[^\]]*\])*)[\'\"]?\])/
var txt =3D ".model |,| 'anController'.$scope.inputObjects['fieldName .../*=
 !! comment ...*/"

var s =3Dr.exec (txt)

console.log(s)


~~~





--=20
https://bugs.ruby-lang.org/

In This Thread

Prev Next