color.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. #!/usr/bin/env python3
  2. #
  3. # mmgen = Multi-Mode GENerator, command-line Bitcoin cold storage solution
  4. # Copyright (C)2013-2019 The MMGen Project <mmgen@tuta.io>
  5. #
  6. # This program is free software: you can redistribute it and/or modify
  7. # it under the terms of the GNU General Public License as published by
  8. # the Free Software Foundation, either version 3 of the License, or
  9. # (at your option) any later version.
  10. #
  11. # This program is distributed in the hope that it will be useful,
  12. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. # GNU General Public License for more details.
  15. #
  16. # You should have received a copy of the GNU General Public License
  17. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. """
  19. color.py: color handling for the MMGen suite
  20. """
  21. _colors = {
  22. 'black': ( 232, (30,0) ),
  23. 'red': ( 210, (31,1) ),
  24. 'green': ( 121, (32,1) ),
  25. 'yellow': ( 229, (33,1) ),
  26. 'blue': ( 75, (34,1) ),
  27. 'magenta': ( 213, (35,1) ),
  28. 'cyan': ( 122, (36,1) ),
  29. 'pink': ( 218, (35,1) ),
  30. 'orange': ( 216, (31,1) ),
  31. 'gray': ( 246, (30,1) ),
  32. 'purple': ( 141, (35,1) ),
  33. 'brown': ( 208, (33,0) ),
  34. 'grndim': ( 108, (32,0) ),
  35. 'redbg': ( (232,210), (30,101) ),
  36. 'grnbg': ( (232,121), (30,102) ),
  37. 'blubg': ( (232,75), (30,104) ),
  38. 'yelbg': ( (232,229), (30,103) ),
  39. }
  40. for c in _colors:
  41. e = _colors[c]
  42. globals()['_256_'+c] = '\033[38;5;{};1m'.format(e[0]) if type(e[0]) == int \
  43. else '\033[38;5;{};48;5;{};1m'.format(*e[0])
  44. globals()['_16_'+c] = '\033[{}m'.format(e[1][0]) if e[1][1] == 0 \
  45. else '\033[{};{}m'.format(*e[1])
  46. globals()['_clr_'+c] = ''; _reset = ''
  47. exec('def {c}(s): return _clr_{c}+s+_reset'.format(c=c))
  48. def nocolor(s): return s
  49. def init_color(num_colors='auto'):
  50. assert num_colors in ('auto',8,16,256)
  51. globals()['_reset'] = '\033[0m'
  52. if num_colors in (8,16):
  53. pfx = '_16_'
  54. elif num_colors in (256,):
  55. pfx = '_256_'
  56. else:
  57. try:
  58. import os
  59. assert os.environ['TERM'][-8:] == '256color'
  60. pfx = '_256_'
  61. except:
  62. try:
  63. import subprocess
  64. a = subprocess.check_output(['infocmp','-0']).decode()
  65. b = [e.split('#')[1] for e in a.split(',') if e[:6] == 'colors'][0]
  66. pfx = ('_16_','_256_')[b=='256']
  67. except:
  68. pfx = '_16_'
  69. for c in _colors:
  70. globals()['_clr_'+c] = globals()[pfx+c]
  71. def start_mscolor():
  72. import sys
  73. from mmgen.globalvars import g
  74. try:
  75. import colorama
  76. colorama.init(strip=True,convert=True)
  77. except:
  78. from mmgen.util import msg
  79. msg('Import of colorama module failed')
  80. else:
  81. g.stdout = sys.stdout
  82. g.stderr = sys.stderr
  83. def test_color():
  84. try:
  85. import colorama
  86. colorama.init(strip=True,convert=True)
  87. except:
  88. pass
  89. for desc,n in (('auto','auto'),('8-color',8),('256-color',256)):
  90. init_color(num_colors=n)
  91. print('{:9}: {}'.format(desc,' '.join([globals()[c](c) for c in sorted(_colors)])))
  92. if __name__ == '__main__': test_color()