typesense/include/facet_index.h
2023-04-13 17:48:48 +05:30

58 lines
1.5 KiB
C++

#pragma once
#include "ids_t.h"
#include "tsl/htrie_map.h"
class facet_index_t {
private:
struct count_list {
count_list(const std::string& sv, uint32_t facet_count) {
facet_value = sv;
count = facet_count;
}
std::string facet_value;
uint32_t count;
};
struct facet_index_struct {
void* id_list_ptr;
uint32_t index;
};
struct facet_index_counter {
tsl::htrie_map<char, facet_index_struct> facet_index_map;
std::vector<count_list> counter_list;
~facet_index_counter() {
for(auto it = facet_index_map.begin(); it != facet_index_map.end(); ++it) {
ids_t::destroy_list(it.value().id_list_ptr);
}
facet_index_map.clear();
counter_list.clear();
}
};
std::map<std::string, facet_index_counter> facet_field_map;
uint32_t count_index = 0;
public:
facet_index_t() = default;
~facet_index_t();
uint32_t insert(const std::string& field, const std::string& value, uint32_t id);
void erase(const std::string& field);
bool contains(const std::string& field);
size_t get_facet_count(const std::string& field);
int intersect(const std::string& val, const uint32_t* result_ids, int result_id_len,
int max_facet_count, std::map<std::string, uint32_t>& found);
std::string get_facet_by_count_index(const std::string& field, uint32_t count_index);
};