diff options
author | Sebastien Helleu <flashcode@flashtux.org> | 2008-10-18 18:04:02 +0200 |
---|---|---|
committer | Sebastien Helleu <flashcode@flashtux.org> | 2008-10-18 18:04:02 +0200 |
commit | 8511f9a77e45307389f54afa8ddfc1e112f0f59c (patch) | |
tree | ed72ebbfe04269fd5fa37c558552b484b9a1ff52 /src/plugins/aspell/aspell-speller.c | |
parent | bbe01eff1916434069ec4af4256789e9591687b5 (diff) | |
download | weechat-8511f9a77e45307389f54afa8ddfc1e112f0f59c.zip |
Fix compilation of aspell with autotools
Sources are renamed with prefix "weechat-", to prevent conflict between two
files called "aspell.h".
Diffstat (limited to 'src/plugins/aspell/aspell-speller.c')
-rw-r--r-- | src/plugins/aspell/aspell-speller.c | 237 |
1 files changed, 0 insertions, 237 deletions
diff --git a/src/plugins/aspell/aspell-speller.c b/src/plugins/aspell/aspell-speller.c deleted file mode 100644 index f066cc64a..000000000 --- a/src/plugins/aspell/aspell-speller.c +++ /dev/null @@ -1,237 +0,0 @@ -/* - * Copyright (c) 2003-2008 by FlashCode <flashcode@flashtux.org> - * See README for License detail, AUTHORS for developers list. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program. If not, see <http://www.gnu.org/licenses/>. - */ - -/* aspell-speller.c: speller management for aspell plugin */ - - -#include <stdlib.h> -#include <string.h> - -#include "../weechat-plugin.h" -#include "aspell.h" -#include "aspell-speller.h" - - -struct t_aspell_speller *weechat_aspell_spellers = NULL; -struct t_aspell_speller *last_weechat_aspell_speller = NULL; - - -/* - * weechat_aspell_speller_exists: return 1 if an aspell dict exists for a lang, - * 0 otherwise - */ - -int -weechat_aspell_speller_exists (const char *lang) -{ - struct AspellConfig *config; - AspellDictInfoList *list; - AspellDictInfoEnumeration *el; - const AspellDictInfo *dict; - int rc; - - rc = 0; - - config = new_aspell_config (); - list = get_aspell_dict_info_list (config); - el = aspell_dict_info_list_elements (list); - - while ((dict = aspell_dict_info_enumeration_next (el))) - { - if (strcmp (dict->name, lang) == 0) - { - rc = 1; - break; - } - } - - delete_aspell_dict_info_enumeration (el); - delete_aspell_config (config); - - return rc; -} - -/* - * weechat_aspell_speller_check_dictionaries: check dictionaries (called when - * user creates/changes dictionaries - * for a buffer) - */ - -void -weechat_aspell_speller_check_dictionaries (const char *dict_list) -{ - char **argv; - int argc, i; - - if (dict_list) - { - argv = weechat_string_explode (dict_list, ",", 0, 0, &argc); - if (argv) - { - for (i = 0; i < argc; i++) - { - if (!weechat_aspell_speller_exists (argv[i])) - { - weechat_printf (NULL, - _("%s: warning: dictionary \"%s\" is not " - "available on your system"), - ASPELL_PLUGIN_NAME, argv[i]); - } - } - weechat_string_free_exploded (argv); - } - } -} - -/* - * weechat_aspell_speller_search: search a speller - */ - -struct t_aspell_speller * -weechat_aspell_speller_search (const char *lang) -{ - struct t_aspell_speller *ptr_speller; - - for (ptr_speller = weechat_aspell_spellers; ptr_speller; - ptr_speller = ptr_speller->next_speller) - { - if (strcmp (ptr_speller->lang, lang) == 0) - return ptr_speller; - } - - /* no speller found */ - return NULL; -} - -/* - * weechat_aspell_speller_new: create and add a new speller instance - */ - -struct t_aspell_speller * -weechat_aspell_speller_new (const char *lang) -{ - struct t_aspell_speller *new_speller; - AspellConfig *config; - AspellCanHaveError *ret; - - if (!lang) - return NULL; - - if (aspell_debug) - { - weechat_printf (NULL, - "%s: creating new speller for lang \"%s\"", - ASPELL_PLUGIN_NAME, lang); - } - - /* create a speller instance for the newly created cell */ - config = new_aspell_config(); - aspell_config_replace (config, "lang", lang); - - ret = new_aspell_speller (config); - - if (aspell_error (ret) != 0) - { - weechat_printf (NULL, - "%s%s: error: %s", - weechat_prefix ("error"), ASPELL_PLUGIN_NAME, - aspell_error_message (ret)); - delete_aspell_config (config); - delete_aspell_can_have_error (ret); - return NULL; - } - - /* create and add a new speller cell */ - new_speller = malloc (sizeof (*new_speller)); - if (!new_speller) - { - weechat_printf (NULL, - _("%s%s: not enough memory to create new speller"), - weechat_prefix ("error"), ASPELL_PLUGIN_NAME); - return NULL; - } - - new_speller->speller = to_aspell_speller (ret); - new_speller->lang = strdup (lang); - - /* add speller to list */ - new_speller->prev_speller = last_weechat_aspell_speller; - new_speller->next_speller = NULL; - if (weechat_aspell_spellers) - last_weechat_aspell_speller->next_speller = new_speller; - else - weechat_aspell_spellers = new_speller; - last_weechat_aspell_speller = new_speller; - - /* free config */ - delete_aspell_config (config); - - return new_speller; -} - -/* - * weechat_aspell_speller_free: remove a speller instance - */ - -void -weechat_aspell_speller_free (struct t_aspell_speller *speller) -{ - if (!speller) - return; - - if (aspell_debug) - { - weechat_printf (NULL, - "%s: removing speller for lang \"%s\"", - ASPELL_PLUGIN_NAME, speller->lang); - } - - /* free data */ - if (speller->speller) - { - aspell_speller_save_all_word_lists (speller->speller); - delete_aspell_speller (speller->speller); - } - if (speller->lang) - free (speller->lang); - - /* remove speller from list */ - if (speller->prev_speller) - (speller->prev_speller)->next_speller = speller->next_speller; - if (speller->next_speller) - (speller->next_speller)->prev_speller = speller->prev_speller; - if (weechat_aspell_spellers == speller) - weechat_aspell_spellers = speller->next_speller; - if (last_weechat_aspell_speller == speller) - last_weechat_aspell_speller = speller->prev_speller; - - free (speller); -} - -/* - * weechat_aspell_speller_free_all: free all spellers - */ - -void -weechat_aspell_speller_free_all () -{ - while (weechat_aspell_spellers) - { - weechat_aspell_speller_free (weechat_aspell_spellers); - } -} |