#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 facet_index_map; std::vector 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 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, bool is_string = false); void erase(const std::string& field); bool contains(const std::string& field); size_t get_facet_count(const std::string& field); size_t intersect(const std::string& val, const uint32_t* result_ids, int result_id_len, int max_facet_count, std::map& found, bool is_wildcard_no_filter_query); };