-
-
Notifications
You must be signed in to change notification settings - Fork 74
/
Copy pathJSONParserString.java
100 lines (87 loc) · 2.66 KB
/
JSONParserString.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
package net.minidev.json.parser;
/*
* Copyright 2011-2024 JSON-SMART authors
*
* 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.
*/
import static net.minidev.json.parser.ParseException.ERROR_UNEXPECTED_EOF;
import net.minidev.json.JSONValue;
import net.minidev.json.writer.JsonReaderI;
/**
* Parser for JSON text. Please note that JSONParser is NOT thread-safe.
*
* @author Uriel Chemouni <[email protected]>
*/
class JSONParserString extends JSONParserMemory {
private String in;
public JSONParserString(int permissiveMode) {
super(permissiveMode);
}
/**
* use to return Primitive Type, or String, Or JsonObject or JsonArray generated by a
* ContainerFactory
*/
public Object parse(String in) throws ParseException {
return parse(in, JSONValue.defaultReader.DEFAULT);
}
//
//
//
//
//
//
//
/**
* use to return Primitive Type, or String, Or JsonObject or JsonArray generated by a
* ContainerFactory
*/
public <T> T parse(String in, JsonReaderI<T> mapper) throws ParseException {
this.base = mapper.base;
this.in = in;
this.len = in.length();
return parse(mapper);
}
protected void extractString(int beginIndex, int endIndex) {
xs = in.substring(beginIndex, endIndex);
}
protected void extractStringTrim(int start, int stop) {
while (start < stop - 1 && Character.isWhitespace(in.charAt(start))) {
start++;
}
while (stop - 1 > start && Character.isWhitespace(in.charAt(stop - 1))) {
stop--;
}
extractString(start, stop);
}
protected int indexOf(char c, int pos) {
return in.indexOf(c, pos);
}
/** Read next char or END OF INPUT */
protected void read() {
if (++pos >= len) this.c = EOI;
else this.c = in.charAt(pos);
}
/** Same as read() in memory parsing */
protected void readS() {
if (++pos >= len) this.c = EOI;
else this.c = in.charAt(pos);
}
/** read data can not be EOI */
protected void readNoEnd() throws ParseException {
if (++pos >= len) {
this.c = EOI;
if (super.acceptIncomplete) return;
throw new ParseException(pos - 1, ERROR_UNEXPECTED_EOF, "EOF");
} else this.c = in.charAt(pos);
}
}