diff options
author | Steve Block <steveblock@google.com> | 2010-04-27 16:31:00 +0100 |
---|---|---|
committer | Steve Block <steveblock@google.com> | 2010-05-11 14:42:12 +0100 |
commit | dcc8cf2e65d1aa555cce12431a16547e66b469ee (patch) | |
tree | 92a8d65cd5383bca9749f5327fb5e440563926e6 /WebCore/inspector/front-end/SourceHTMLTokenizer.re2js | |
parent | ccac38a6b48843126402088a309597e682f40fe6 (diff) | |
download | external_webkit-dcc8cf2e65d1aa555cce12431a16547e66b469ee.zip external_webkit-dcc8cf2e65d1aa555cce12431a16547e66b469ee.tar.gz external_webkit-dcc8cf2e65d1aa555cce12431a16547e66b469ee.tar.bz2 |
Merge webkit.org at r58033 : Initial merge by git
Change-Id: If006c38561af287c50cd578d251629b51e4d8cd1
Diffstat (limited to 'WebCore/inspector/front-end/SourceHTMLTokenizer.re2js')
-rw-r--r-- | WebCore/inspector/front-end/SourceHTMLTokenizer.re2js | 81 |
1 files changed, 55 insertions, 26 deletions
diff --git a/WebCore/inspector/front-end/SourceHTMLTokenizer.re2js b/WebCore/inspector/front-end/SourceHTMLTokenizer.re2js index cfa8834..44c62b3 100644 --- a/WebCore/inspector/front-end/SourceHTMLTokenizer.re2js +++ b/WebCore/inspector/front-end/SourceHTMLTokenizer.re2js @@ -70,31 +70,43 @@ WebInspector.SourceHTMLTokenizer = function() }; this.initialCondition = { lexCondition: this._lexConditions.INITIAL, parseCondition: this._parseConditions.INITIAL }; + this.condition = this.initialCondition; } WebInspector.SourceHTMLTokenizer.prototype = { + set line(line) { + if (this._internalJavaScriptTokenizer) { + var match = /<\/script/i.exec(line); + if (match) { + this._internalJavaScriptTokenizer.line = line.substring(0, match.index); + } else + this._internalJavaScriptTokenizer.line = line; + } + this._line = line; + }, + _isExpectingAttribute: function() { - return this._parseCondition & this._parseConditions.ATTRIBUTE; + return this._condition.parseCondition & this._parseConditions.ATTRIBUTE; }, _isExpectingAttributeValue: function() { - return this._parseCondition & this._parseConditions.ATTRIBUTE_VALUE; + return this._condition.parseCondition & this._parseConditions.ATTRIBUTE_VALUE; }, _setExpectingAttribute: function() { if (this._isExpectingAttributeValue()) - this._parseCondition ^= this._parseConditions.ATTRIBUTE_VALUE; - this._parseCondition |= this._parseConditions.ATTRIBUTE; + this._condition.parseCondition ^= this._parseConditions.ATTRIBUTE_VALUE; + this._condition.parseCondition |= this._parseConditions.ATTRIBUTE; }, _setExpectingAttributeValue: function() { if (this._isExpectingAttribute()) - this._parseCondition ^= this._parseConditions.ATTRIBUTE; - this._parseCondition |= this._parseConditions.ATTRIBUTE_VALUE; + this._condition.parseCondition ^= this._parseConditions.ATTRIBUTE; + this._condition.parseCondition |= this._parseConditions.ATTRIBUTE_VALUE; }, _stringToken: function(cursor, stringEnds) @@ -111,8 +123,8 @@ WebInspector.SourceHTMLTokenizer.prototype = { _attrValueTokenType: function() { - if (this._parseCondition & this._parseConditions.LINKIFY) { - if (this._parseCondition & this._parseConditions.A_NODE) + if (this._condition.parseCondition & this._parseConditions.LINKIFY) { + if (this._condition.parseCondition & this._parseConditions.A_NODE) return "html-external-link"; return "html-resource-link"; } @@ -121,6 +133,20 @@ WebInspector.SourceHTMLTokenizer.prototype = { nextToken: function(cursor) { + if (this._internalJavaScriptTokenizer) { + // Re-set line to force </script> detection first. + this.line = this._line; + if (cursor !== this._internalJavaScriptTokenizer._line.length) { + // Tokenizer is stateless, so restore its condition before tokenizing and save it after. + this._internalJavaScriptTokenizer.condition = this._condition.internalJavaScriptTokenizerCondition; + var result = this._internalJavaScriptTokenizer.nextToken(cursor); + this.tokenType = this._internalJavaScriptTokenizer.tokenType; + this._condition.internalJavaScriptTokenizerCondition = this._internalJavaScriptTokenizer.condition; + return result; + } else if (cursor !== this._line.length) + delete this._internalJavaScriptTokenizer; + } + var cursorOnEnter = cursor; var gotoCase = 1; while (1) { @@ -174,14 +200,14 @@ WebInspector.SourceHTMLTokenizer.prototype = { <INITIAL> ScriptStart => TAG { - if (this._parseCondition & this._parseConditions.SCRIPT) { + if (this._condition.parseCondition & this._parseConditions.SCRIPT) { // Do not tokenize script tag contents, keep lexer state although processing "<". this.setLexCondition(this._lexConditions.INITIAL); this.tokenType = null; return cursor; } this.tokenType = "html-tag"; - this._parseCondition = this._parseConditions.SCRIPT; + this._condition.parseCondition = this._parseConditions.SCRIPT; this._setExpectingAttribute(); return cursor; } @@ -189,34 +215,37 @@ WebInspector.SourceHTMLTokenizer.prototype = { <INITIAL> ScriptEnd => TAG { this.tokenType = "html-tag"; - this._parseCondition = this._parseConditions.INITIAL; + this._condition.parseCondition = this._parseConditions.INITIAL; return cursor; } <INITIAL> LT => TAG { - if (this._parseCondition & this._parseConditions.SCRIPT) { + if (this._condition.parseCondition & this._parseConditions.SCRIPT) { // Do not tokenize script tag contents, keep lexer state although processing "<". this.setLexCondition(this._lexConditions.INITIAL); this.tokenType = null; return cursor; } - this._parseCondition = this._parseConditions.INITIAL; + this._condition.parseCondition = this._parseConditions.INITIAL; this.tokenType = "html-tag"; return cursor; } - + <TAG> GT => INITIAL { - if (this._parseCondition & this._parseConditions.SCRIPT) { + this.tokenType = "html-tag"; + if (this._condition.parseCondition & this._parseConditions.SCRIPT) { + if (!this._internalJavaScriptTokenizer) { + this._internalJavaScriptTokenizer = WebInspector.SourceTokenizer.Registry.getInstance().getTokenizer("text/javascript"); + this._condition.internalJavaScriptTokenizerCondition = this._internalJavaScriptTokenizer.initialCondition; + } // Do not tokenize script tag contents. - this.tokenType = null; return cursor; } - this._parseCondition = this._parseConditions.INITIAL; - this.tokenType = "html-tag"; + this._condition.parseCondition = this._parseConditions.INITIAL; return cursor; } @@ -238,26 +267,26 @@ WebInspector.SourceHTMLTokenizer.prototype = { <TAG> Identifier { - if (this._parseCondition === this._parseConditions.SCRIPT) { + if (this._condition.parseCondition === this._parseConditions.SCRIPT) { // Fall through if expecting attributes. this.tokenType = null; return cursor; } - if (this._parseCondition === this._parseConditions.INITIAL) { + if (this._condition.parseCondition === this._parseConditions.INITIAL) { this.tokenType = "html-tag"; this._setExpectingAttribute(); var token = this._line.substring(cursorOnEnter, cursor); if (token === "a") - this._parseCondition |= this._parseConditions.A_NODE; - else if (this._parseCondition & this._parseConditions.A_NODE) - this._parseCondition ^= this._parseConditions.A_NODE; + this._condition.parseCondition |= this._parseConditions.A_NODE; + else if (this._condition.parseCondition & this._parseConditions.A_NODE) + this._condition.parseCondition ^= this._parseConditions.A_NODE; } else if (this._isExpectingAttribute()) { var token = this._line.substring(cursorOnEnter, cursor); if (token === "href" || token === "src") - this._parseCondition |= this._parseConditions.LINKIFY; - else if (this._parseCondition |= this._parseConditions.LINKIFY) - this._parseCondition ^= this._parseConditions.LINKIFY; + this._condition.parseCondition |= this._parseConditions.LINKIFY; + else if (this._condition.parseCondition |= this._parseConditions.LINKIFY) + this._condition.parseCondition ^= this._parseConditions.LINKIFY; this.tokenType = "html-attribute-name"; } else if (this._isExpectingAttributeValue()) this.tokenType = this._attrValueTokenType(); |