Make `parseMultiField` part of `parseField`. #17313
All our fields are supposed to support multi fields, so we could put the logic in `TypeParsers.parseField` instead of duplicating the logic in every type parser.
This commit is contained in:
parent
8e749998f3
commit
e5074e2b1b
|
@ -110,8 +110,6 @@ public class BooleanFieldMapper extends FieldMapper {
|
||||||
}
|
}
|
||||||
builder.nullValue(lenientNodeBooleanValue(propNode));
|
builder.nullValue(lenientNodeBooleanValue(propNode));
|
||||||
iterator.remove();
|
iterator.remove();
|
||||||
} else if (parseMultiField(builder, name, parserContext, propName, propNode)) {
|
|
||||||
iterator.remove();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return builder;
|
return builder;
|
||||||
|
|
|
@ -134,8 +134,6 @@ public final class KeywordFieldMapper extends FieldMapper implements AllFieldMap
|
||||||
} else if (propName.equals("eager_global_ordinals")) {
|
} else if (propName.equals("eager_global_ordinals")) {
|
||||||
builder.eagerGlobalOrdinals(XContentMapValues.nodeBooleanValue(propNode));
|
builder.eagerGlobalOrdinals(XContentMapValues.nodeBooleanValue(propNode));
|
||||||
iterator.remove();
|
iterator.remove();
|
||||||
} else if (parseMultiField(builder, name, parserContext, propName, propNode)) {
|
|
||||||
iterator.remove();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return builder;
|
return builder;
|
||||||
|
|
|
@ -334,8 +334,6 @@ public class StringFieldMapper extends FieldMapper implements AllFieldMapper.Inc
|
||||||
builder.fielddataFrequencyFilter(minFrequency, maxFrequency, minSegmentSize);
|
builder.fielddataFrequencyFilter(minFrequency, maxFrequency, minSegmentSize);
|
||||||
DocumentMapperParser.checkNoRemainingFields(propName, frequencyFilter, parserContext.indexVersionCreated());
|
DocumentMapperParser.checkNoRemainingFields(propName, frequencyFilter, parserContext.indexVersionCreated());
|
||||||
iterator.remove();
|
iterator.remove();
|
||||||
} else if (parseMultiField(builder, fieldName, parserContext, propName, propNode)) {
|
|
||||||
iterator.remove();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return builder;
|
return builder;
|
||||||
|
|
|
@ -163,8 +163,6 @@ public class TextFieldMapper extends FieldMapper implements AllFieldMapper.Inclu
|
||||||
builder.fielddataFrequencyFilter(minFrequency, maxFrequency, minSegmentSize);
|
builder.fielddataFrequencyFilter(minFrequency, maxFrequency, minSegmentSize);
|
||||||
DocumentMapperParser.checkNoRemainingFields(propName, frequencyFilter, parserContext.indexVersionCreated());
|
DocumentMapperParser.checkNoRemainingFields(propName, frequencyFilter, parserContext.indexVersionCreated());
|
||||||
iterator.remove();
|
iterator.remove();
|
||||||
} else if (parseMultiField(builder, fieldName, parserContext, propName, propNode)) {
|
|
||||||
iterator.remove();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return builder;
|
return builder;
|
||||||
|
|
|
@ -268,6 +268,8 @@ public class TypeParsers {
|
||||||
&& parserContext.indexVersionCreated().before(Version.V_5_0_0_alpha1)) {
|
&& parserContext.indexVersionCreated().before(Version.V_5_0_0_alpha1)) {
|
||||||
// ignore for bw compat
|
// ignore for bw compat
|
||||||
iterator.remove();
|
iterator.remove();
|
||||||
|
} else if (parseMultiField(builder, name, parserContext, propName, propNode)) {
|
||||||
|
iterator.remove();
|
||||||
} else if (propName.equals("copy_to")) {
|
} else if (propName.equals("copy_to")) {
|
||||||
if (parserContext.isWithinMultiField()) {
|
if (parserContext.isWithinMultiField()) {
|
||||||
if (indexVersionCreated.after(Version.V_2_1_0) ||
|
if (indexVersionCreated.after(Version.V_2_1_0) ||
|
||||||
|
|
|
@ -220,8 +220,6 @@ public abstract class BaseGeoPointFieldMapper extends FieldMapper implements Arr
|
||||||
} else if (propName.equals(Names.IGNORE_MALFORMED)) {
|
} else if (propName.equals(Names.IGNORE_MALFORMED)) {
|
||||||
builder.ignoreMalformed(XContentMapValues.lenientNodeBooleanValue(propNode));
|
builder.ignoreMalformed(XContentMapValues.lenientNodeBooleanValue(propNode));
|
||||||
iterator.remove();
|
iterator.remove();
|
||||||
} else if (parseMultiField(builder, name, parserContext, propName, propNode)) {
|
|
||||||
iterator.remove();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -125,16 +125,6 @@ public class ExternalMapper extends FieldMapper {
|
||||||
public Mapper.Builder parse(String name, Map<String, Object> node, ParserContext parserContext) throws MapperParsingException {
|
public Mapper.Builder parse(String name, Map<String, Object> node, ParserContext parserContext) throws MapperParsingException {
|
||||||
ExternalMapper.Builder builder = new ExternalMapper.Builder(name, generatedValue, mapperName);
|
ExternalMapper.Builder builder = new ExternalMapper.Builder(name, generatedValue, mapperName);
|
||||||
parseField(builder, name, node, parserContext);
|
parseField(builder, name, node, parserContext);
|
||||||
for (Iterator<Map.Entry<String, Object>> iterator = node.entrySet().iterator(); iterator.hasNext();) {
|
|
||||||
Map.Entry<String, Object> entry = iterator.next();
|
|
||||||
String propName = Strings.toUnderscoreCase(entry.getKey());
|
|
||||||
Object propNode = entry.getValue();
|
|
||||||
|
|
||||||
if (parseMultiField(builder, name, parserContext, propName, propNode)) {
|
|
||||||
iterator.remove();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return builder;
|
return builder;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue