terminal.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. # Copyright (c) 2011 The Chromium OS Authors.
  2. #
  3. # See file CREDITS for list of people who contributed to this
  4. # project.
  5. #
  6. # This program is free software; you can redistribute it and/or
  7. # modify it under the terms of the GNU General Public License as
  8. # published by the Free Software Foundation; either version 2 of
  9. # the License, or (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, write to the Free Software
  18. # Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  19. # MA 02111-1307 USA
  20. #
  21. """Terminal utilities
  22. This module handles terminal interaction including ANSI color codes.
  23. """
  24. import os
  25. import sys
  26. # Selection of when we want our output to be colored
  27. COLOR_IF_TERMINAL, COLOR_ALWAYS, COLOR_NEVER = range(3)
  28. class Color(object):
  29. """Conditionally wraps text in ANSI color escape sequences."""
  30. BLACK, RED, GREEN, YELLOW, BLUE, MAGENTA, CYAN, WHITE = range(8)
  31. BOLD = -1
  32. BRIGHT_START = '\033[1;%dm'
  33. NORMAL_START = '\033[22;%dm'
  34. BOLD_START = '\033[1m'
  35. RESET = '\033[0m'
  36. def __init__(self, colored=COLOR_IF_TERMINAL):
  37. """Create a new Color object, optionally disabling color output.
  38. Args:
  39. enabled: True if color output should be enabled. If False then this
  40. class will not add color codes at all.
  41. """
  42. self._enabled = (colored == COLOR_ALWAYS or
  43. (colored == COLOR_IF_TERMINAL and os.isatty(sys.stdout.fileno())))
  44. def Start(self, color, bright=True):
  45. """Returns a start color code.
  46. Args:
  47. color: Color to use, .e.g BLACK, RED, etc.
  48. Returns:
  49. If color is enabled, returns an ANSI sequence to start the given color,
  50. otherwise returns empty string
  51. """
  52. if self._enabled:
  53. base = self.BRIGHT_START if bright else self.NORMAL_START
  54. return base % (color + 30)
  55. return ''
  56. def Stop(self):
  57. """Retruns a stop color code.
  58. Returns:
  59. If color is enabled, returns an ANSI color reset sequence, otherwise
  60. returns empty string
  61. """
  62. if self._enabled:
  63. return self.RESET
  64. return ''
  65. def Color(self, color, text, bright=True):
  66. """Returns text with conditionally added color escape sequences.
  67. Keyword arguments:
  68. color: Text color -- one of the color constants defined in this class.
  69. text: The text to color.
  70. Returns:
  71. If self._enabled is False, returns the original text. If it's True,
  72. returns text with color escape sequences based on the value of color.
  73. """
  74. if not self._enabled:
  75. return text
  76. if color == self.BOLD:
  77. start = self.BOLD_START
  78. else:
  79. base = self.BRIGHT_START if bright else self.NORMAL_START
  80. start = base % (color + 30)
  81. return start + text + self.RESET