aboutsummaryrefslogtreecommitdiffstats
path: root/streamingvisitors/src/vespa/vsm/vsm/query_term_filter_factory.cpp
blob: 2ed3c81027fb9e6667346936af03f023552606ec (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.

#include "query_term_filter_factory.h"
#include <vespa/searchsummary/docsummary/query_term_filter.h>
#include <vespa/vespalib/stllike/hash_map.hpp>
#include <vespa/vespalib/stllike/hash_set.hpp>
#include <cassert>
#include <vespa/log/log.h>
LOG_SETUP(".vsm.query_term_filter_factory");

using search::docsummary::IQueryTermFilter;
using search::docsummary::IQueryTermFilterFactory;
using search::docsummary::QueryTermFilter;
using vespa::config::search::vsm::VsmfieldsConfig;
using vespa::config::search::vsm::VsmsummaryConfig;

namespace vsm {

QueryTermFilterFactory::QueryTermFilterFactory(VsmfieldsConfig& vsm_fields_config,
                                                 VsmsummaryConfig& vsm_summary_config)
    : IQueryTermFilterFactory(),
      _view_map(),
      _field_map()
{
    populate_view_map(vsm_fields_config);
    populate_field_map(vsm_summary_config);
}

QueryTermFilterFactory::~QueryTermFilterFactory() = default;

void
QueryTermFilterFactory::populate_view_map(VsmfieldsConfig& vsm_fields_config)
{
    for (auto& doctype : vsm_fields_config.documenttype) {
        for (auto& index : doctype.index) {
            for (auto& field : index.field) {
                _view_map[field.name].insert(index.name);
            }
        }
    }
}

void
QueryTermFilterFactory::populate_field_map(VsmsummaryConfig& vsm_summary_config)
{
    for (auto& summary_field : vsm_summary_config.fieldmap) {
        for (auto& document : summary_field.document) {
            _field_map[summary_field.summary].insert(document.field);
        }
    }
}

void
QueryTermFilterFactory::populate_views(StringSet& views, const vespalib::string& field) const
{
    auto itr = _view_map.find(field);
    if (itr != _view_map.end()) {
        for (auto& index : itr->second) {
            views.insert(index);
        }
    }
}

std::shared_ptr<const IQueryTermFilter>
QueryTermFilterFactory::make(vespalib::stringref input_field) const
{
    StringSet views;
    auto itr = _field_map.find(input_field);
    if (itr != _field_map.end()) {
        for (auto& field : itr->second) {
            populate_views(views, field);
        }
    } else {
        // Assume identity mapping vsm summary field -> document field
        populate_views(views, input_field);
    }
    return std::make_shared<QueryTermFilter>(std::move(views));
}

}