From e2295b71251476650fb376a3d973c53e0c319bdc Mon Sep 17 00:00:00 2001 From: Peng Wu Date: Thu, 6 May 2010 16:24:28 +0800 Subject: [PATCH] add fillCommandCandidates(string) implementation. --- src/ExtEditor.cc | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/src/ExtEditor.cc b/src/ExtEditor.cc index 3f0addf..f4a2d7d 100644 --- a/src/ExtEditor.cc +++ b/src/ExtEditor.cc @@ -88,9 +88,11 @@ ExtEditor::updateStateFromInput() bool ExtEditor::fillCommandCandidates() { + + /* try to replace this with fillCommandCandidates("") call. */ clearLookupTable(); - /* fill Candidates here. */ + /* fill candidates here. */ const GArray * commands = ibus_engine_plugin_get_available_commands(m_lua_plugin); for ( int i = 0; i < commands->len; ++i){ lua_command_t * command = &g_array_index(commands, lua_command_t, i); @@ -105,6 +107,21 @@ ExtEditor::fillCommandCandidates() bool ExtEditor::fillCommandCandidates(std::string prefix) { + clearLookupTable(); + + /* fill candidates here. */ + int len = prefix.length(); + const char * prefix_str = prefix.c_str(); + const GArray * commands = ibus_engine_plugin_get_available_commands(m_lua_plugin); + for ( int i = 0; i < commands->len; ++i){ + lua_command_t * command = &g_array_index(commands, lua_command_t, i); + if ( strncmp(prefix_str, command->command_name, len) == 0){ + m_lookup_table.appendLabel(Text(command->command_name)); + m_lookup_table.appendCandidate(Text(command->description)); + } + } + + sendLookupTable(); return true; } -- 2.7.4