summaryrefslogtreecommitdiff
path: root/src/lib-config/irssi-config.c
diff options
context:
space:
mode:
authorTimo Sirainen <cras@irssi.org>1999-09-03 14:32:03 +0000
committercras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564>1999-09-03 14:32:03 +0000
commitce0a796a235fb1bfd8cf5aebfd5198cc066852ee (patch)
treed701f83288a60c5efd07f1a3d728a586383bd5c5 /src/lib-config/irssi-config.c
parent770ae4596d3e826c63e8c9fa441d65bd0889f03c (diff)
downloadirssi-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.c191
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;
+}
+