aboutsummaryrefslogtreecommitdiffstats
path: root/container-search/src/main/java/com/yahoo/search/yql
diff options
context:
space:
mode:
authorJon Bratseth <bratseth@gmail.com>2023-01-27 16:14:25 +0100
committerJon Bratseth <bratseth@gmail.com>2023-01-27 16:14:25 +0100
commit69ca57e0cbf0bd6f6f58e9477ac240c0bc5e3533 (patch)
tree7bf694fc20abf7710ca7f4b0c2155eb59058b40e /container-search/src/main/java/com/yahoo/search/yql
parent414aaf3e1e478deadf199488887dc0d9da0881ab (diff)
Keep synthetic fields
Diffstat (limited to 'container-search/src/main/java/com/yahoo/search/yql')
-rw-r--r--container-search/src/main/java/com/yahoo/search/yql/FieldFilter.java13
1 files changed, 9 insertions, 4 deletions
diff --git a/container-search/src/main/java/com/yahoo/search/yql/FieldFilter.java b/container-search/src/main/java/com/yahoo/search/yql/FieldFilter.java
index d5603ff0171..8cc6a1b42b9 100644
--- a/container-search/src/main/java/com/yahoo/search/yql/FieldFilter.java
+++ b/container-search/src/main/java/com/yahoo/search/yql/FieldFilter.java
@@ -29,6 +29,9 @@ public class FieldFilter extends Searcher {
public static final CompoundName FIELD_FILTER_DISABLE = new CompoundName("FieldFilter.disable");
+ /** Fields that should be kept even if not explicitly requested */
+ private static final Set<String> syntheticFields = Set.of("matchfeatures", "rankfeatures", "summaryfeatures");
+
@Override
public Result search(Query query, Execution execution) {
Result result = execution.search(query);
@@ -43,16 +46,18 @@ public class FieldFilter extends Searcher {
}
private void filter(Result result) {
- Set<String> requestedFields;
-
if (result.getQuery().properties().getBoolean(FIELD_FILTER_DISABLE)) return;
if (result.getQuery().getPresentation().getSummaryFields().isEmpty()) return;
- requestedFields = result.getQuery().getPresentation().getSummaryFields();
for (Iterator<Hit> i = result.hits().unorderedDeepIterator(); i.hasNext();) {
Hit h = i.next();
if (h.isMeta()) continue;
- h.fieldKeys().retainAll(requestedFields);
+ for (var fields = h.fieldIterator(); fields.hasNext(); ) {
+ var field = fields.next();
+ if ( ! result.getQuery().getPresentation().getSummaryFields().contains(field.getKey()) &&
+ ! syntheticFields.contains(field.getKey()))
+ fields.remove();
+ }
}
}