diff --git a/src/rime/lever/levers_api_impl.h b/src/rime/lever/levers_api_impl.h new file mode 100644 index 0000000000..c2a60d1c49 --- /dev/null +++ b/src/rime/lever/levers_api_impl.h @@ -0,0 +1,278 @@ +// implementation of levers api + +#include +#include +#include +#include + +using namespace rime; + +static RimeCustomSettings* rime_levers_custom_settings_init( + const char* config_id, + const char* generator_id) { + return reinterpret_cast(new CustomSettings( + &Service::instance().deployer(), config_id, generator_id)); +} + +static void rime_levers_custom_settings_destroy(RimeCustomSettings* settings) { + delete reinterpret_cast(settings); +} + +static Bool rime_levers_load_settings(RimeCustomSettings* settings) { + return Bool(reinterpret_cast(settings)->Load()); +} + +static Bool rime_levers_save_settings(RimeCustomSettings* settings) { + return Bool(reinterpret_cast(settings)->Save()); +} + +static Bool rime_levers_customize_bool(RimeCustomSettings* settings, + const char* key, + Bool value) { + an item = New(bool(value)); + auto custom_settings = reinterpret_cast(settings); + return custom_settings->Customize(key, item); +} + +static Bool rime_levers_customize_int(RimeCustomSettings* settings, + const char* key, + int value) { + an item = New(value); + auto custom_settings = reinterpret_cast(settings); + return custom_settings->Customize(key, item); +} + +static Bool rime_levers_customize_double(RimeCustomSettings* settings, + const char* key, + double value) { + an item = New(value); + auto custom_settings = reinterpret_cast(settings); + return custom_settings->Customize(key, item); +} + +static Bool rime_levers_customize_string(RimeCustomSettings* settings, + const char* key, + const char* value) { + an item = New(value); + auto custom_settings = reinterpret_cast(settings); + return custom_settings->Customize(key, item); +} + +static Bool rime_levers_customize_item(RimeCustomSettings* settings, + const char* key, + RimeConfig* value) { + an item; + if (value) { + if (Config* v = reinterpret_cast(value->ptr)) { + item = v->GetItem(""); + } + } + auto custom_settings = reinterpret_cast(settings); + return custom_settings->Customize(key, item); +} + +static Bool rime_levers_is_first_run(RimeCustomSettings* settings) { + return reinterpret_cast(settings)->IsFirstRun(); +} + +static Bool rime_levers_settings_is_modified(RimeCustomSettings* settings) { + return reinterpret_cast(settings)->modified(); +} + +static Bool rime_levers_settings_get_config(RimeCustomSettings* settings, + RimeConfig* config) { + if (!config) + return False; + config->ptr = reinterpret_cast(settings)->config(); + return Bool(!!config->ptr); +} + +static RimeSwitcherSettings* rime_levers_switcher_settings_init() { + return reinterpret_cast( + new SwitcherSettings(&Service::instance().deployer())); +} + +static Bool rime_levers_get_available_schema_list( + RimeSwitcherSettings* settings, + RimeSchemaList* list) { + auto ss = reinterpret_cast(settings); + list->size = 0; + list->list = NULL; + if (ss->available().empty()) { + return False; + } + list->list = new RimeSchemaListItem[ss->available().size()]; + for (const auto& info : ss->available()) { + auto& item(list->list[list->size]); + item.schema_id = const_cast(info.schema_id.c_str()); + item.name = const_cast(info.name.c_str()); + item.reserved = const_cast(&info); + ++list->size; + } + return True; +} + +static Bool rime_levers_get_selected_schema_list(RimeSwitcherSettings* settings, + RimeSchemaList* list) { + auto ss = reinterpret_cast(settings); + list->size = 0; + list->list = NULL; + if (ss->selection().empty()) { + return False; + } + list->list = new RimeSchemaListItem[ss->selection().size()]; + for (const string& schema_id : ss->selection()) { + auto& item(list->list[list->size]); + item.schema_id = const_cast(schema_id.c_str()); + item.name = NULL; + item.reserved = NULL; + ++list->size; + } + return True; +} + +static void rime_levers_schema_list_destroy(RimeSchemaList* list) { + delete[] list->list; + list->size = 0; + list->list = NULL; +} + +static const char* rime_levers_get_schema_id(RimeSchemaInfo* info) { + auto si = reinterpret_cast(info); + return si && !si->schema_id.empty() ? si->schema_id.c_str() : NULL; +} + +static const char* rime_levers_get_schema_name(RimeSchemaInfo* info) { + auto si = reinterpret_cast(info); + return si && !si->name.empty() ? si->name.c_str() : NULL; +} + +static const char* rime_levers_get_schema_version(RimeSchemaInfo* info) { + auto si = reinterpret_cast(info); + return si && !si->version.empty() ? si->version.c_str() : NULL; +} +static const char* rime_levers_get_schema_author(RimeSchemaInfo* info) { + auto si = reinterpret_cast(info); + return si && !si->author.empty() ? si->author.c_str() : NULL; +} + +static const char* rime_levers_get_schema_description(RimeSchemaInfo* info) { + auto si = reinterpret_cast(info); + return si && !si->description.empty() ? si->description.c_str() : NULL; +} + +static const char* rime_levers_get_schema_file_path(RimeSchemaInfo* info) { + auto si = reinterpret_cast(info); + return si && !si->file_path.empty() ? si->file_path.c_str() : NULL; +} + +static Bool rime_levers_select_schemas(RimeSwitcherSettings* settings, + const char* schema_id_list[], + int count) { + auto ss = reinterpret_cast(settings); + SwitcherSettings::Selection selection; + for (int i = 0; i < count; ++i) { + selection.push_back(schema_id_list[i]); + } + return ss->Select(selection); +} + +static const char* rime_levers_get_hotkeys(RimeSwitcherSettings* settings) { + auto ss = reinterpret_cast(settings); + return !ss->hotkeys().empty() ? ss->hotkeys().c_str() : NULL; +} + +static Bool rime_levers_set_hotkeys(RimeSwitcherSettings* settings, + const char* hotkeys) { + auto ss = reinterpret_cast(settings); + return Bool(ss->SetHotkeys(hotkeys)); +} + +static Bool rime_levers_user_dict_iterator_init(RimeUserDictIterator* iter) { + UserDictManager mgr(&Service::instance().deployer()); + UserDictList* list = new UserDictList; + mgr.GetUserDictList(list); + if (list->empty()) { + delete list; + return False; + } + iter->ptr = list; + iter->i = 0; + return True; +} + +static void rime_levers_user_dict_iterator_destroy(RimeUserDictIterator* iter) { + delete (UserDictList*)iter->ptr; + iter->ptr = NULL; + iter->i = 0; +} + +static const char* rime_levers_next_user_dict(RimeUserDictIterator* iter) { + auto list = reinterpret_cast(iter->ptr); + if (!list || iter->i >= list->size()) { + return NULL; + } + return (*list)[iter->i++].c_str(); +} + +static Bool rime_levers_backup_user_dict(const char* dict_name) { + UserDictManager mgr(&Service::instance().deployer()); + return Bool(mgr.Backup(dict_name)); +} + +static Bool rime_levers_restore_user_dict(const char* snapshot_file) { + UserDictManager mgr(&Service::instance().deployer()); + return Bool(mgr.Restore(path(snapshot_file))); +} + +static int rime_levers_export_user_dict(const char* dict_name, + const char* text_file) { + UserDictManager mgr(&Service::instance().deployer()); + return mgr.Export(dict_name, path(text_file)); +} + +static int rime_levers_import_user_dict(const char* dict_name, + const char* text_file) { + UserDictManager mgr(&Service::instance().deployer()); + return mgr.Import(dict_name, path(text_file)); +} + +static RimeCustomApi* RIME_FLAVORED(rime_levers_get_api)() { + static RIME_FLAVORED(RimeLeversApi) s_api = {0}; + if (!s_api.data_size) { + RIME_STRUCT_INIT(RIME_FLAVORED(RimeLeversApi), s_api); + s_api.custom_settings_init = rime_levers_custom_settings_init; + s_api.custom_settings_destroy = rime_levers_custom_settings_destroy; + s_api.load_settings = rime_levers_load_settings; + s_api.save_settings = rime_levers_save_settings; + s_api.customize_bool = rime_levers_customize_bool; + s_api.customize_int = rime_levers_customize_int; + s_api.customize_double = rime_levers_customize_double; + s_api.customize_string = rime_levers_customize_string; + s_api.is_first_run = rime_levers_is_first_run; + s_api.settings_is_modified = rime_levers_settings_is_modified; + s_api.settings_get_config = rime_levers_settings_get_config; + s_api.switcher_settings_init = rime_levers_switcher_settings_init; + s_api.get_available_schema_list = rime_levers_get_available_schema_list; + s_api.get_selected_schema_list = rime_levers_get_selected_schema_list; + s_api.schema_list_destroy = rime_levers_schema_list_destroy; + s_api.get_schema_id = rime_levers_get_schema_id; + s_api.get_schema_name = rime_levers_get_schema_name; + s_api.get_schema_version = rime_levers_get_schema_version; + s_api.get_schema_author = rime_levers_get_schema_author; + s_api.get_schema_description = rime_levers_get_schema_description; + s_api.get_schema_file_path = rime_levers_get_schema_file_path; + s_api.select_schemas = rime_levers_select_schemas; + s_api.get_hotkeys = rime_levers_get_hotkeys; + s_api.set_hotkeys = rime_levers_set_hotkeys; + s_api.user_dict_iterator_init = rime_levers_user_dict_iterator_init; + s_api.user_dict_iterator_destroy = rime_levers_user_dict_iterator_destroy; + s_api.next_user_dict = rime_levers_next_user_dict; + s_api.backup_user_dict = rime_levers_backup_user_dict; + s_api.restore_user_dict = rime_levers_restore_user_dict; + s_api.export_user_dict = rime_levers_export_user_dict; + s_api.import_user_dict = rime_levers_import_user_dict; + s_api.customize_item = rime_levers_customize_item; + } + return (RimeCustomApi*)&s_api; +} diff --git a/src/rime/lever/levers_module.cc b/src/rime/lever/levers_module.cc index 7bf261644f..23667e938d 100644 --- a/src/rime/lever/levers_module.cc +++ b/src/rime/lever/levers_module.cc @@ -6,15 +6,9 @@ // #include -#include #include #include -#include - -#include #include -#include -#include using namespace rime; @@ -38,279 +32,9 @@ static void rime_levers_initialize() { static void rime_levers_finalize() {} -// implementation of levers api - -static RimeCustomSettings* rime_levers_custom_settings_init( - const char* config_id, - const char* generator_id) { - return reinterpret_cast(new CustomSettings( - &Service::instance().deployer(), config_id, generator_id)); -} - -static void rime_levers_custom_settings_destroy(RimeCustomSettings* settings) { - delete reinterpret_cast(settings); -} - -static Bool rime_levers_load_settings(RimeCustomSettings* settings) { - return Bool(reinterpret_cast(settings)->Load()); -} - -static Bool rime_levers_save_settings(RimeCustomSettings* settings) { - return Bool(reinterpret_cast(settings)->Save()); -} - -static Bool rime_levers_customize_bool(RimeCustomSettings* settings, - const char* key, - Bool value) { - an item = New(bool(value)); - auto custom_settings = reinterpret_cast(settings); - return custom_settings->Customize(key, item); -} - -static Bool rime_levers_customize_int(RimeCustomSettings* settings, - const char* key, - int value) { - an item = New(value); - auto custom_settings = reinterpret_cast(settings); - return custom_settings->Customize(key, item); -} - -static Bool rime_levers_customize_double(RimeCustomSettings* settings, - const char* key, - double value) { - an item = New(value); - auto custom_settings = reinterpret_cast(settings); - return custom_settings->Customize(key, item); -} - -static Bool rime_levers_customize_string(RimeCustomSettings* settings, - const char* key, - const char* value) { - an item = New(value); - auto custom_settings = reinterpret_cast(settings); - return custom_settings->Customize(key, item); -} - -static Bool rime_levers_customize_item(RimeCustomSettings* settings, - const char* key, - RimeConfig* value) { - an item; - if (value) { - if (Config* v = reinterpret_cast(value->ptr)) { - item = v->GetItem(""); - } - } - auto custom_settings = reinterpret_cast(settings); - return custom_settings->Customize(key, item); -} - -static Bool rime_levers_is_first_run(RimeCustomSettings* settings) { - return reinterpret_cast(settings)->IsFirstRun(); -} - -static Bool rime_levers_settings_is_modified(RimeCustomSettings* settings) { - return reinterpret_cast(settings)->modified(); -} - -static Bool rime_levers_settings_get_config(RimeCustomSettings* settings, - RimeConfig* config) { - if (!config) - return False; - config->ptr = reinterpret_cast(settings)->config(); - return Bool(!!config->ptr); -} - -static RimeSwitcherSettings* rime_levers_switcher_settings_init() { - return reinterpret_cast( - new SwitcherSettings(&Service::instance().deployer())); -} - -static Bool rime_levers_get_available_schema_list( - RimeSwitcherSettings* settings, - RimeSchemaList* list) { - auto ss = reinterpret_cast(settings); - list->size = 0; - list->list = NULL; - if (ss->available().empty()) { - return False; - } - list->list = new RimeSchemaListItem[ss->available().size()]; - for (const auto& info : ss->available()) { - auto& item(list->list[list->size]); - item.schema_id = const_cast(info.schema_id.c_str()); - item.name = const_cast(info.name.c_str()); - item.reserved = const_cast(&info); - ++list->size; - } - return True; -} - -static Bool rime_levers_get_selected_schema_list(RimeSwitcherSettings* settings, - RimeSchemaList* list) { - auto ss = reinterpret_cast(settings); - list->size = 0; - list->list = NULL; - if (ss->selection().empty()) { - return False; - } - list->list = new RimeSchemaListItem[ss->selection().size()]; - for (const string& schema_id : ss->selection()) { - auto& item(list->list[list->size]); - item.schema_id = const_cast(schema_id.c_str()); - item.name = NULL; - item.reserved = NULL; - ++list->size; - } - return True; -} - -static void rime_levers_schema_list_destroy(RimeSchemaList* list) { - delete[] list->list; - list->size = 0; - list->list = NULL; -} - -static const char* rime_levers_get_schema_id(RimeSchemaInfo* info) { - auto si = reinterpret_cast(info); - return si && !si->schema_id.empty() ? si->schema_id.c_str() : NULL; -} - -static const char* rime_levers_get_schema_name(RimeSchemaInfo* info) { - auto si = reinterpret_cast(info); - return si && !si->name.empty() ? si->name.c_str() : NULL; -} - -static const char* rime_levers_get_schema_version(RimeSchemaInfo* info) { - auto si = reinterpret_cast(info); - return si && !si->version.empty() ? si->version.c_str() : NULL; -} -static const char* rime_levers_get_schema_author(RimeSchemaInfo* info) { - auto si = reinterpret_cast(info); - return si && !si->author.empty() ? si->author.c_str() : NULL; -} - -static const char* rime_levers_get_schema_description(RimeSchemaInfo* info) { - auto si = reinterpret_cast(info); - return si && !si->description.empty() ? si->description.c_str() : NULL; -} - -static const char* rime_levers_get_schema_file_path(RimeSchemaInfo* info) { - auto si = reinterpret_cast(info); - return si && !si->file_path.empty() ? si->file_path.c_str() : NULL; -} - -static Bool rime_levers_select_schemas(RimeSwitcherSettings* settings, - const char* schema_id_list[], - int count) { - auto ss = reinterpret_cast(settings); - SwitcherSettings::Selection selection; - for (int i = 0; i < count; ++i) { - selection.push_back(schema_id_list[i]); - } - return ss->Select(selection); -} - -static const char* rime_levers_get_hotkeys(RimeSwitcherSettings* settings) { - auto ss = reinterpret_cast(settings); - return !ss->hotkeys().empty() ? ss->hotkeys().c_str() : NULL; -} - -static Bool rime_levers_set_hotkeys(RimeSwitcherSettings* settings, - const char* hotkeys) { - auto ss = reinterpret_cast(settings); - return Bool(ss->SetHotkeys(hotkeys)); -} - -static Bool rime_levers_user_dict_iterator_init(RimeUserDictIterator* iter) { - UserDictManager mgr(&Service::instance().deployer()); - UserDictList* list = new UserDictList; - mgr.GetUserDictList(list); - if (list->empty()) { - delete list; - return False; - } - iter->ptr = list; - iter->i = 0; - return True; -} - -static void rime_levers_user_dict_iterator_destroy(RimeUserDictIterator* iter) { - delete (UserDictList*)iter->ptr; - iter->ptr = NULL; - iter->i = 0; -} - -static const char* rime_levers_next_user_dict(RimeUserDictIterator* iter) { - auto list = reinterpret_cast(iter->ptr); - if (!list || iter->i >= list->size()) { - return NULL; - } - return (*list)[iter->i++].c_str(); -} - -static Bool rime_levers_backup_user_dict(const char* dict_name) { - UserDictManager mgr(&Service::instance().deployer()); - return Bool(mgr.Backup(dict_name)); -} - -static Bool rime_levers_restore_user_dict(const char* snapshot_file) { - UserDictManager mgr(&Service::instance().deployer()); - return Bool(mgr.Restore(path(snapshot_file))); -} - -static int rime_levers_export_user_dict(const char* dict_name, - const char* text_file) { - UserDictManager mgr(&Service::instance().deployer()); - return mgr.Export(dict_name, path(text_file)); -} - -static int rime_levers_import_user_dict(const char* dict_name, - const char* text_file) { - UserDictManager mgr(&Service::instance().deployer()); - return mgr.Import(dict_name, path(text_file)); -} - -// - -static RimeCustomApi* rime_levers_get_api() { - static RimeLeversApi s_api = {0}; - if (!s_api.data_size) { - RIME_STRUCT_INIT(RimeLeversApi, s_api); - s_api.custom_settings_init = rime_levers_custom_settings_init; - s_api.custom_settings_destroy = rime_levers_custom_settings_destroy; - s_api.load_settings = rime_levers_load_settings; - s_api.save_settings = rime_levers_save_settings; - s_api.customize_bool = rime_levers_customize_bool; - s_api.customize_int = rime_levers_customize_int; - s_api.customize_double = rime_levers_customize_double; - s_api.customize_string = rime_levers_customize_string; - s_api.is_first_run = rime_levers_is_first_run; - s_api.settings_is_modified = rime_levers_settings_is_modified; - s_api.settings_get_config = rime_levers_settings_get_config; - s_api.switcher_settings_init = rime_levers_switcher_settings_init; - s_api.get_available_schema_list = rime_levers_get_available_schema_list; - s_api.get_selected_schema_list = rime_levers_get_selected_schema_list; - s_api.schema_list_destroy = rime_levers_schema_list_destroy; - s_api.get_schema_id = rime_levers_get_schema_id; - s_api.get_schema_name = rime_levers_get_schema_name; - s_api.get_schema_version = rime_levers_get_schema_version; - s_api.get_schema_author = rime_levers_get_schema_author; - s_api.get_schema_description = rime_levers_get_schema_description; - s_api.get_schema_file_path = rime_levers_get_schema_file_path; - s_api.select_schemas = rime_levers_select_schemas; - s_api.get_hotkeys = rime_levers_get_hotkeys; - s_api.set_hotkeys = rime_levers_set_hotkeys; - s_api.user_dict_iterator_init = rime_levers_user_dict_iterator_init; - s_api.user_dict_iterator_destroy = rime_levers_user_dict_iterator_destroy; - s_api.next_user_dict = rime_levers_next_user_dict; - s_api.backup_user_dict = rime_levers_backup_user_dict; - s_api.restore_user_dict = rime_levers_restore_user_dict; - s_api.export_user_dict = rime_levers_export_user_dict; - s_api.import_user_dict = rime_levers_import_user_dict; - s_api.customize_item = rime_levers_customize_item; - } - return (RimeCustomApi*)&s_api; -} +#include +// defines rime_levers_get_api() +#include "levers_api_impl.h" RIME_REGISTER_CUSTOM_MODULE(levers) { module->get_api = rime_levers_get_api; diff --git a/src/rime/lever/levers_stdbool.cc b/src/rime/lever/levers_stdbool.cc new file mode 100644 index 0000000000..42d59cf681 --- /dev/null +++ b/src/rime/lever/levers_stdbool.cc @@ -0,0 +1,11 @@ +#include +#include +// defines rime_levers_get_api_stdbool() +#include "levers_api_impl.h" + +static void rime_levers_stdbool_initialize() {} +static void rime_levers_stdbool_finalize() {} + +RIME_REGISTER_CUSTOM_MODULE(levers_stdbool) { + module->get_api = rime_levers_get_api_stdbool; +} diff --git a/src/rime_levers_api.h b/src/rime_levers_api.h index fbd6332ac9..ba029b6f4d 100644 --- a/src/rime_levers_api.h +++ b/src/rime_levers_api.h @@ -30,7 +30,7 @@ typedef struct { size_t i; } RimeUserDictIterator; -typedef struct rime_levers_api_t { +typedef struct RIME_FLAVORED(rime_levers_api_t) { int data_size; RimeCustomSettings* (*custom_settings_init)(const char* config_id, @@ -85,7 +85,7 @@ typedef struct rime_levers_api_t { const char* key, RimeConfig* value); -} RimeLeversApi; +} RIME_FLAVORED(RimeLeversApi); #ifdef __cplusplus } diff --git a/test/flavored_api_test.cc b/test/flavored_api_test.cc index 0e0fcd3b45..feefc5e491 100644 --- a/test/flavored_api_test.cc +++ b/test/flavored_api_test.cc @@ -21,3 +21,20 @@ TEST(RimeApiStdboolTest, GetContext) { ASSERT_TRUE(rime->get_status(test_session, &status)); ASSERT_FALSE(status.is_composing); } + +TEST(RimeLeversApiStdboolTest, CustomSettings) { + RIME_FLAVORED(RimeApi)* rime = RIME_FLAVORED(rime_get_api)(); + RimeModule* module = rime->find_module("levers_stdbool"); + ASSERT_TRUE(bool(module)); + RIME_FLAVORED(RimeLeversApi)* levers = (RIME_FLAVORED(RimeLeversApi)*)module->get_api(); + ASSERT_TRUE(bool(levers)); + + ASSERT_TRUE(RIME_API_AVAILABLE(levers, custom_settings_init)); + RimeCustomSettings* custom_settings = levers->custom_settings_init("flavored_api_test", "rime_test"); + ASSERT_TRUE(bool(custom_settings)); + + ASSERT_TRUE(RIME_API_AVAILABLE(levers, customize_bool)); + ASSERT_TRUE(levers->customize_bool(custom_settings, "test_key", true)); + + levers->custom_settings_destroy(custom_settings); +}