org.elasticsearch.xcontent.XContentParser Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of elasticsearch-x-content Show documentation
Show all versions of elasticsearch-x-content Show documentation
Elasticsearch subproject :libs:elasticsearch-x-content
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0 and the Server Side Public License, v 1; you may not use this file except
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/
package org.elasticsearch.xcontent;
import org.elasticsearch.core.CheckedFunction;
import org.elasticsearch.core.Nullable;
import org.elasticsearch.core.RestApiVersion;
import java.io.Closeable;
import java.io.IOException;
import java.nio.CharBuffer;
import java.util.List;
import java.util.Map;
import java.util.function.Supplier;
/**
* Interface for pull - parsing {@link XContent} see {@link XContentType} for supported types.
*
* To obtain an instance of this class use the following pattern:
*
*
* XContentType xContentType = XContentType.JSON;
* XContentParser parser = xContentType.xContent().createParser(
* NamedXContentRegistry.EMPTY, ParserField."{\"key\" : \"value\"}");
*
*/
public interface XContentParser extends Closeable {
enum Token {
START_OBJECT(false),
END_OBJECT(false),
START_ARRAY(false),
END_ARRAY(false),
FIELD_NAME(false),
VALUE_STRING(true),
VALUE_NUMBER(true),
VALUE_BOOLEAN(true),
// usually a binary value
VALUE_EMBEDDED_OBJECT(true),
VALUE_NULL(false);
private final boolean isValue;
Token(boolean isValue) {
this.isValue = isValue;
}
public boolean isValue() {
return isValue;
}
}
enum NumberType {
INT,
BIG_INTEGER,
LONG,
FLOAT,
DOUBLE,
BIG_DECIMAL
}
XContentType contentType();
void allowDuplicateKeys(boolean allowDuplicateKeys);
Token nextToken() throws IOException;
@Nullable
default String nextFieldName() throws IOException {
return nextToken() == Token.FIELD_NAME ? currentName() : null;
}
void skipChildren() throws IOException;
Token currentToken();
String currentName() throws IOException;
Map map() throws IOException;
Map mapOrdered() throws IOException;
Map mapStrings() throws IOException;
/**
* Returns an instance of {@link Map} holding parsed map.
* Serves as a replacement for the "map", "mapOrdered" and "mapStrings" methods above.
*
* @param mapFactory factory for creating new {@link Map} objects
* @param mapValueParser parser for parsing a single map value
* @param map value type
* @return {@link Map} object
*/
Map map(Supplier