#include "dictionary.h" #include "word.h" #include #include #include #include #include #include using std::string; using std::vector; // using std::filesystem::path; Dictionary::Dictionary() {} bool Dictionary::contains(const string &word) const { return true; } vector Dictionary::get_suggestions(const string &word) const { vector suggestions; // add_trigram_suggestions(suggestions, word); // rank_suggestions(suggestions, word); // trim_suggestions(suggestions); return suggestions; } // Function to generate trigrams from a string std::vector get_trigrams(const std::string &text) { std::vector trigrams; if (text.size() < 3) { return trigrams; // Return an empty vector if the input is too short } for (size_t i = 0; i <= text.size() - 3; ++i) { trigrams.push_back( text.substr(i, 3)); // Extract a substring of length 3 } return trigrams; } int Dictionary::spit(path p) { std::ofstream file(p); if (!file.is_open()) { std::cerr << "Error opening file! " << std::endl; return 1; } for (int a = 0; a < MAXLEN; a++) { for (auto &word : words[a]) { std::vector trias = get_trigrams(word.get_word()); file << word << " " << trias.size(); for (auto tria : trias) { file << " " << tria; } file << std::endl; } } file.flush(); file.close(); return 0; } int Dictionary::slurp(path p) { std::ifstream file(p.string()); if (!file.is_open()) { std::cerr << "Error opening file! " << std::endl; return 1; } std::string line; while (std::getline(file, line)) { if (line.size() > MAXLEN) continue; words[line.size()].push_back(Word(line, get_trigrams(line))); } file.close(); return 0; }