From 9e33a5f2e55689e44dc9c5436391a018ee36dcd2 Mon Sep 17 00:00:00 2001 From: axelcl Date: Mon, 19 Dec 2005 20:34:36 +0000 Subject: [PATCH] Fix bug #1385272: Parsing of short open tags not fully compatible to PHP parse --- .../phpdt/internal/compiler/parser/Parser.java | 16 +--------- .../phpdt/internal/compiler/parser/Scanner.java | 31 +++++++++++-------- 2 files changed, 20 insertions(+), 27 deletions(-) diff --git a/net.sourceforge.phpeclipse/src/net/sourceforge/phpdt/internal/compiler/parser/Parser.java b/net.sourceforge.phpeclipse/src/net/sourceforge/phpdt/internal/compiler/parser/Parser.java index 1a3da1e..3c7c661 100644 --- a/net.sourceforge.phpeclipse/src/net/sourceforge/phpdt/internal/compiler/parser/Parser.java +++ b/net.sourceforge.phpeclipse/src/net/sourceforge/phpdt/internal/compiler/parser/Parser.java @@ -745,26 +745,14 @@ public class Parser implements ITerminalSymbols, CompilerModifiers, ParserBasicI if (token == TokenNameSEMICOLON) { getNextToken(); } else { - if (token != TokenNameINLINE_HTML ) { + if (token != TokenNameINLINE_HTML) { throwSyntaxError("';' expected after 'echo' statement."); } getNextToken(); } return statement; } else if (token == TokenNameINLINE_HTML) { -// if (scanner.phpExpressionTag) { -// // start of block -// getNextToken(); -// expr(); -// if (token == TokenNameSEMICOLON) { -// getNextToken(); -// } -// if (token != TokenNameINLINE_HTML) { -// throwSyntaxError("Missing '?>' for open PHP expression block (' source.length) { currentPosition = source.length; return TokenNameEOF; @@ -3545,11 +3548,12 @@ public class Scanner implements IScanner, ITerminalSymbols { case 's': // self static switch switch (length) { -// case 4: -// if ((data[++index] == 'e') && (data[++index] == 'l') && (data[++index] == 'f')) { -// return TokenNameself; -// } -// return TokenNameIdentifier; + // case 4: + // if ((data[++index] == 'e') && (data[++index] == 'l') && (data[++index] + // == 'f')) { + // return TokenNameself; + // } + // return TokenNameIdentifier; case 6: if (data[++index] == 't') if ((data[++index] == 'a') && (data[++index] == 't') && (data[++index] == 'i') && (data[++index] == 'c')) { @@ -3843,6 +3847,7 @@ public class Scanner implements IScanner, ITerminalSymbols { initialPosition = currentPosition = 0; containsAssertKeyword = false; withoutUnicodeBuffer = new char[this.source.length]; + fFillerToken = TokenNameEOF; // encapsedStringStack = new Stack(); } @@ -3977,8 +3982,8 @@ public class Scanner implements IScanner, ITerminalSymbols { return "require_once"; //$NON-NLS-1$ case TokenNamereturn: return "return"; //$NON-NLS-1$ -// case TokenNameself: -// return "self"; //$NON-NLS-1$ + // case TokenNameself: + // return "self"; //$NON-NLS-1$ case TokenNamestatic: return "static"; //$NON-NLS-1$ case TokenNameswitch: -- 1.7.1