From: Peng Wu Date: Mon, 5 Nov 2012 05:55:34 +0000 (+0800) Subject: write get length X-Git-Tag: 0.8.91~69 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=ed47add4965f5a22f697e1ec795be9e03065b18a;p=platform%2Fupstream%2Flibpinyin.git write get length --- diff --git a/src/storage/chewing_large_table.cpp b/src/storage/chewing_large_table.cpp index 8eb43d3..68eb3ed 100644 --- a/src/storage/chewing_large_table.cpp +++ b/src/storage/chewing_large_table.cpp @@ -53,6 +53,9 @@ public: /* in */ phrase_token_t token); int remove_index(int phrase_length, /* in */ ChewingKey keys[], /* in */ phrase_token_t token); + + /* get length method */ + int get_length() const; }; @@ -85,6 +88,9 @@ public: int add_index(/* in */ ChewingKey keys[], /* in */ phrase_token_t token); int remove_index(/* in */ ChewingKey keys[], /* in */ phrase_token_t token); + + /* get length method */ + int get_length() const; }; }; @@ -890,3 +896,31 @@ store(MemoryChunk * new_chunk, table_offset_t offset, table_offset_t & end) { end = offset + m_chunk.size(); return true; } + + +/* get length method */ + +int ChewingLengthIndexLevel::get_length() const { + int length = m_chewing_array_indexes->len; + + /* trim trailing zero. */ + for (int i = length - 1; i >= 0; --i) { + void * array = g_array_index(m_chewing_array_indexes, void *, i); + + if (NULL != array) + break; + + --length; + } + + return length; +} + +template +int ChewingArrayIndexLevel::get_length() const { + IndexItem * chunk_begin = NULL, * chunk_end = NULL; + chunk_begin = (IndexItem *) m_chunk.begin(); + chunk_end = (IndexItem *) m_chunk.end(); + + return chunk_end - chunk_begin; +} diff --git a/src/storage/phrase_large_table2.cpp b/src/storage/phrase_large_table2.cpp index 7d3d83b..7a045e4 100644 --- a/src/storage/phrase_large_table2.cpp +++ b/src/storage/phrase_large_table2.cpp @@ -678,7 +678,6 @@ int PhraseLengthIndexLevel2::get_length() const { return length; } - template int PhraseArrayIndexLevel2::get_length() const { IndexItem * chunk_begin = NULL, * chunk_end = NULL;