summary refs log tree commit diff stats
path: root/lib/word.cpp
diff options
context:
space:
mode:
authorKelly Rauchenberger <fefferburbia@gmail.com>2017-02-16 20:02:55 -0500
committerKelly Rauchenberger <fefferburbia@gmail.com>2017-02-16 20:02:55 -0500
commit7cb714b57d1cbebb572e2279e2058f5fc94ba171 (patch)
tree0f2f6222b61a9dde824585625f2ab2043861d6a6 /lib/word.cpp
parent824b4b580adeea161be89a8aa114fabb794fb4ce (diff)
downloadverbly-7cb714b57d1cbebb572e2279e2058f5fc94ba171.tar.gz
verbly-7cb714b57d1cbebb572e2279e2058f5fc94ba171.tar.bz2
verbly-7cb714b57d1cbebb572e2279e2058f5fc94ba171.zip
Added word::synonyms join field (BAD)
Note that this is not a great implementation; the filter generated is
mergable with unrelated filters and may cause results that are
misleading.
Diffstat (limited to 'lib/word.cpp')
-rw-r--r--lib/word.cpp20
1 files changed, 20 insertions, 0 deletions
diff --git a/lib/word.cpp b/lib/word.cpp index e4de187..dc269c9 100644 --- a/lib/word.cpp +++ b/lib/word.cpp
@@ -38,6 +38,8 @@ namespace verbly {
38 const field word::regionalTerms = field::selfJoin(object::word, "word_id", "regionality", "domain_id", "term_id"); 38 const field word::regionalTerms = field::selfJoin(object::word, "word_id", "regionality", "domain_id", "term_id");
39 const field word::regionalDomains = field::selfJoin(object::word, "word_id", "regionality", "term_id", "domain_id"); 39 const field word::regionalDomains = field::selfJoin(object::word, "word_id", "regionality", "term_id", "domain_id");
40 40
41 const word::synonyms_field word::synonyms = {};
42
41 field word::forms(inflection category) 43 field word::forms(inflection category)
42 { 44 {
43 return field::joinThroughWhere(object::word, "lemma_id", object::form, "lemmas_forms", "form_id", "category", static_cast<int>(category)); 45 return field::joinThroughWhere(object::word, "lemma_id", object::form, "lemmas_forms", "form_id", "category", static_cast<int>(category));
@@ -168,4 +170,22 @@ namespace verbly {
168 forms_[infl] = db_->forms(form::words(infl) %= *this, verbly::form::id, -1).all(); 170 forms_[infl] = db_->forms(form::words(infl) %= *this, verbly::form::id, -1).all();
169 } 171 }
170 172
173 filter word::synonyms_field::operator%=(filter joinCondition) const
174 {
175 return (verbly::notion::words %= (
176 std::move(joinCondition)
177 && (filter(
178 verbly::word::id,
179 filter::comparison::field_does_not_equal,
180 verbly::word::id))));
181 }
182
183 word::synonyms_field::operator filter() const
184 {
185 return (verbly::notion::words %= filter(
186 verbly::word::id,
187 filter::comparison::field_does_not_equal,
188 verbly::word::id));
189 }
190
171}; 191};