2009-05-14 22:18:45 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2009 Google Inc.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
package com.google.gson;
|
|
|
|
|
|
|
|
import java.io.EOFException;
|
|
|
|
import java.io.Reader;
|
|
|
|
import java.io.StringReader;
|
2009-08-12 23:01:42 +02:00
|
|
|
import java.util.Iterator;
|
2009-05-14 22:18:45 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A parser that allows reading of multiple {@link JsonElement}s from the specified reader
|
2009-08-12 23:01:42 +02:00
|
|
|
* asynchronously. This class is not thread-safe.
|
2009-05-14 22:18:45 +02:00
|
|
|
*
|
|
|
|
* @author Inderjeet Singh
|
|
|
|
* @author Joel Leitch
|
|
|
|
* @since 1.4
|
|
|
|
*/
|
2009-08-12 23:01:42 +02:00
|
|
|
public final class JsonParserAsync implements Iterator<JsonElement> {
|
2009-05-14 22:18:45 +02:00
|
|
|
|
|
|
|
private final JsonParserJavacc parser;
|
2009-08-12 23:01:42 +02:00
|
|
|
private boolean eof;
|
|
|
|
private JsonElement nextElement;
|
2009-05-14 22:18:45 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param json The string containing JSON elements concatenated to each other.
|
|
|
|
* @since 1.4
|
|
|
|
*/
|
|
|
|
public JsonParserAsync(String json) {
|
|
|
|
this(new StringReader(json));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param reader The data stream containing JSON elements concatenated to each other.
|
|
|
|
* @since 1.4
|
|
|
|
*/
|
|
|
|
public JsonParserAsync(Reader reader) {
|
|
|
|
parser = new JsonParserJavacc(reader);
|
2009-08-12 23:01:42 +02:00
|
|
|
eof = false;
|
|
|
|
nextElement = null;
|
2009-05-14 22:18:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the next available {@link JsonElement} on the reader. Null if none available.
|
|
|
|
*
|
|
|
|
* @return the next available {@link JsonElement} on the reader. Null if none available.
|
|
|
|
* @throws JsonParseException if the incoming stream is malformed JSON.
|
|
|
|
* @since 1.4
|
|
|
|
*/
|
2009-08-12 23:01:42 +02:00
|
|
|
public JsonElement next() throws JsonParseException {
|
|
|
|
if (eof) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
if (nextElement != null) {
|
|
|
|
JsonElement returnValue = nextElement;
|
|
|
|
nextElement = null;
|
|
|
|
return returnValue;
|
|
|
|
}
|
2009-05-14 22:18:45 +02:00
|
|
|
try {
|
|
|
|
JsonElement element = parser.parse();
|
|
|
|
return element;
|
|
|
|
} catch (TokenMgrError e) {
|
|
|
|
throw new JsonParseException("Failed parsing JSON source to Json", e);
|
|
|
|
} catch (ParseException e) {
|
|
|
|
throw new JsonParseException("Failed parsing JSON source to Json", e);
|
|
|
|
} catch (StackOverflowError e) {
|
|
|
|
throw new JsonParseException("Failed parsing JSON source to Json", e);
|
|
|
|
} catch (OutOfMemoryError e) {
|
|
|
|
throw new JsonParseException("Failed parsing JSON source to Json", e);
|
|
|
|
} catch (JsonParseException e) {
|
|
|
|
if (e.getCause() instanceof EOFException) {
|
2009-08-12 23:01:42 +02:00
|
|
|
eof = true;
|
2009-05-14 22:18:45 +02:00
|
|
|
return null;
|
|
|
|
} else {
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
}
|
2009-08-12 23:01:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public boolean hasNext() {
|
|
|
|
nextElement = next();
|
|
|
|
return nextElement != null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void remove() {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
2009-05-14 22:18:45 +02:00
|
|
|
}
|