Skip to content

Commit

Permalink
Fixed issue #603 (#604)
Browse files Browse the repository at this point in the history
Fixed issue #603 (location offset regression in 2.10.1)
  • Loading branch information
fabienrenaud authored Feb 26, 2020
1 parent 7fe4494 commit 993d66a
Show file tree
Hide file tree
Showing 3 changed files with 78 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -221,9 +221,6 @@ protected boolean _loadMore() throws IOException
if (_reader != null) {
int count = _reader.read(_inputBuffer, 0, _inputBuffer.length);
if (count > 0) {
_inputPtr = 0;
_inputEnd = count;

_currInputProcessed += bufSize;
_currInputRowStart -= bufSize;

Expand All @@ -232,6 +229,9 @@ protected boolean _loadMore() throws IOException
// in negative value, which is fine as combine value remains unchanged.
_nameStartOffset -= bufSize;

_inputPtr = 0;
_inputEnd = count;

return true;
}
// End of input
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -193,9 +193,6 @@ protected final boolean _loadMore() throws IOException

int count = _inputStream.read(_inputBuffer, 0, space);
if (count > 0) {
_inputPtr = 0;
_inputEnd = count;

_currInputProcessed += _inputEnd;
_currInputRowStart -= _inputEnd;

Expand All @@ -204,6 +201,9 @@ protected final boolean _loadMore() throws IOException
// in negative value, which is fine as combine value remains unchanged.
_nameStartOffset -= bufSize;

_inputPtr = 0;
_inputEnd = count;

return true;
}
// End of input
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@
import com.fasterxml.jackson.core.*;
import com.fasterxml.jackson.core.json.JsonFactory;

import java.io.IOException;
import java.util.Random;

public class LocationOffsetsTest extends com.fasterxml.jackson.core.BaseTest
{
final JsonFactory JSON_F = new JsonFactory();
Expand Down Expand Up @@ -143,7 +146,7 @@ private void _testWithLazyStringRead(int readMode) throws Exception
assertEquals(8, p.getCurrentLocation().getColumnNr());
p.close();
}

// for [core#533]
public void testUtf8Bom() throws Exception
{
Expand Down Expand Up @@ -232,4 +235,72 @@ private byte[] withUtf8Bom(byte[] bytes) {
System.arraycopy(bytes, 0, arr, 3, bytes.length);
return arr;
}

public void testBigPayload() throws IOException {
JsonLocation loc;
JsonParser p;

String doc = "{\"key\":\"" + generateRandomAlpha(50000) + "\"}";

p = createParserUsingStream(JSON_F, doc, "UTF-8");

assertToken(JsonToken.START_OBJECT, p.nextToken());
loc = p.getTokenLocation();
assertEquals(0, loc.getByteOffset());
assertEquals(-1L, loc.getCharOffset());
assertEquals(1, loc.getLineNr());
assertEquals(1, loc.getColumnNr());
loc = p.getCurrentLocation();
assertEquals(1, loc.getByteOffset());
assertEquals(-1L, loc.getCharOffset());
assertEquals(1, loc.getLineNr());
assertEquals(2, loc.getColumnNr());

assertToken(JsonToken.FIELD_NAME, p.nextToken());
loc = p.getTokenLocation();
assertEquals(1, loc.getByteOffset());
assertEquals(-1L, loc.getCharOffset());
assertEquals(1, loc.getLineNr());
assertEquals(2, loc.getColumnNr());
loc = p.getCurrentLocation();
assertEquals(8, loc.getByteOffset());
assertEquals(-1L, loc.getCharOffset());
assertEquals(1, loc.getLineNr());
assertEquals(9, loc.getColumnNr());

assertToken(JsonToken.VALUE_STRING, p.nextToken());
loc = p.getTokenLocation();
assertEquals(7, loc.getByteOffset());
assertEquals(-1L, loc.getCharOffset());
assertEquals(1, loc.getLineNr());
assertEquals(8, loc.getColumnNr());
loc = p.getCurrentLocation();
assertEquals(8, loc.getByteOffset());
assertEquals(-1L, loc.getCharOffset());
assertEquals(1, loc.getLineNr());
assertEquals(9, loc.getColumnNr());

p.getTextCharacters();
loc = p.getTokenLocation();
assertEquals(7, loc.getByteOffset());
assertEquals(-1L, loc.getCharOffset());
assertEquals(1, loc.getLineNr());
assertEquals(8, loc.getColumnNr());
loc = p.getCurrentLocation();
assertEquals(doc.length() - 1, loc.getByteOffset());
assertEquals(-1L, loc.getCharOffset());
assertEquals(1, loc.getLineNr());
assertEquals(doc.length(), loc.getColumnNr());
}

private String generateRandomAlpha(int length) {
StringBuilder sb = new StringBuilder(length);
Random rnd = new Random(length);
for (int i = 0; i < length; ++i) {
// let's limit it not to include surrogate pairs:
char ch = (char) ('A' + rnd.nextInt(26));
sb.append(ch);
}
return sb.toString();
}
}

0 comments on commit 993d66a

Please sign in to comment.