diff options
author | Timo Sirainen <cras@irssi.org> | 1999-09-03 14:32:03 +0000 |
---|---|---|
committer | cras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564> | 1999-09-03 14:32:03 +0000 |
commit | ce0a796a235fb1bfd8cf5aebfd5198cc066852ee (patch) | |
tree | d701f83288a60c5efd07f1a3d728a586383bd5c5 /src/lib-config/irssi-config.c | |
parent | 770ae4596d3e826c63e8c9fa441d65bd0889f03c (diff) | |
download | irssi-ce0a796a235fb1bfd8cf5aebfd5198cc066852ee.zip |
Initial revision
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@4 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src/lib-config/irssi-config.c')
-rw-r--r-- | src/lib-config/irssi-config.c | 191 |
1 files changed, 191 insertions, 0 deletions
diff --git a/src/lib-config/irssi-config.c b/src/lib-config/irssi-config.c new file mode 100644 index 00000000..dbfb5d41 --- /dev/null +++ b/src/lib-config/irssi-config.c @@ -0,0 +1,191 @@ +/* + config.c : Functions for reading onfiguration file + + Copyright (C) 1999 Timo Sirainen + + 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 2 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, write to the Free Software + Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +*/ + +#include "../common.h" +#include "../irc-base/irc-base.h" + +proplist_t cprop = NULL; + +gboolean config_get_bool(proplist_t prop, gchar *key, gboolean def) +{ + proplist_t pkey, pvalue; + gchar *value; + + if (prop == NULL) + return def; + + pkey = PLMakeString(key); + pvalue = PLGetDictionaryEntry(prop, pkey); + PLRelease(pkey); + if (pvalue == NULL) return def; + + value = PLGetString(pvalue); + return toupper(*value) == 'T' || toupper(*value) == 'Y'; +} + +gint config_get_int(proplist_t prop, gchar *key, gint def) +{ + proplist_t pkey, pvalue; + gint num; + + if (prop == NULL) + return def; + + pkey = PLMakeString(key); + pvalue = PLGetDictionaryEntry(prop, pkey); + PLRelease(pkey); + if (pvalue == NULL) return def; + + return sscanf(PLGetString(pvalue), "%d", &num) != 1 ? def : num; +} + +gchar *config_get_str(proplist_t prop, gchar *key, gchar *def) +{ + proplist_t pkey, pvalue; + + if (prop == NULL) + return def; + + pkey = PLMakeString(key); + pvalue = PLGetDictionaryEntry(prop, pkey); + PLRelease(pkey); + + return pvalue == NULL ? def : PLGetString(pvalue); +} + +proplist_t config_get_prop(proplist_t prop, gchar *key) +{ + proplist_t ret, pkey; + + pkey = PLMakeString(key); + ret = PLGetDictionaryEntry(prop, pkey); + PLRelease(pkey); + + return ret; +} + +proplist_t config_make_dict(proplist_t prop, gchar *section) +{ + proplist_t psect, pkey; + + pkey = PLMakeString(section); + psect = PLMakeDictionaryFromEntries(NULL, NULL); + prop = PLInsertDictionaryEntry(prop, pkey, psect); + return prop; +} + +proplist_t config_set_str(proplist_t prop, gchar *key, gchar *value) +{ + proplist_t pkey, pvalue; + + pkey = PLMakeString(key); pvalue = PLMakeString(value); + prop = PLInsertDictionaryEntry(prop, pkey, pvalue); + PLRelease(pkey); PLRelease(pvalue); + return prop; +} + +proplist_t config_set_int(proplist_t prop, gchar *key, gint value) +{ + proplist_t pkey, pvalue; + gchar *strval; + + strval = g_strdup_printf("%d", value); + pkey = PLMakeString(key); pvalue = PLMakeString(strval); + prop = PLInsertDictionaryEntry(prop, pkey, pvalue); + PLRelease(pkey); PLRelease(pvalue); + g_free(strval); + return prop; +} + +proplist_t config_set_bool(proplist_t prop, gchar *key, gboolean value) +{ + proplist_t pkey, pvalue; + + pkey = PLMakeString(key); pvalue = PLMakeString(value ? "Yes" : "No"); + prop = PLInsertDictionaryEntry(prop, pkey, pvalue); + PLRelease(pkey); PLRelease(pvalue); + return prop; +} + +proplist_t config_clean_key(proplist_t prop, gchar *key) +{ + proplist_t pkey; + + pkey = PLMakeString(key); + PLRemoveDictionaryEntry(prop, pkey); + PLRelease(pkey); + return prop; +} + +proplist_t config_section(proplist_t prop, gchar *section) +{ + proplist_t ret, pkey, psect; + + pkey = PLMakeString(section); + ret = PLGetDictionaryEntry(prop, pkey); + if (ret == NULL) + { + psect = PLMakeDictionaryFromEntries(NULL, NULL); + prop = PLInsertDictionaryEntry(prop, pkey, psect); + ret = PLGetDictionaryEntry(prop, pkey); + } + PLRelease(pkey); + + return ret; +} + +proplist_t config_list_section(proplist_t prop, gchar *section) +{ + proplist_t ret, pkey, psect; + + pkey = PLMakeString(section); + ret = PLGetDictionaryEntry(prop, pkey); + if (ret == NULL) + { + psect = PLMakeArrayFromElements(NULL); + prop = PLInsertDictionaryEntry(prop, pkey, psect); + ret = PLGetDictionaryEntry(prop, pkey); + } + PLRelease(pkey); + + return ret; +} + +gint config_list_find(proplist_t prop, gchar *key, gchar *value) +{ + proplist_t item; + gint num, max; + gchar *ret; + + if (prop == NULL) + return -1; + + max = PLGetNumberOfElements(prop); + for (num = 0; num < max; num++) + { + item = PLGetArrayElement(prop, num); + ret = config_get_str(item, key, NULL); + if (ret != NULL && g_strcasecmp(ret, value) == 0) + return num; + } + + return -1; +} + |