diff options
Diffstat (limited to 'sonar-channel')
-rw-r--r-- | sonar-channel/src/main/java/org/sonar/channel/CodeBuffer.java | 45 | ||||
-rw-r--r-- | sonar-channel/src/test/java/org/sonar/channel/CodeBufferTest.java | 16 |
2 files changed, 52 insertions, 9 deletions
diff --git a/sonar-channel/src/main/java/org/sonar/channel/CodeBuffer.java b/sonar-channel/src/main/java/org/sonar/channel/CodeBuffer.java index a8433264b7a..34cdb51ad1d 100644 --- a/sonar-channel/src/main/java/org/sonar/channel/CodeBuffer.java +++ b/sonar-channel/src/main/java/org/sonar/channel/CodeBuffer.java @@ -85,6 +85,15 @@ public class CodeBuffer implements CharSequence { return -1; } int character = buffer[bufferPosition++]; + updateCursorPosition(character); + if (recordingMode) { + recordedCharacters.append((char) character); + } + lastChar = character; + return character; + } + + private final void updateCursorPosition(int character) { if (character == LF || character == CR) { if ((lastChar != LF && lastChar != CR) || lastChar == character || lastChar == LF) { cursor.line++; @@ -95,11 +104,6 @@ public class CodeBuffer implements CharSequence { } else { cursor.column++; } - if (recordingMode) { - recordedCharacters.append((char) character); - } - lastChar = character; - return character; } private int fillBuffer() { @@ -121,7 +125,7 @@ public class CodeBuffer implements CharSequence { } /** - * Get the last consumed character + * Looks at the last consumed character * * @return the last character or -1 if the no character has been yet consumed */ @@ -130,15 +134,40 @@ public class CodeBuffer implements CharSequence { } /** - * Read without consuming the next character + * Looks at the next character without consuming it * - * @return the next character or -1 if the end of the stream is reached + * @return the next character or -1 if the end of the stream has been reached */ public final int peek() { return intAt(0); } /** + * Pushes a character sequence onto the top of this CodeBuffer. This characters will be then the first to be read. + * + * @param chars + * the character sequences to push into the CodeBuffer + */ + public void push(CharSequence chars) { + int length = chars.length(); + if (bufferPosition >= length) { + for (int index = 0; index < length; index++) { + buffer[bufferPosition + index - length] = chars.charAt(index); + } + bufferPosition -= length; + } else { + char[] extendedBuffer = new char[buffer.length - bufferPosition + length]; + for (int index = 0; index < length; index++) { + extendedBuffer[index] = chars.charAt(index); + } + System.arraycopy(buffer, bufferPosition, extendedBuffer, length, bufferSize - bufferPosition); + buffer = extendedBuffer; + bufferSize = bufferSize + length - bufferPosition; + bufferPosition = 0; + } + } + + /** * Close the stream */ public final void close() { diff --git a/sonar-channel/src/test/java/org/sonar/channel/CodeBufferTest.java b/sonar-channel/src/test/java/org/sonar/channel/CodeBufferTest.java index d9ce7fe570b..98ffb19af42 100644 --- a/sonar-channel/src/test/java/org/sonar/channel/CodeBufferTest.java +++ b/sonar-channel/src/test/java/org/sonar/channel/CodeBufferTest.java @@ -31,7 +31,7 @@ import org.junit.Test; public class CodeBufferTest { private CodeReaderConfiguration defaulConfiguration = new CodeReaderConfiguration(); - + @Test public void testPop() { CodeBuffer code = new CodeBuffer("pa", defaulConfiguration); @@ -117,6 +117,20 @@ public class CodeBufferTest { } @Test + public void testPush() { + CodeReader reader = new CodeReader("12", defaulConfiguration); + assertEquals('1', (char) reader.pop()); + reader.push("a"); + assertEquals('a', (char) reader.peek()); + reader.push("45"); + assertEquals("45a2", new String(reader.peek(4))); + for (int i = 0; i < 4; i++) { + reader.pop(); + } + assertEquals( -1, reader.pop()); + } + + @Test public void testCharAtIndexOutOfBoundsException() { CodeBuffer reader = new CodeBuffer("12345", defaulConfiguration); assertEquals(reader.charAt(5), (char) -1); |