X-Git-Url: https://jfr.im/git/erebus.git/blobdiff_plain/a4eacae2beaf344a5fd5b1d231f772e9fcbe4e10..HEAD:/config.py diff --git a/config.py b/config.py index c41e806..9755f84 100644 --- a/config.py +++ b/config.py @@ -1,9 +1,18 @@ -import ConfigParser +# Erebus IRC bot - Author: John Runyon +# vim: fileencoding=utf-8 +# "Config" class (reading/providing access to bot.config) + +from __future__ import print_function +import sys, os + +if sys.version_info.major < 3: + import ConfigParser +else: + import configparser as ConfigParser class Config(object): -# config = ConfigParser.SafeConfigParser() def __init__(self, filename, writeout=True): - self.__dict__['config'] = ConfigParser.SafeConfigParser() + self.__dict__['config'] = ConfigParser.RawConfigParser(delimiters=('=',)) self.__dict__['filename'] = filename self.__dict__['writeout'] = writeout self.config.read(filename) @@ -14,20 +23,63 @@ class Config(object): def __setattr__(self, key, value): self.config.set('erebus', key, value) - def items(self): - return self.config.items('erebus') + def __getitem__(self, section): #!! READ-ONLY !! + return {item: self.config.get(section, item) for item in self.config.options(section)} + + def level(self, cmd): + return self.config.get('levels', cmd) + + def setlevel(self, cmd, level): + self.config.set('levels', cmd, level) + + def items(self, section='erebus'): + return self.config.items(section) + + def get(self, section, key, default=None): + try: + return self.config.get(section, key) + except: + return default + def getint(self, section, key, default=0): + try: + return int(self.config.get(section, key)) + except: + return default + def getboolean(self, section, key, default=False): + val = self.get(section, key, default) + if type(val) is bool: + return val + elif val == "0" or val.lower() == "false": + return False + else: + return True + + def set(self, section, key, value): + if not self.config.has_section(section): + self.config.add_section(section) + self.config.set(section, key, str(value)) + if self.writeout: self.write() + + def delete(self, section, key): + if self.config.has_section(section): + self.config.remove_option(section, key) + if self.writeout: self.write() def write(self): - with open(self._filename, 'wb') as configfile: + with open(self.filename+'.tmp', 'w') as configfile: self.config.write(configfile) + os.rename(configfile.name, self.filename) def __del__(self): if self.writeout: self.write() - if __name__ == '__main__': import sys - cfg = Config(sys.argv[1], False) + if len(sys.argv) > 1: + cfg = Config(sys.argv[1], False) + else: + cfg = Config('bot.config', False) - for k, v in cfg.items(): - print k, '=', v + for s in cfg.config.sections(): + for k, v in cfg.items(s): + print("[%r][%r] = %r" % (s, k, v))