com.landawn.abacus.parser.JSONReader Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of abacus-common Show documentation
Show all versions of abacus-common Show documentation
A general programming library in Java/Android. It's easy to learn and simple to use with concise and powerful APIs.
/*
* Copyright (C) 2015 HaiYang Li
*
* 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.landawn.abacus.parser;
import java.io.IOException;
import com.landawn.abacus.parser.ParserUtil.PropInfo;
import com.landawn.abacus.type.Type;
/**
*
* @author Haiyang Li
* @since 0.8
*/
interface JSONReader {
// < 32 = ' ' (Space) White space
int EOR = -1;
int START_BRACE = 1;
int END_BRACE = 2;
int START_BRACKET = 3;
int END_BRACKET = 4;
int START_QUOTATION_D = 5;
int END_QUOTATION_D = 6;
int START_QUOTATION_S = 7;
int END_QUOTATION_S = 8;
int COLON = 9;
int COMMA = 10;
// > 32 = ' ' (Space)
/**
* Checks for text.
*
* @return true, if successful
* @throws IOException Signals that an I/O exception has occurred.
*/
boolean hasText() throws IOException;
/**
*
* @return - 1 is returned if no next symbol is found.
* @throws IOException Signals that an I/O exception has occurred.
*/
int nextToken() throws IOException;
// int nextNameToken() throws IOException;
/**
* Gets the text.
*
* @return
* @throws IOException Signals that an I/O exception has occurred.
*/
String getText() throws IOException;
/**
*
* @param
* @param type
* @return
* @throws IOException Signals that an I/O exception has occurred.
*/
T readValue(Type type) throws IOException;
/**
* Read prop info.
*
* @param symbolReader
* @return
*/
PropInfo readPropInfo(SymbolReader symbolReader);
/**
*
* @throws IOException Signals that an I/O exception has occurred.
*/
void close() throws IOException;
/**
* Added for performance tuning.
*
* @author haiyangl
*
*/
interface SymbolReader {
/**
*
* @param propName
* @return
*/
PropInfo getPropInfo(String propName);
/**
* Read prop info.
*
* @param cbuf
* @param fromIndex
* @param toIndex
* @return
*/
PropInfo readPropInfo(char[] cbuf, int fromIndex, int toIndex);
// PropInfo readPropInfo(String str, int fromIndex, int toIndex);
}
}