fix bug
[rainbowstream.git] / rainbowstream / config.py
index af03a1b144d8146516ace13c9b2e67eb09c68469..697361d5369adfe51bba161fa88599a9d8f23914 100644 (file)
@@ -1,21 +1,50 @@
-# Max Search record
-SEARCH_MAX_RECORD = 5
-# Default home tweet
-HOME_TWEET_NUM = 5
-# Autocomplete history
-HISTORY_FILENAME = 'completer.hist'
+import json
+import re
+import os
+import os.path
 
-# Stream Domain
-USER_DOMAIN = 'userstream.twitter.com'
-PUBLIC_DOMAIN = 'stream.twitter.com'
-SITE_DOMAIN = 'sitestream.twitter.com'
-# Actually called
-DOMAIN = USER_DOMAIN
+from .db import *
 
-# Filter and Ignore list ex: ['@fat','@mdo']
-ONLY_LIST = []
-IGNORE_LIST = []
+db = RainbowDB()
 
-# Image shift and size
-IMAGE_SHIFT = 10
-IMAGE_MAX_HEIGHT = 300
\ No newline at end of file
+# Regular expression for comments
+comment_re = re.compile(
+    '(^)?[^\S\n]*/(?:\*(.*?)\*/[^\S\n]*|/[^\n]*)($)?',
+    re.DOTALL | re.MULTILINE
+)
+
+
+def load_config(filepath):
+    """
+    Load config from filepath
+    """
+    try:
+        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)
+        return json.loads(content)
+    except IOError:
+        return None
+
+# Load default colorset
+c = {}
+default_config = 'rainbowstream/colorset/default.json'
+data = load_config(default_config)
+if data:
+    for d in data:
+        c[d] = data[d]
+db.theme_store('default')
+# Load user's colorset
+rainbow_config = os.environ.get(
+    'HOME',
+    os.environ.get(
+        'USERPROFILE',
+        '')) + os.sep + '.rainbow_config.json'
+data = load_config(rainbow_config)
+if data:
+    for d in data:
+        c[d] = data[d]
+    db.theme_update('user')