aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/pinyin/3rdparty/pinyin/include/splparser.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/plugins/pinyin/3rdparty/pinyin/include/splparser.h')
-rw-r--r--src/plugins/pinyin/3rdparty/pinyin/include/splparser.h96
1 files changed, 96 insertions, 0 deletions
diff --git a/src/plugins/pinyin/3rdparty/pinyin/include/splparser.h b/src/plugins/pinyin/3rdparty/pinyin/include/splparser.h
new file mode 100644
index 00000000..d783bd73
--- /dev/null
+++ b/src/plugins/pinyin/3rdparty/pinyin/include/splparser.h
@@ -0,0 +1,96 @@
+/*
+ * Copyright (C) 2009 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#ifndef PINYINIME_INCLUDE_SPLPARSER_H__
+#define PINYINIME_INCLUDE_SPLPARSER_H__
+
+#include "./dictdef.h"
+#include "./spellingtrie.h"
+
+namespace ime_pinyin {
+
+class SpellingParser {
+ protected:
+ const SpellingTrie *spl_trie_;
+
+ public:
+ SpellingParser();
+
+ // Given a string, parse it into a spelling id stream.
+ // If the whole string are sucessfully parsed, last_is_pre will be true;
+ // if the whole string is not fullly parsed, last_is_pre will return whether
+ // the last part of the string is a prefix of a full spelling string. For
+ // example, given string "zhengzhon", "zhon" is not a valid speling, but it is
+ // the prefix of "zhong".
+ //
+ // If splstr starts with a character not in ['a'-z'] (it is a split char),
+ // return 0.
+ // Split char can only appear in the middle of the string or at the end.
+ uint16 splstr_to_idxs(const char *splstr, uint16 str_len, uint16 splidx[],
+ uint16 start_pos[], uint16 max_size, bool &last_is_pre);
+
+ // Similar to splstr_to_idxs(), the only difference is that splstr_to_idxs()
+ // convert single-character Yunmus into half ids, while this function converts
+ // them into full ids.
+ uint16 splstr_to_idxs_f(const char *splstr, uint16 str_len, uint16 splidx[],
+ uint16 start_pos[], uint16 max_size, bool &last_is_pre);
+
+ // Similar to splstr_to_idxs(), the only difference is that this function
+ // uses char16 instead of char8.
+ uint16 splstr16_to_idxs(const char16 *splstr, uint16 str_len, uint16 splidx[],
+ uint16 start_pos[], uint16 max_size, bool &last_is_pre);
+
+ // Similar to splstr_to_idxs_f(), the only difference is that this function
+ // uses char16 instead of char8.
+ uint16 splstr16_to_idxs_f(const char16 *splstr16, uint16 str_len,
+ uint16 splidx[], uint16 start_pos[],
+ uint16 max_size, bool &last_is_pre);
+
+ // If the given string is a spelling, return the id, others, return 0.
+ // If the give string is a single char Yunmus like "A", and the char is
+ // enabled in ShouZiMu mode, the returned spelling id will be a half id.
+ // When the returned spelling id is a half id, *is_pre returns whether it
+ // is a prefix of a full spelling string.
+ uint16 get_splid_by_str(const char *splstr, uint16 str_len, bool *is_pre);
+
+ // If the given string is a spelling, return the id, others, return 0.
+ // If the give string is a single char Yunmus like "a", no matter the char
+ // is enabled in ShouZiMu mode or not, the returned spelling id will be
+ // a full id.
+ // When the returned spelling id is a half id, *p_is_pre returns whether it
+ // is a prefix of a full spelling string.
+ uint16 get_splid_by_str_f(const char *splstr, uint16 str_len, bool *is_pre);
+
+ // Splitter chars are not included.
+ bool is_valid_to_parse(char ch);
+
+ // When auto-correction is not enabled, get_splid_by_str() will be called to
+ // return the single result. When auto-correction is enabled, this function
+ // will be called to get the results. Auto-correction is not ready.
+ // full_id_num returns number of full spelling ids.
+ // is_pre returns whether the given string is the prefix of a full spelling
+ // string.
+ // If splstr starts with a character not in [a-zA-Z] (it is a split char),
+ // return 0.
+ // Split char can only appear in the middle of the string or at the end.
+ // The caller should guarantee NULL != splstr && str_len > 0 && NULL != splidx
+ uint16 get_splids_parallel(const char *splstr, uint16 str_len,
+ uint16 splidx[], uint16 max_size,
+ uint16 &full_id_num, bool &is_pre);
+};
+}
+
+#endif // PINYINIME_INCLUDE_SPLPARSER_H__