-
Notifications
You must be signed in to change notification settings - Fork 183
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add buffered lookahead for Jackson (#338)
Signed-off-by: luneo7 <luneo7@gmail.com>
- Loading branch information
Showing
12 changed files
with
599 additions
and
42 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
137 changes: 137 additions & 0 deletions
137
java-client/src/main/java/org/opensearch/client/json/DelegatingJsonParser.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,137 @@ | ||
/* | ||
* SPDX-License-Identifier: Apache-2.0 | ||
* | ||
* The OpenSearch Contributors require contributions made to | ||
* this file be licensed under the Apache-2.0 license or a | ||
* compatible open source license. | ||
*/ | ||
|
||
/* | ||
* Licensed to Elasticsearch B.V. under one or more contributor | ||
* license agreements. See the NOTICE file distributed with | ||
* this work for additional information regarding copyright | ||
* ownership. Elasticsearch B.V. licenses this file to you 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. | ||
*/ | ||
|
||
/* | ||
* Modifications Copyright OpenSearch Contributors. See | ||
* GitHub history for details. | ||
*/ | ||
|
||
package org.opensearch.client.json; | ||
|
||
import jakarta.json.JsonArray; | ||
import jakarta.json.JsonObject; | ||
import jakarta.json.JsonValue; | ||
import jakarta.json.stream.JsonLocation; | ||
import jakarta.json.stream.JsonParser; | ||
|
||
import java.math.BigDecimal; | ||
import java.util.Map; | ||
import java.util.stream.Stream; | ||
|
||
public abstract class DelegatingJsonParser implements JsonParser { | ||
|
||
private final JsonParser parser; | ||
|
||
public DelegatingJsonParser(JsonParser parser) { | ||
this.parser = parser; | ||
} | ||
|
||
@Override | ||
public boolean hasNext() { | ||
return parser.hasNext(); | ||
} | ||
|
||
@Override | ||
public Event next() { | ||
return parser.next(); | ||
} | ||
|
||
@Override | ||
public String getString() { | ||
return parser.getString(); | ||
} | ||
|
||
@Override | ||
public boolean isIntegralNumber() { | ||
return parser.isIntegralNumber(); | ||
} | ||
|
||
@Override | ||
public int getInt() { | ||
return parser.getInt(); | ||
} | ||
|
||
@Override | ||
public long getLong() { | ||
return parser.getLong(); | ||
} | ||
|
||
@Override | ||
public BigDecimal getBigDecimal() { | ||
return parser.getBigDecimal(); | ||
} | ||
|
||
@Override | ||
public JsonLocation getLocation() { | ||
return parser.getLocation(); | ||
} | ||
|
||
@Override | ||
public JsonObject getObject() { | ||
return parser.getObject(); | ||
} | ||
|
||
@Override | ||
public JsonValue getValue() { | ||
return parser.getValue(); | ||
} | ||
|
||
@Override | ||
public JsonArray getArray() { | ||
return parser.getArray(); | ||
} | ||
|
||
@Override | ||
public Stream<JsonValue> getArrayStream() { | ||
return parser.getArrayStream(); | ||
} | ||
|
||
@Override | ||
public Stream<Map.Entry<String, JsonValue>> getObjectStream() { | ||
return parser.getObjectStream(); | ||
} | ||
|
||
@Override | ||
public Stream<JsonValue> getValueStream() { | ||
return parser.getValueStream(); | ||
} | ||
|
||
@Override | ||
public void skipArray() { | ||
parser.skipArray(); | ||
} | ||
|
||
@Override | ||
public void skipObject() { | ||
parser.skipObject(); | ||
} | ||
|
||
@Override | ||
public void close() { | ||
parser.close(); | ||
} | ||
} |
68 changes: 68 additions & 0 deletions
68
java-client/src/main/java/org/opensearch/client/json/JsonLocationImpl.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
/* | ||
* SPDX-License-Identifier: Apache-2.0 | ||
* | ||
* The OpenSearch Contributors require contributions made to | ||
* this file be licensed under the Apache-2.0 license or a | ||
* compatible open source license. | ||
*/ | ||
|
||
/* | ||
* Licensed to Elasticsearch B.V. under one or more contributor | ||
* license agreements. See the NOTICE file distributed with | ||
* this work for additional information regarding copyright | ||
* ownership. Elasticsearch B.V. licenses this file to you 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. | ||
*/ | ||
|
||
/* | ||
* Modifications Copyright OpenSearch Contributors. See | ||
* GitHub history for details. | ||
*/ | ||
|
||
package org.opensearch.client.json; | ||
|
||
import jakarta.json.stream.JsonLocation; | ||
|
||
class JsonLocationImpl implements JsonLocation { | ||
|
||
private final long columnNo; | ||
private final long lineNo; | ||
private final long offset; | ||
|
||
JsonLocationImpl(long lineNo, long columnNo, long streamOffset) { | ||
this.lineNo = lineNo; | ||
this.columnNo = columnNo; | ||
this.offset = streamOffset; | ||
} | ||
|
||
@Override | ||
public long getLineNumber() { | ||
return lineNo; | ||
} | ||
|
||
@Override | ||
public long getColumnNumber() { | ||
return columnNo; | ||
} | ||
|
||
@Override | ||
public long getStreamOffset() { | ||
return offset; | ||
} | ||
|
||
@Override | ||
public String toString() { | ||
return "(line no=" + lineNo + ", column no=" + columnNo + ", offset=" + offset + ")"; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
59 changes: 59 additions & 0 deletions
59
java-client/src/main/java/org/opensearch/client/json/LookAheadJsonParser.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
/* | ||
* SPDX-License-Identifier: Apache-2.0 | ||
* | ||
* The OpenSearch Contributors require contributions made to | ||
* this file be licensed under the Apache-2.0 license or a | ||
* compatible open source license. | ||
*/ | ||
|
||
/* | ||
* Licensed to Elasticsearch B.V. under one or more contributor | ||
* license agreements. See the NOTICE file distributed with | ||
* this work for additional information regarding copyright | ||
* ownership. Elasticsearch B.V. licenses this file to you 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. | ||
*/ | ||
|
||
/* | ||
* Modifications Copyright OpenSearch Contributors. See | ||
* GitHub history for details. | ||
*/ | ||
|
||
package org.opensearch.client.json; | ||
|
||
import jakarta.json.stream.JsonParser; | ||
|
||
import java.util.Map; | ||
|
||
public interface LookAheadJsonParser extends JsonParser { | ||
|
||
/** | ||
* Look ahead the value of a text property in the JSON stream. The parser must be on the {@code START_OBJECT} event. | ||
* | ||
* @param name the field name to look up. | ||
* @param defaultValue default value if the field is not found. | ||
* @return a pair containing the field value (or {@code null} if not found), and a parser to be used to read the JSON object. | ||
*/ | ||
Map.Entry<String, JsonParser> lookAheadFieldValue(String name, String defaultValue); | ||
|
||
/** | ||
* In union types, find the variant to be used by looking up property names in the JSON stream until we find one that | ||
* uniquely identifies the variant. | ||
* | ||
* @param <Variant> the type of variant descriptors used by the caller. | ||
* @param variants a map of variant descriptors, keyed by the property name that uniquely identifies the variant. | ||
* @return a pair containing the variant descriptor (or {@code null} if not found), and a parser to be used to read the JSON object. | ||
*/ | ||
<Variant> Map.Entry<Variant, JsonParser> findVariant(Map<String, Variant> variants); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.