#pragma once #include "ids_t.h" #include "tsl/htrie_map.h" #include class facet_index_t { private: struct count_list { count_list() = delete; ~count_list () = default; count_list(const std::string& sv, uint32_t facet_count, uint32_t facet_index) { facet_value = sv; count = facet_count; index = facet_index; } count_list& operator=(count_list& obj) { facet_value = obj.facet_value; count = obj.count; index = obj.index; return *this; } std::string facet_value; uint32_t count; uint32_t index; }; struct facet_index_struct { void* id_list_ptr; uint32_t index; facet_index_struct() { id_list_ptr = nullptr; index = UINT32_MAX; } ~facet_index_struct() {}; }; struct facet_index_counter { tsl::htrie_map facet_index_map; std::vector counter_list; bool is_migrated = false; facet_index_counter() { facet_index_map.clear(); counter_list.clear(); } ~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); void remove(const std::string& field, const uint32_t seq_id); 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); size_t get_facet_indexes(const std::string& field, std::map>& seqid_countIndexes); void initialize(const std::string& field); };