X-Git-Url: http://git.roojs.org/?p=gnome.introspection-doc-generator;a=blobdiff_plain;f=JSDOC%2FTokenReader.js;h=cd3b9cb1aced7cea44f8c841ced271f766357af1;hp=e98dbb437b038a35906b9af2f5dd721aacb8db16;hb=HEAD;hpb=0c86ac36a342f6b89ad2c42ca28c64fe06ae2b7f diff --git a/JSDOC/TokenReader.js b/JSDOC/TokenReader.js index e98dbb4..cd3b9cb 100644 --- a/JSDOC/TokenReader.js +++ b/JSDOC/TokenReader.js @@ -258,9 +258,8 @@ const TokenReader = XObject.define( if (this.collapseWhite) { found = "\n"; } - if (this.keepWhite) { - console.log('got here?'); - var last = tokens.pop(); + if (this.keepWhite) { + var last = tokens ? tokens.pop() : false; if (last && last.name != "WHIT") { tokens.push(last); } @@ -465,12 +464,24 @@ const TokenReader = XObject.define( ) ) { var regex = stream.next(); - + var in_brace = false; while (!stream.look().eof) { + + if (stream.look() == "[") { // escape sequence + in_brace = true; + + } + + if (stream.look() == "]") { // escape sequence + in_brace = false; + } + if (stream.look() == "\\") { // escape sequence regex += stream.next(2); + continue; } - else if (stream.look() == "/") { + + if (!in_brace && stream.look() == "/") { regex += stream.next(); while (/[gmi]/.test(stream.look())) { @@ -480,9 +491,9 @@ const TokenReader = XObject.define( tokens.push(new Token(regex, "REGX", "REGX", this.line)); return true; } - else { - regex += stream.next(); - } + + regex += stream.next(); + } // error: unterminated regex }