[tor-commits] [arm/master] Skeleton terminal contorl interpretor
atagar at torproject.org
atagar at torproject.org
Thu Aug 25 17:17:32 UTC 2011
commit ba49077b953265515aef1b2b98b159636f37d7c5
Author: Damian Johnson <atagar at torproject.org>
Date: Thu Aug 25 10:15:24 2011 -0700
Skeleton terminal contorl interpretor
This provides a basic skeleton for a terminal-only interpretor of the control
port. This provides terminal coloring, formatting, and history scollback but it
not yet tied into the control port. The plan is that both the torInterpretor
and interpretorPanel will use the same backend for irc style interpretor
commands so people can use the interpretor in both the curses interface or
plain terminal.
---
src/util/torInterpretor.py | 66 ++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 66 insertions(+), 0 deletions(-)
diff --git a/src/util/torInterpretor.py b/src/util/torInterpretor.py
new file mode 100644
index 0000000..9b6bff4
--- /dev/null
+++ b/src/util/torInterpretor.py
@@ -0,0 +1,66 @@
+"""
+Provides an interactive interpretor for working with the Tor control port. This
+adds usability features like IRC style interpretor commands and, when ran
+directly, history and tab completion.
+"""
+
+import readline # simply importing this provides history to raw_input
+
+from util import enum
+
+TERM_COLORS = ("BLACK", "RED", "GREEN", "YELLOW", "BLUE", "MAGENTA", "CYAN", "WHITE")
+
+Color = enum.Enum(*TERM_COLORS)
+BgColor = enum.Enum(*["BG_" + color for color in TERM_COLORS])
+Attr = enum.Enum("BOLD", "UNDERLINE", "HILIGHT")
+
+FG_ENCODING = dict([(Color.values()[i], str(30 + i)) for i in range(8)])
+BG_ENCODING = dict([(BgColor.values()[i], str(40 + i)) for i in range(8)])
+ATTR_ENCODING = {Attr.BOLD: "1", Attr.UNDERLINE: "4", Attr.HILIGHT: "7"}
+
+CSI = "\x1B[%sm"
+RESET = CSI % "0"
+
+def format(msg, *attr):
+ """
+ Simple terminal text formatting, using ANSI escape sequences from:
+ https://secure.wikimedia.org/wikipedia/en/wiki/ANSI_escape_code#CSI_codes
+
+ toolkits providing similar capabilities:
+ * django.utils.termcolors
+ https://code.djangoproject.com/browser/django/trunk/django/utils/termcolors.py
+
+ * termcolor
+ http://pypi.python.org/pypi/termcolor
+
+ * colorama
+ http://pypi.python.org/pypi/colorama
+
+ Arguments:
+ msg - string to be formatted
+ attr - text attributes, this can be Color, BgColor, or Attr enums and are
+ case insensitive (so strings like "red" are fine)
+ """
+
+ encodings = []
+ for textAttr in attr:
+ textAttr, encoding = enum.toCamelCase(textAttr), None
+ encoding = FG_ENCODING.get(textAttr, encoding)
+ encoding = BG_ENCODING.get(textAttr, encoding)
+ encoding = ATTR_ENCODING.get(textAttr, encoding)
+ if encoding: encodings.append(encoding)
+
+ if encodings:
+ return (CSI % ";".join(encodings)) + msg + RESET
+ else:
+ raise IOError("BLARG! %s" % str(attr))
+ return msg
+
+def prompt():
+ prompt = format(">>> ", Color.GREEN, Attr.BOLD)
+ input = ""
+
+ while input != "/quit":
+ input = raw_input(prompt)
+ print format("echoing back '%s'" % input, Color.BLUE)
+
More information about the tor-commits
mailing list