summaryrefslogtreecommitdiffstats
path: root/src/storage
diff options
context:
space:
mode:
authorPeng Wu <alexepico@gmail.com>2016-03-02 15:00:34 +0800
committerPeng Wu <alexepico@gmail.com>2016-03-02 15:00:34 +0800
commitce724784daf9e2eb6608278bc6712ebedbfc5e66 (patch)
tree92bdf875454c25ed1d4caa539866548825bbd94b /src/storage
parent6f785fe6118aff18ea596c095ce67e513de88471 (diff)
downloadlibpinyin-ce724784daf9e2eb6608278bc6712ebedbfc5e66.tar.gz
libpinyin-ce724784daf9e2eb6608278bc6712ebedbfc5e66.tar.xz
libpinyin-ce724784daf9e2eb6608278bc6712ebedbfc5e66.zip
write add_index method
Diffstat (limited to 'src/storage')
-rw-r--r--src/storage/chewing_large_table2.h25
1 files changed, 24 insertions, 1 deletions
diff --git a/src/storage/chewing_large_table2.h b/src/storage/chewing_large_table2.h
index 963008d..95cc41f 100644
--- a/src/storage/chewing_large_table2.h
+++ b/src/storage/chewing_large_table2.h
@@ -121,7 +121,30 @@ public:
/* add/remove index method */
int add_index(/* in */ const ChewingKey keys[],
- /* in */ phrase_token_t token);
+ /* in */ phrase_token_t token) {
+ const IndexItem * begin = (IndexItem *) m_chunk.begin();
+ const IndexItem * end = (IndexItem *) m_chunk.end();
+
+ const IndexItem add_elem(keys, token);
+
+ std_lite::pair<const IndexItem *, const IndexItem *> range =
+ std_lite::equal_range(begin, end, add_elem,
+ phrase_exact_less_than2<phrase_length>);
+
+ const IndexItem * cur_elem;
+ for (cur_elem = range.first;
+ cur_elem != range.second; ++cur_elem) {
+ if (cur_elem->m_token == token)
+ return ERROR_INSERT_ITEM_EXISTS;
+ if (cur_elem->m_token > token)
+ break;
+ }
+
+ int offset = (cur_elem - begin) * sizeof(IndexItem);
+ m_chunk.insert_content(offset, &add_elem, sizeof(IndexItem));
+ return ERROR_OK;
+ }
+
int remove_index(/* in */ const ChewingKey keys[],
/* in */ phrase_token_t token);