-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathstopwords.h
More file actions
41 lines (35 loc) · 1.69 KB
/
Copy pathstopwords.h
File metadata and controls
41 lines (35 loc) · 1.69 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#pragma once
#include <string>
#include <unordered_set>
#include <array>
#include <algorithm>
#include <cf/searchstring.h>
#include "../index/stemmer/stemmer.h"
class StopWords {
private:
// Compile-time array of stopwords
static constexpr std::array<const char*, 127> stopwords_array = {
"i", "me", "my", "myself", "we", "our", "ours", "ourselves",
"you", "your", "yours", "yourself", "yourselves", "he", "him", "his",
"himself", "she", "her", "hers", "herself", "it", "its", "itself",
"they", "them", "their", "theirs", "themselves", "what", "which",
"who", "whom", "this", "that", "these", "those", "am", "is", "are",
"was", "were", "be", "been", "being", "have", "has", "had", "having",
"do", "does", "did", "doing", "a", "an", "the", "and", "but", "if",
"or", "because", "as", "until", "while", "of", "at", "by", "for",
"with", "about", "against", "between", "into", "through", "during",
"before", "after", "above", "below", "to", "from", "up", "down", "in",
"out", "on", "off", "over", "under", "again", "further", "then", "once",
"here", "there", "when", "where", "why", "how", "all", "any", "both",
"each", "few", "more", "most", "other", "some", "such", "no", "nor",
"not", "only", "own", "same", "so", "than", "too", "very", "s", "t",
"can", "will", "just", "don", "should", "now"
};
// Compile-time generated unordered_set
static const std::unordered_set<std::string> stopwords;
public:
// Check if a word is a stopword
static bool isStopword(const string& word);
// Get the stopwords set
static const std::unordered_set<std::string>& getStopwords();
};