Commit ce2778ef authored by Jacek Sowiński's avatar Jacek Sowiński

Add direct method for getting priority color

Removed `topydo.lib.Colors.Colors.get_priority_colors()` and added in
its place `topydo.lib.Colors.Colors.get_priority_color(p_priority)`.

Also moved `_name_to_ansi`, `_name_to_int`, and `_get_ansi` outside of
the class.
parent 26371a66
...@@ -122,49 +122,49 @@ class ColorsTest(TopydoTest): ...@@ -122,49 +122,49 @@ class ColorsTest(TopydoTest):
def test_priority_color1(self): def test_priority_color1(self):
config("test/data/ColorsTest1.conf") config("test/data/ColorsTest1.conf")
color = Colors().get_priority_colors() colors = Colors()
self.assertEqual(color['A'], '\033[0;38;5;1m') self.assertEqual(colors.get_priority_color('A'), '\033[0;38;5;1m')
self.assertEqual(color['B'], '\033[0;38;5;2m') self.assertEqual(colors.get_priority_color('B'), '\033[0;38;5;2m')
self.assertEqual(color['C'], '\033[0;38;5;3m') self.assertEqual(colors.get_priority_color('C'), '\033[0;38;5;3m')
def test_priority_color2(self): def test_priority_color2(self):
config("test/data/ColorsTest2.conf") config("test/data/ColorsTest2.conf")
color = Colors().get_priority_colors() colors = Colors()
self.assertEqual(color['A'], '\033[0;35m') self.assertEqual(colors.get_priority_color('A'), '\033[0;35m')
self.assertEqual(color['B'], '\033[0;1;36m') self.assertEqual(colors.get_priority_color('B'), '\033[0;1;36m')
self.assertEqual(color['C'], '\033[0;37m') self.assertEqual(colors.get_priority_color('C'), '\033[0;37m')
def test_priority_color3(self): def test_priority_color3(self):
config("test/data/ColorsTest3.conf") config("test/data/ColorsTest3.conf")
color = Colors().get_priority_colors() colors = Colors()
self.assertEqual(color['A'], '\033[0;35m') self.assertEqual(colors.get_priority_color('A'), '\033[0;35m')
self.assertEqual(color['B'], '\033[0;1;36m') self.assertEqual(colors.get_priority_color('B'), '\033[0;1;36m')
self.assertEqual(color['Z'], NEUTRAL_COLOR) self.assertEqual(colors.get_priority_color('Z'), NEUTRAL_COLOR)
self.assertEqual(color['D'], '\033[0;31m') self.assertEqual(colors.get_priority_color('D'), '\033[0;31m')
self.assertEqual(color['C'], '\033[0;38;5;7m') self.assertEqual(colors.get_priority_color('C'), '\033[0;38;5;7m')
def test_priority_color4(self): def test_priority_color4(self):
config("test/data/ColorsTest4.conf") config("test/data/ColorsTest4.conf")
color = Colors().get_priority_colors() colors = Colors()
self.assertEqual(color['A'], NEUTRAL_COLOR) self.assertEqual(colors.get_priority_color('A'), NEUTRAL_COLOR)
self.assertEqual(color['B'], NEUTRAL_COLOR) self.assertEqual(colors.get_priority_color('B'), NEUTRAL_COLOR)
self.assertEqual(color['C'], NEUTRAL_COLOR) self.assertEqual(colors.get_priority_color('C'), NEUTRAL_COLOR)
def test_empty_color_values(self): def test_empty_color_values(self):
config("test/data/ColorsTest5.conf") config("test/data/ColorsTest5.conf")
pri_color = Colors().get_priority_colors() colors = Colors()
project_color = Colors().get_project_color() project_color = colors.get_project_color()
context_color = Colors().get_context_color() context_color = colors.get_context_color()
link_color = Colors().get_link_color() link_color = colors.get_link_color()
metadata_color = Colors().get_metadata_color() metadata_color = colors.get_metadata_color()
self.assertEqual(pri_color['A'], NEUTRAL_COLOR) self.assertEqual(colors.get_priority_color('A'), NEUTRAL_COLOR)
self.assertEqual(pri_color['B'], NEUTRAL_COLOR) self.assertEqual(colors.get_priority_color('B'), NEUTRAL_COLOR)
self.assertEqual(pri_color['C'], NEUTRAL_COLOR) self.assertEqual(colors.get_priority_color('C'), NEUTRAL_COLOR)
self.assertEqual(project_color, '') self.assertEqual(project_color, '')
self.assertEqual(context_color, '') self.assertEqual(context_color, '')
self.assertEqual(link_color, '') self.assertEqual(link_color, '')
...@@ -172,15 +172,15 @@ class ColorsTest(TopydoTest): ...@@ -172,15 +172,15 @@ class ColorsTest(TopydoTest):
def test_empty_colorscheme(self): def test_empty_colorscheme(self):
config("test/data/config1") config("test/data/config1")
pri_color = Colors().get_priority_colors() colors = Colors()
project_color = Colors().get_project_color() project_color = colors.get_project_color()
context_color = Colors().get_context_color() context_color = colors.get_context_color()
link_color = Colors().get_link_color() link_color = colors.get_link_color()
metadata_color = Colors().get_metadata_color() metadata_color = colors.get_metadata_color()
self.assertEqual(pri_color['A'], '\033[0;36m') self.assertEqual(colors.get_priority_color('A'), '\033[0;36m')
self.assertEqual(pri_color['B'], '\033[0;33m') self.assertEqual(colors.get_priority_color('B'), '\033[0;33m')
self.assertEqual(pri_color['C'], '\033[0;34m') self.assertEqual(colors.get_priority_color('C'), '\033[0;34m')
self.assertEqual(project_color, '\033[1;31m') self.assertEqual(project_color, '\033[1;31m')
self.assertEqual(context_color, '\033[1;35m') self.assertEqual(context_color, '\033[1;35m')
self.assertEqual(link_color, '\033[4;36m') self.assertEqual(link_color, '\033[4;36m')
......
...@@ -59,16 +59,7 @@ def int_to_ansi(p_int, p_decorator='normal', p_safe=True, p_background=''): ...@@ -59,16 +59,7 @@ def int_to_ansi(p_int, p_decorator='normal', p_safe=True, p_background=''):
except ValueError: except ValueError:
return None return None
def _name_to_int(p_color_name):
class Colors(object):
def __init__(self):
self.priority_colors = config().priority_colors()
self.project_color = config().project_color()
self.context_color = config().context_color()
self.metadata_color = config().metadata_color()
self.link_color = config().link_color()
def _name_to_int(self, p_color_name):
""" Returns xterm color id from color name. """ """ Returns xterm color id from color name. """
color_names_dict = { color_names_dict = {
'black': 0, 'black': 0,
...@@ -94,13 +85,13 @@ class Colors(object): ...@@ -94,13 +85,13 @@ class Colors(object):
except KeyError: except KeyError:
return 404 return 404
def _name_to_ansi(self, p_color_name, p_decorator): def _name_to_ansi(p_color_name, p_decorator):
""" Returns ansi color code from color name. """ """ Returns ansi color code from color name. """
number = self._name_to_int(p_color_name) number = _name_to_int(p_color_name)
return int_to_ansi(number, p_decorator) return int_to_ansi(number, p_decorator)
def _get_ansi(self, p_color, p_decorator): def _get_ansi(p_color, p_decorator):
""" Returns ansi color code from color name or xterm color id. """ """ Returns ansi color code from color name or xterm color id. """
if p_color == '': if p_color == '':
ansi = '' ansi = ''
...@@ -108,15 +99,16 @@ class Colors(object): ...@@ -108,15 +99,16 @@ class Colors(object):
ansi = int_to_ansi(p_color, p_decorator, False) ansi = int_to_ansi(p_color, p_decorator, False)
if not ansi: if not ansi:
ansi = self._name_to_ansi(p_color, p_decorator) ansi = _name_to_ansi(p_color, p_decorator)
return ansi return ansi
def get_priority_colors(self): def _get_priority_colors():
pri_ansi_colors = dict() pri_ansi_colors = dict()
pri_colors = config().priority_colors()
for pri in self.priority_colors: for pri in pri_colors:
color = self._get_ansi(self.priority_colors[pri], 'normal') color = _get_ansi(pri_colors[pri], 'normal')
if color == '': if color == '':
color = NEUTRAL_COLOR color = NEUTRAL_COLOR
...@@ -125,14 +117,31 @@ class Colors(object): ...@@ -125,14 +117,31 @@ class Colors(object):
return pri_ansi_colors return pri_ansi_colors
class Colors(object):
def __init__(self):
self.priority_colors = _get_priority_colors()
self.project_color = config().project_color()
self.context_color = config().context_color()
self.metadata_color = config().metadata_color()
self.link_color = config().link_color()
def get_project_color(self): def get_project_color(self):
return self._get_ansi(self.project_color, 'bold') return _get_ansi(self.project_color, 'bold')
def get_context_color(self): def get_context_color(self):
return self._get_ansi(self.context_color, 'bold') return _get_ansi(self.context_color, 'bold')
def get_metadata_color(self): def get_metadata_color(self):
return self._get_ansi(self.metadata_color, 'bold') return _get_ansi(self.metadata_color, 'bold')
def get_link_color(self): def get_link_color(self):
return self._get_ansi(self.link_color, 'underline') return _get_ansi(self.link_color, 'underline')
def get_priority_color(self, p_priority):
try:
priority_color = self.priority_colors[p_priority]
except KeyError:
priority_color = NEUTRAL_COLOR
return priority_color
...@@ -34,18 +34,12 @@ class PrettyPrinterColorFilter(PrettyPrinterFilter): ...@@ -34,18 +34,12 @@ class PrettyPrinterColorFilter(PrettyPrinterFilter):
""" Applies the colors. """ """ Applies the colors. """
if config().colors(): if config().colors():
colorscheme = Colors() colorscheme = Colors()
priority_colors = colorscheme.get_priority_colors() priority_color = colorscheme.get_priority_color(p_todo.priority())
project_color = colorscheme.get_project_color() project_color = colorscheme.get_project_color()
context_color = colorscheme.get_context_color() context_color = colorscheme.get_context_color()
metadata_color = colorscheme.get_metadata_color() metadata_color = colorscheme.get_metadata_color()
link_color = colorscheme.get_link_color() link_color = colorscheme.get_link_color()
priority_color = NEUTRAL_COLOR
try:
priority_color = priority_colors[p_todo.priority()]
except KeyError:
pass
# color projects / contexts # color projects / contexts
p_todo_str = re.sub( p_todo_str = re.sub(
r'\B(\+|@)(\S*\w)', r'\B(\+|@)(\S*\w)',
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment