mirror of
https://gitlab.com/manzerbredes/i3-colors.git
synced 2025-04-06 08:36:24 +02:00
Debug/refactoring
This commit is contained in:
parent
3e8c84e135
commit
9adb0c6b4b
3 changed files with 61 additions and 23 deletions
11
TODO.org
11
TODO.org
|
@ -1,18 +1,19 @@
|
|||
#+TITLE: "i3-colors Project Todo List"
|
||||
#+AUTHOR: "Loic Guegan"
|
||||
|
||||
- Refactoring [1/3]:
|
||||
- Refactoring [1/2]:
|
||||
- [X] Change src/parser.py name => now config.py
|
||||
- [ ] Improve function/variables names
|
||||
|
||||
- YAML Theme Parser [0/2]:
|
||||
- YAML Theme Parser [1/2]:
|
||||
- [ ] Improve yaml theme loader reliability
|
||||
- [ ] Allow several metadata
|
||||
- [X] Allow several metadata
|
||||
|
||||
- Theme applying algorithm [0/3]:
|
||||
- Theme applying algorithm [1/3]:
|
||||
- [ ] Improve efficiency
|
||||
- [ ] Bugs may appear here! Found them...
|
||||
- [ ] Assume that theme to apply is well formated (checked in YAML Theme Parser)
|
||||
- [ ] If there is no "colors" field in "bar" section, we still need to apply theme
|
||||
- [X] If there is no "colors" field in "bar" section, we still need to apply theme
|
||||
|
||||
- General [1/2]:
|
||||
- [ ] Improve user API
|
||||
|
|
|
@ -17,42 +17,80 @@ config_keys=["client.focused",
|
|||
def contains(r,line):
|
||||
return(re.match(r,line)!=None)
|
||||
|
||||
def extract_config(config_file):
|
||||
def no_comment(line):
|
||||
newline=""
|
||||
for ch in line:
|
||||
if ch=='#':
|
||||
break
|
||||
else:
|
||||
newline+=ch
|
||||
return(newline)
|
||||
|
||||
def extract(config_file):
|
||||
"""
|
||||
Return a temporary file path containing the current user configuration
|
||||
without any related theme/colors lines.
|
||||
"""
|
||||
f=open(config_file,"r")
|
||||
tmp=tempfile.NamedTemporaryFile(mode="w",delete=False)
|
||||
for line in f:
|
||||
|
||||
in_colors=False
|
||||
for line_orig in f:
|
||||
line=no_comment(line_orig)
|
||||
is_theme_line=False
|
||||
for key in config_keys:
|
||||
if contains(".*"+key+"\s",line):
|
||||
is_theme_line=True
|
||||
if not(is_theme_line):
|
||||
tmp.write(line)
|
||||
|
||||
if contains(".*colors",line):
|
||||
in_colors=True
|
||||
beforeColor=re.search(".*colors",line).group(0)[:-6]
|
||||
if len(beforeColor)>0:
|
||||
tmp.write(beforeColor+"\n")
|
||||
if not(is_theme_line) and not(in_colors):
|
||||
tmp.write(line_orig)
|
||||
if contains(".*}",line) and in_colors:
|
||||
in_colors=False
|
||||
f.close()
|
||||
tmp.close()
|
||||
return(tmp.name)
|
||||
|
||||
def safe_get(theme,key):
|
||||
"""
|
||||
TODO: To remove (useless now)
|
||||
"""
|
||||
if key in theme:
|
||||
return(theme[key])
|
||||
return("")
|
||||
|
||||
def apply_to_config(tmp_config,theme):
|
||||
def write_theme(tmp_config,theme):
|
||||
"""
|
||||
Write the theme in a temporary file
|
||||
based on tmp_config file.
|
||||
"""
|
||||
f=open(tmp_config,mode="r")
|
||||
tmp=tempfile.NamedTemporaryFile(mode="w",delete=False)
|
||||
|
||||
##### Apply bar theme #####
|
||||
bar_theme=theme["bar_colors"]
|
||||
for line in f:
|
||||
if contains(".*colors\s{",line):
|
||||
tmp.write(line)
|
||||
in_bar=False
|
||||
for line_orig in f:
|
||||
line=no_comment(line_orig)
|
||||
if contains("(\s)*bar",line):
|
||||
in_bar=True
|
||||
if contains(".*}",line) and in_bar:
|
||||
beforeBrace=re.search(".*}",line).group(0)[:-1]
|
||||
if len(beforeBrace)>0:
|
||||
tmp.write(beforeBrace+"\n")
|
||||
tmp.write(" colors {\n")
|
||||
for key,value in bar_theme.items():
|
||||
if not(isinstance(value,dict)):
|
||||
tmp.write("\t"+key+" "+value+"\n")
|
||||
tmp.write(" "+key+" "+value+"\n")
|
||||
else:
|
||||
tmp.write("\t"+key+" "+value["border"]+" "+value["background"]+" "+value["text"]+"\n")
|
||||
tmp.write(" "+key+" "+value["border"]+" "+value["background"]+" "+value["text"]+"\n")
|
||||
tmp.write(" }\n}\n")
|
||||
in_bar=False
|
||||
else:
|
||||
tmp.write(line)
|
||||
tmp.write(line_orig)
|
||||
tmp.close()
|
||||
f.close()
|
||||
shutil.move(tmp.name,tmp_config)
|
||||
|
@ -65,8 +103,8 @@ def apply_to_config(tmp_config,theme):
|
|||
f.close()
|
||||
|
||||
|
||||
def apply_theme(config_file,theme):
|
||||
tmp=extract_config(config_file)
|
||||
apply_to_config(tmp,theme)
|
||||
def apply(config_file,theme):
|
||||
tmp=extract(config_file)
|
||||
write_theme(tmp,theme)
|
||||
shutil.move(tmp,config_file)
|
||||
|
||||
|
|
|
@ -1,7 +1,6 @@
|
|||
#!/usr/bin/python
|
||||
import config, theme, os, argparse, subprocess
|
||||
|
||||
|
||||
##### Utils Functions #####
|
||||
def log(msg,title=""):
|
||||
if len(title)>0:
|
||||
|
@ -21,7 +20,7 @@ args = args_parser.parse_args()
|
|||
|
||||
##### Apply Theme #####
|
||||
loaded_theme=theme.load(args.theme_path)
|
||||
config.apply_theme(os.environ["HOME"]+"/.config/i3/config",loaded_theme)
|
||||
config.apply(os.environ["HOME"]+"/.config/i3/config",loaded_theme)
|
||||
for meta_key,meta_value in loaded_theme["meta"].items():
|
||||
log(meta_value,title=meta_key.title())
|
||||
if args.restart:
|
||||
|
|
Loading…
Add table
Reference in a new issue