aboutsummaryrefslogtreecommitdiffstats
path: root/libmproxy/console/__init__.py
diff options
context:
space:
mode:
authorAldo Cortesi <aldo@nullcube.com>2015-04-07 08:42:40 +1200
committerAldo Cortesi <aldo@nullcube.com>2015-04-07 08:42:40 +1200
commit1cb1ee411b9c8ffc40f83bcca99770af7f43a521 (patch)
tree6168cc606a28ab82643e1da69716f51648267ca4 /libmproxy/console/__init__.py
parent538f215458891f045b2de6a8b675db48754fbb4a (diff)
downloadmitmproxy-1cb1ee411b9c8ffc40f83bcca99770af7f43a521.tar.gz
mitmproxy-1cb1ee411b9c8ffc40f83bcca99770af7f43a521.tar.bz2
mitmproxy-1cb1ee411b9c8ffc40f83bcca99770af7f43a521.zip
console: palette picker for the options screen
Diffstat (limited to 'libmproxy/console/__init__.py')
-rw-r--r--libmproxy/console/__init__.py22
1 files changed, 18 insertions, 4 deletions
diff --git a/libmproxy/console/__init__.py b/libmproxy/console/__init__.py
index 2421aa6b..1fdf503a 100644
--- a/libmproxy/console/__init__.py
+++ b/libmproxy/console/__init__.py
@@ -16,7 +16,7 @@ import weakref
from .. import controller, flow, script
from . import flowlist, flowview, help, window, signals, options
-from . import grideditor, palettes, contentview, statusbar
+from . import grideditor, palettes, contentview, statusbar, palettepicker
EVENTLOG_SIZE = 500
@@ -157,7 +157,6 @@ class ConsoleMaster(flow.FlowMaster):
self.setheaders.add(*i)
self.flow_list_walker = None
- self.set_palette(options.palette)
r = self.set_intercept(options.intercept)
if r:
@@ -183,6 +182,7 @@ class ConsoleMaster(flow.FlowMaster):
self.rheaders = options.rheaders
self.nopop = options.nopop
self.showhost = options.showhost
+ self.palette = options.palette
self.eventlog = options.eventlog
self.eventlist = urwid.SimpleListWalker([])
@@ -391,7 +391,11 @@ class ConsoleMaster(flow.FlowMaster):
os.unlink(name)
def set_palette(self, name):
- self.palette = palettes.palettes[name]
+ self.palette = name
+ self.ui.register_palette(
+ palettes.palettes[name].palette()
+ )
+ self.ui.clear()
def ticker(self, *userdata):
changed = self.tick(self.masterq, timeout=0)
@@ -403,7 +407,7 @@ class ConsoleMaster(flow.FlowMaster):
def run(self):
self.ui = urwid.raw_display.Screen()
self.ui.set_terminal_properties(256)
- self.ui.register_palette(self.palette.palette())
+ self.set_palette(self.palette)
self.flow_list_walker = flowlist.FlowListWalker(self, self.state)
self.loop = urwid.MainLoop(
urwid.SolidFill("x"),
@@ -475,6 +479,16 @@ class ConsoleMaster(flow.FlowMaster):
options.help_context,
)
+ def view_palette_picker(self):
+ signals.push_view_state.send(self)
+ self.loop.widget = window.Window(
+ self,
+ palettepicker.PalettePicker(self),
+ None,
+ statusbar.StatusBar(self, palettepicker.footer),
+ palettepicker.help_context,
+ )
+
def view_grideditor(self, ge):
signals.push_view_state.send(self)
self.loop.widget = window.Window(