Inline DocumentParser#parseObject

Relates #16725
This commit is contained in:
Jason Tedor 2016-02-14 00:10:56 -05:00
parent 5bbb1312b1
commit 7273948188
1 changed files with 52 additions and 42 deletions

View File

@ -262,22 +262,7 @@ class DocumentParser implements Closeable {
ObjectMapper.Nested nested = mapper.nested(); ObjectMapper.Nested nested = mapper.nested();
if (nested.isNested()) { if (nested.isNested()) {
context = context.createNestedContext(mapper.fullPath()); context = nestedContext(context, mapper);
ParseContext.Document nestedDoc = context.doc();
ParseContext.Document parentDoc = nestedDoc.getParent();
// pre add the uid field if possible (id was already provided)
IndexableField uidField = parentDoc.getField(UidFieldMapper.NAME);
if (uidField != null) {
// we don't need to add it as a full uid field in nested docs, since we don't need versioning
// we also rely on this for UidField#loadVersion
// this is a deeply nested field
nestedDoc.add(new Field(UidFieldMapper.NAME, uidField.stringValue(), UidFieldMapper.Defaults.NESTED_FIELD_TYPE));
}
// the type of the nested doc starts with __, so we can identify that its a nested one in filters
// note, we don't prefix it with the type of the doc since it allows us to execute a nested query
// across types (for example, with similar nested objects)
nestedDoc.add(new Field(TypeFieldMapper.NAME, mapper.nestedTypePathAsString(), TypeFieldMapper.Defaults.FIELD_TYPE));
} }
// if we are at the end of the previous object, advance // if we are at the end of the previous object, advance
@ -290,6 +275,15 @@ class DocumentParser implements Closeable {
} }
ObjectMapper update = null; ObjectMapper update = null;
update = innerParseObject(context, mapper, parser, currentFieldName, token, update);
// restore the enable path flag
if (nested.isNested()) {
nested(context, nested);
}
return update;
}
private static ObjectMapper innerParseObject(ParseContext context, ObjectMapper mapper, XContentParser parser, String currentFieldName, XContentParser.Token token, ObjectMapper update) throws IOException {
while (token != XContentParser.Token.END_OBJECT) { while (token != XContentParser.Token.END_OBJECT) {
ObjectMapper newUpdate = null; ObjectMapper newUpdate = null;
if (token == XContentParser.Token.START_OBJECT) { if (token == XContentParser.Token.START_OBJECT) {
@ -314,34 +308,50 @@ class DocumentParser implements Closeable {
} }
} }
} }
// restore the enable path flag return update;
if (nested.isNested()) { }
private static void nested(ParseContext context, ObjectMapper.Nested nested) {
ParseContext.Document nestedDoc = context.doc(); ParseContext.Document nestedDoc = context.doc();
ParseContext.Document parentDoc = nestedDoc.getParent(); ParseContext.Document parentDoc = nestedDoc.getParent();
if (nested.isIncludeInParent()) { if (nested.isIncludeInParent()) {
for (IndexableField field : nestedDoc.getFields()) { addFields(nestedDoc, parentDoc);
if (field.name().equals(UidFieldMapper.NAME) || field.name().equals(TypeFieldMapper.NAME)) {
continue;
} else {
parentDoc.add(field);
}
}
} }
if (nested.isIncludeInRoot()) { if (nested.isIncludeInRoot()) {
ParseContext.Document rootDoc = context.rootDoc(); ParseContext.Document rootDoc = context.rootDoc();
// don't add it twice, if its included in parent, and we are handling the master doc... // don't add it twice, if its included in parent, and we are handling the master doc...
if (!nested.isIncludeInParent() || parentDoc != rootDoc) { if (!nested.isIncludeInParent() || parentDoc != rootDoc) {
addFields(nestedDoc, rootDoc);
}
}
}
private static void addFields(ParseContext.Document nestedDoc, ParseContext.Document rootDoc) {
for (IndexableField field : nestedDoc.getFields()) { for (IndexableField field : nestedDoc.getFields()) {
if (field.name().equals(UidFieldMapper.NAME) || field.name().equals(TypeFieldMapper.NAME)) { if (!field.name().equals(UidFieldMapper.NAME) && !field.name().equals(TypeFieldMapper.NAME)) {
continue;
} else {
rootDoc.add(field); rootDoc.add(field);
} }
} }
} }
private static ParseContext nestedContext(ParseContext context, ObjectMapper mapper) {
context = context.createNestedContext(mapper.fullPath());
ParseContext.Document nestedDoc = context.doc();
ParseContext.Document parentDoc = nestedDoc.getParent();
// pre add the uid field if possible (id was already provided)
IndexableField uidField = parentDoc.getField(UidFieldMapper.NAME);
if (uidField != null) {
// we don't need to add it as a full uid field in nested docs, since we don't need versioning
// we also rely on this for UidField#loadVersion
// this is a deeply nested field
nestedDoc.add(new Field(UidFieldMapper.NAME, uidField.stringValue(), UidFieldMapper.Defaults.NESTED_FIELD_TYPE));
} }
} // the type of the nested doc starts with __, so we can identify that its a nested one in filters
return update; // note, we don't prefix it with the type of the doc since it allows us to execute a nested query
// across types (for example, with similar nested objects)
nestedDoc.add(new Field(TypeFieldMapper.NAME, mapper.nestedTypePathAsString(), TypeFieldMapper.Defaults.FIELD_TYPE));
return context;
} }
private static Mapper parseObjectOrField(ParseContext context, Mapper mapper) throws IOException { private static Mapper parseObjectOrField(ParseContext context, Mapper mapper) throws IOException {