ibus-libpinyin/ibus-libpinyin-1.8.x-head.patch
2016-08-09 13:46:39 +08:00

87 lines
2.8 KiB
Diff

diff --git a/src/PYPBopomofoEditor.cc b/src/PYPBopomofoEditor.cc
index a48a856..be89eb5 100644
--- a/src/PYPBopomofoEditor.cc
+++ b/src/PYPBopomofoEditor.cc
@@ -329,7 +329,7 @@ BopomofoEditor::updatePreeditText ()
size_t offset = 0;
guint cursor = getPinyinCursor ();
- g_assert (pinyin_get_character_offset(m_instance, sentence, cursor, &offset));
+ pinyin_get_character_offset(m_instance, sentence, cursor, &offset);
Editor::updatePreeditText (preedit_text, offset, TRUE);
if (sentence)
diff --git a/src/PYPFullPinyinEditor.cc b/src/PYPFullPinyinEditor.cc
index 70de09f..b0ad3d7 100644
--- a/src/PYPFullPinyinEditor.cc
+++ b/src/PYPFullPinyinEditor.cc
@@ -116,3 +116,21 @@ FullPinyinEditor::update (void)
updatePreeditText ();
updateAuxiliaryText ();
}
+
+guint
+FullPinyinEditor::getLookupCursor (void)
+{
+ guint lookup_cursor = getPinyinCursor ();
+
+ /* as pinyin_get_pinyin_offset can't handle the last "'" characters,
+ strip the string to work around it here. */
+ String stripped = m_text;
+ size_t pos = stripped.find_last_not_of ("'") + 1;
+ if (pos < stripped.length ())
+ stripped.erase (pos);
+
+ /* show candidates when pinyin cursor is at end. */
+ if (lookup_cursor == stripped.length ())
+ lookup_cursor = 0;
+ return lookup_cursor;
+}
diff --git a/src/PYPFullPinyinEditor.h b/src/PYPFullPinyinEditor.h
index cffbdd9..84a160f 100644
--- a/src/PYPFullPinyinEditor.h
+++ b/src/PYPFullPinyinEditor.h
@@ -44,6 +44,8 @@ protected:
virtual void updatePinyin (void);
+ virtual guint getLookupCursor (void);
+
};
};
diff --git a/src/PYPPhoneticEditor.cc b/src/PYPPhoneticEditor.cc
index 517bac4..0ef11d7 100644
--- a/src/PYPPhoneticEditor.cc
+++ b/src/PYPPhoneticEditor.cc
@@ -365,15 +365,8 @@ PhoneticEditor::getLookupCursor (void)
{
guint lookup_cursor = getPinyinCursor ();
- /* as pinyin_get_pinyin_offset can't handle the last "'" characters,
- strip the string to work around it here. */
- String stripped = m_text;
- size_t pos = stripped.find_last_not_of ("'") + 1;
- if (pos < stripped.length ())
- stripped.erase (pos);
-
/* show candidates when pinyin cursor is at end. */
- if (lookup_cursor == stripped.length ())
+ if (lookup_cursor == m_text.length ())
lookup_cursor = 0;
return lookup_cursor;
}
diff --git a/src/PYPPinyinEditor.cc b/src/PYPPinyinEditor.cc
index 4ed475f..b7ab8c3 100644
--- a/src/PYPPinyinEditor.cc
+++ b/src/PYPPinyinEditor.cc
@@ -266,7 +266,7 @@ PinyinEditor::updatePreeditText ()
size_t offset = 0;
guint cursor = getPinyinCursor ();
- g_assert (pinyin_get_character_offset(m_instance, sentence, cursor, &offset));
+ pinyin_get_character_offset(m_instance, sentence, cursor, &offset);
Editor::updatePreeditText (preedit_text, offset, TRUE);
if (sentence)