8073653: Secondary heredoc eating wrong lines

Reviewed-by: mhaupt, jlaskey
This commit is contained in:
Hannes Wallnöfer 2016-06-24 14:46:45 +02:00
parent 939f1f7308
commit 4f3b48809e
3 changed files with 81 additions and 2 deletions

View File

@ -609,6 +609,9 @@ public class Lexer extends Scanner {
if (stream.get(stream.last()) != token) { if (stream.get(stream.last()) != token) {
return false; return false;
} }
// Record current position in case multiple heredocs start on this line - see JDK-8073653
final State state = saveState();
// Rewind to token start position // Rewind to token start position
reset(Token.descPosition(token)); reset(Token.descPosition(token));
@ -616,7 +619,7 @@ public class Lexer extends Scanner {
return scanRegEx(); return scanRegEx();
} else if (ch0 == '<') { } else if (ch0 == '<') {
if (ch1 == '<') { if (ch1 == '<') {
return scanHereString(lir); return scanHereString(lir, state);
} else if (Character.isJavaIdentifierStart(ch1)) { } else if (Character.isJavaIdentifierStart(ch1)) {
return scanXMLLiteral(); return scanXMLLiteral();
} }
@ -1539,7 +1542,7 @@ public class Lexer extends Scanner {
* *
* @return TRUE if is a here string. * @return TRUE if is a here string.
*/ */
private boolean scanHereString(final LineInfoReceiver lir) { private boolean scanHereString(final LineInfoReceiver lir, final State oldState) {
assert ch0 == '<' && ch1 == '<'; assert ch0 == '<' && ch1 == '<';
if (scripting) { if (scripting) {
// Record beginning of here string. // Record beginning of here string.
@ -1589,6 +1592,11 @@ public class Lexer extends Scanner {
int lastLinePosition = position; int lastLinePosition = position;
restState.setLimit(position); restState.setLimit(position);
if (oldState.position > position) {
restoreState(oldState);
skipLine(false);
}
// Record beginning of string. // Record beginning of string.
final State stringState = saveState(); final State stringState = saveState();
int stringEnd = position; int stringEnd = position;

View File

@ -0,0 +1,59 @@
/*
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/**
* JDK-8073653: Secondary heredoc eating wrong lines.
*
* @test
* @run
* @option -scripting
*/
print(<<EOD1); print(<<EOD2.toUpperCase()); var a = <<EOD3, b = <<EOD4.toLowerCase(), c = [<<EOD5, <<EOD6];
This is line 1.
This is line 2.
EOD1
This is line 3.
This is line 4.
EOD2
This is line 5.
This is line 6.
EOD3
This is line 7.
This is line 8.
EOD4
This is line 9.
This is line 10.
EOD5
This is line 11.
This is line 12.
EOD6
print(a);
print(b);
for (var i in c) {
print(c[i]);
}

View File

@ -0,0 +1,12 @@
This is line 1.
This is line 2.
THIS IS LINE 3.
THIS IS LINE 4.
This is line 5.
This is line 6.
this is line 7.
this is line 8.
This is line 9.
This is line 10.
This is line 11.
This is line 12.