2020-02-16 22:19:44 +01:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
|
|
|
|
// A class for performing full text searches on dives.
|
|
|
|
// Search is case-insensitive. Even though QString has many design
|
|
|
|
// issues such as COW semantics and UTF-16 encoding, it provides
|
|
|
|
// platform independence and reasonable performance. Therefore,
|
|
|
|
// this is based in QString instead of std::string.
|
|
|
|
|
|
|
|
#ifndef FULLTEXT_H
|
|
|
|
#define FULLTEXT_H
|
|
|
|
|
2024-05-04 18:45:55 +02:00
|
|
|
#include <QString>
|
|
|
|
#include <vector>
|
2020-02-16 22:19:44 +01:00
|
|
|
|
|
|
|
struct dive;
|
|
|
|
void fulltext_register(struct dive *d); // Note: can be called repeatedly
|
|
|
|
void fulltext_unregister(struct dive *d); // Note: can be called repeatedly
|
|
|
|
void fulltext_unregister_all(); // Unregisters all dives in the dive table
|
2020-04-08 09:05:28 +02:00
|
|
|
void fulltext_populate(); // Registers all dives in the dive table
|
2020-02-16 22:19:44 +01:00
|
|
|
|
|
|
|
enum class StringFilterMode {
|
|
|
|
SUBSTRING = 0,
|
|
|
|
STARTSWITH = 1,
|
|
|
|
EXACT = 2
|
|
|
|
};
|
|
|
|
|
2024-06-03 19:09:43 +02:00
|
|
|
// This class caches each dives words, so that we can unregister a dive from the full text search
|
|
|
|
struct full_text_cache {
|
|
|
|
std::vector<QString> words;
|
|
|
|
};
|
|
|
|
|
2020-02-16 22:19:44 +01:00
|
|
|
// A fulltext query. Basically a list of normalized words we search for
|
|
|
|
struct FullTextQuery {
|
|
|
|
std::vector<QString> words;
|
2020-05-29 08:26:38 +02:00
|
|
|
QString originalQuery; // Remember original query, which will be written to the log
|
2020-02-16 22:19:44 +01:00
|
|
|
FullTextQuery &operator=(const QString &); // Initialize by assigning a user-provided search string
|
|
|
|
bool doit() const; // true if we should to a fulltext search
|
|
|
|
};
|
|
|
|
|
|
|
|
// Describes the result of a fulltext search
|
|
|
|
struct FullTextResult {
|
|
|
|
std::vector<dive *> dives;
|
|
|
|
bool dive_matches(const struct dive *d) const;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Two search modes:
|
|
|
|
// 1) Find all dives matching the query.
|
|
|
|
// 2) Test if a given dive matches the query.
|
|
|
|
FullTextResult fulltext_find_dives(const FullTextQuery &q, StringFilterMode);
|
|
|
|
bool fulltext_dive_matches(const struct dive *d, const FullTextQuery &q, StringFilterMode);
|
|
|
|
|
|
|
|
#endif
|