help command not found
[rainbowstream.git] / rainbowstream / config.py
index dcef9f716aa524811cb82a32d60b34c3f9b591f7..2a11d3bdc9ea36c23d64d172ef4c73d2f910a28f 100644 (file)
@@ -42,15 +42,12 @@ def get_all_config():
     """
     Get all config
     """
-    path = os.environ.get(
-        'HOME',
-        os.environ.get(
-            'USERPROFILE',
-            '')) + os.sep + '.rainbow_config.json'
+    path = os.path.expanduser("~") + os.sep + '.rainbow_config.json'
     data = load_config(path)
     # Hard to set from prompt
     data.pop('ONLY_LIST', None)
     data.pop('IGNORE_LIST', None)
+    data.pop('FORMAT', None)
     return data
 
 
@@ -63,9 +60,10 @@ def get_default_config(key):
     try:
         data = load_config(path)
     except:
-       raise Exception('No such config key.')
+        raise Exception('No such config key.')
     return data[key]
 
+
 def get_config(key):
     """
     Get current value of a config key
@@ -85,17 +83,19 @@ def set_config(key, value):
     elif value.lower() == 'false':
         value = False
     # Fix up
-    path = os.environ.get(
-        'HOME',
-        os.environ.get(
-            'USERPROFILE',
-            '')) + os.sep + '.rainbow_config.json'
-    data = load_config(path)
+    path = os.path.expanduser("~") + os.sep + '.rainbow_config.json'
+    data = {}
+    try:
+        data = load_config(path)
+    except:
+        pass
+    # Update global config
+    c[key] = value
+    # Update config file
     if key in data:
         fixup(data, key, value)
     else:
         data[key] = value
-        c[key] = value
     # Save
     with open(path, 'w') as out:
         json.dump(data, out, indent=4)
@@ -103,36 +103,32 @@ def set_config(key, value):
 
 
 def delete_config(key):
-   """
-   Delete a config key
-   """
-   path = os.environ.get(
-        'HOME',
-        os.environ.get(
-            'USERPROFILE',
-            '')) + os.sep + '.rainbow_config.json'
-   data = load_config(path)
-   # Drop key
-   if key in data and key in c:
-       data.pop(key)
-       c.pop(key)
-   else:
-       raise Exception('No such config key.')
-   # Save
-   with open(path, 'w') as out:
-       json.dump(data, out, indent=4)
-   os.system('chmod 777 ' + path)
+    """
+    Delete a config key
+    """
+    path = os.path.expanduser("~") + os.sep + '.rainbow_config.json'
+    data = load_config(path)
+    # Drop key
+    if key in data and key in c:
+        data.pop(key)
+        c.pop(key)
+        try:
+            data[key] = c[key] = get_default_config(key)
+        except:
+            pass
+    else:
+        raise Exception('No such config key.')
+    # Save
+    with open(path, 'w') as out:
+        json.dump(data, out, indent=4)
+    os.system('chmod 777 ' + path)
 
 
 def reload_config():
     """
     Reload config
     """
-    rainbow_config = os.environ.get(
-        'HOME',
-        os.environ.get(
-            'USERPROFILE',
-            '')) + os.sep + '.rainbow_config.json'
+    rainbow_config = os.path.expanduser("~") + os.sep + '.rainbow_config.json'
     try:
         data = load_config(rainbow_config)
         for d in data:
@@ -155,17 +151,13 @@ def init_config():
     except:
         pass
     # Load user's config
-    rainbow_config = os.environ.get(
-        'HOME',
-        os.environ.get(
-            'USERPROFILE',
-            '')) + os.sep + '.rainbow_config.json'
+    rainbow_config = os.path.expanduser("~") + 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 :(')
+        pass
     # Load default theme
     theme_file = os.path.dirname(
         __file__) + '/colorset/' + c['THEME'] + '.json'