X-Git-Url: https://vcs.fsf.org/?p=rainbowstream.git;a=blobdiff_plain;f=rainbowstream%2Fconfig.py;h=ff2d17df7e51db45591898f5ca442f46d5e853de;hp=de49969846a83d7712b02c192de2b37057bd684e;hb=8b8566d13f923932bee8eec9487d35956797b796;hpb=92be926e9093ad23c463ba39c94047d883e779be diff --git a/rainbowstream/config.py b/rainbowstream/config.py index de49969..ff2d17d 100644 --- a/rainbowstream/config.py +++ b/rainbowstream/config.py @@ -2,7 +2,7 @@ import json import re import os import os.path -from twitter.util import printNicely +from collections import OrderedDict # Regular expression for comments comment_re = re.compile( @@ -14,21 +14,46 @@ def load_config(filepath): """ Load config from filepath """ - try: - with open(filepath) as f: - content = ''.join(f.readlines()) + with open(filepath) as f: + content = ''.join(f.readlines()) + match = comment_re.search(content) + while match: + content = content[:match.start()] + content[match.end():] match = comment_re.search(content) - while match: - content = content[:match.start()] + content[match.end():] - match = comment_re.search(content) - data = json.loads(content) - for d in data: - globals()[d] = data[d] - except: - pass + return json.loads(content, object_pairs_hook=OrderedDict) -# Load colorset -default_config = 'rainbowstream/colorset/default.json' -rainbow_config = os.environ.get('HOME', os.environ.get('USERPROFILE','')) + os.sep + '.rainbow_config.json' -load_config(default_config) -load_config(rainbow_config) +# Config dictionary +c = {} + +# Load the initial config +config = os.path.dirname( + __file__) + '/colorset/config' +try: + data = load_config(config) + for d in data: + c[d] = data[d] +except: + pass + +# Load user's config +rainbow_config = os.environ.get( + 'HOME', + os.environ.get( + 'USERPROFILE', + '')) + os.sep + '.rainbow_config.json' +try: + data = load_config(rainbow_config) + for d in data: + c[d] = data[d] +except: + print('It seems that ~/.rainbow_config.json has wrong format :(') + +# Load default theme +theme_file = os.path.dirname( + __file__) + '/colorset/' + c['THEME'] + '.json' +try: + data = load_config(theme_file) + for d in data: + c[d] = data[d] +except: + pass