1
0
mirror of https://github.com/gryf/wicd.git synced 2025-12-19 20:38:00 +01:00

merged 1.6-urwid-all

This commit is contained in:
Adam Blackburn
2009-08-14 11:00:54 -05:00
2 changed files with 48 additions and 14 deletions

View File

@@ -204,7 +204,8 @@ class TabColumns(urwid.WidgetWrap):
]) ])
if not firstrun: if not firstrun:
self.frame.set_body(self.pile) self.frame.set_body(self.pile)
self.set_w(self.frame) self._w = self.frame
self._invalidate()
def selectable(self): def selectable(self):
return True return True
@@ -375,7 +376,8 @@ class ComboBox(urwid.WidgetWrap):
self.overlay = self.ComboSpace(self.list,parent,ui,self.focus, self.overlay = self.ComboSpace(self.list,parent,ui,self.focus,
pos=(0,row)) pos=(0,row))
self.set_w(w) self._w = w
self._invalidate()
self.parent = parent self.parent = parent
self.ui = ui self.ui = ui
self.row = row self.row = row

View File

@@ -517,6 +517,9 @@ class appGUI():
self.list_header=urwid.AttrWrap(urwid.Text(gen_list_header()),'listbar') self.list_header=urwid.AttrWrap(urwid.Text(gen_list_header()),'listbar')
self.wlessH=NSelListBox([urwid.Text("Wireless Network(s)"),self.list_header]) self.wlessH=NSelListBox([urwid.Text("Wireless Network(s)"),self.list_header])
# Init this earlier to make update_status happy
self.update_tag = None
# FIXME: This should be two variables # FIXME: This should be two variables
self.focusloc = [1,0] self.focusloc = [1,0]
@@ -572,6 +575,8 @@ class appGUI():
self.update_status() self.update_status()
#self.max_wait = ui.max_wait
def doScan(self, sync=False): def doScan(self, sync=False):
self.scanning = True self.scanning = True
wireless.Scan(False) wireless.Scan(False)
@@ -701,7 +706,7 @@ class appGUI():
if self.connecting: if self.connecting:
if not self.conn_status: if not self.conn_status:
self.conn_status = True self.conn_status = True
gobject.idle_add(self.set_connecting_status,fast) gobject.timeout_add(250,self.set_connecting_status,fast)
return True return True
else: else:
if check_for_wired(wired.GetWiredIP(''),self.set_status): if check_for_wired(wired.GetWiredIP(''),self.set_status):
@@ -905,24 +910,44 @@ class appGUI():
self.size = ui.get_cols_rows() self.size = ui.get_cols_rows()
continue continue
def call_update_ui(self,source,cb_condition):
self.update_ui(from_key=True)
return True
# Redraw the screen # Redraw the screen
@wrap_exceptions @wrap_exceptions
def update_ui(self): def update_ui(self,from_key=True,from_alarm=False):
#self.update_status() #self.update_status()
canvas = self.frame.render( (self.size),True ) canvas = self.frame.render( (self.size),True )
### GRRRRRRRRRRRRRRRRRRRRR ->^^^^
# It looks like if I want to get the statusbar to update itself
# continuously, I would have to use overlay the canvasses and redirect
# the input. I'll try to get that working at a later time, if people
# want that "feature".
#canvaso = urwid.CanvasOverlay(self.dialog.render( (80,20),True),canvas,0,1)
# If the screen is turned off for some reason, don't even try to do the
# rest of the stuff.
if not ui._started: if not ui._started:
return False return False
# Update the screen
ui.draw_screen((self.size),canvas) ui.draw_screen((self.size),canvas)
keys = ui.get_input() # Get the input data
input_data = ui.get_input_nonblocking()
max_wait = input_data[0]
keys = input_data[1]
# Resolve any "alarms" in the waiting
if self.update_tag != None:
gobject.source_remove(self.update_tag)
if max_wait == None:
max_wait = 25
else:
max_wait *= 100
max_wait = int(max_wait)
self.update_tag = gobject.timeout_add(max_wait, \
self.update_ui,False,True)
#print keys
#if keys == []:
# return True
self.handle_keys(keys) self.handle_keys(keys)
# If we came from the "alarm", die.
if from_alarm:
return False
return True return True
@@ -1000,6 +1025,7 @@ def run():
ui.set_mouse_tracking() ui.set_mouse_tracking()
app = appGUI() app = appGUI()
# Connect signals and whatnot to UI screen control functions # Connect signals and whatnot to UI screen control functions
bus.add_signal_receiver(app.dbus_scan_finished, 'SendEndScanSignal', bus.add_signal_receiver(app.dbus_scan_finished, 'SendEndScanSignal',
'org.wicd.daemon.wireless') 'org.wicd.daemon.wireless')
@@ -1009,11 +1035,17 @@ def run():
bus.add_signal_receiver(app.update_netlist, 'StatusChanged', bus.add_signal_receiver(app.update_netlist, 'StatusChanged',
'org.wicd.daemon') 'org.wicd.daemon')
# Update what the interface looks like as an idle function # Update what the interface looks like as an idle function
gobject.idle_add(app.update_ui) #gobject.idle_add(app.update_ui)
# Update the connection status on the bottom every 1.5 s. # Update the connection status on the bottom every 1.5 s.
gobject.timeout_add(2000,app.update_status) gobject.timeout_add(2000,app.update_status)
# This will make sure that it is updated on the second. # This will make sure that it is updated on the second.
gobject.timeout_add(500,app.update_time) gobject.timeout_add(500,app.update_time)
app.update_ui()
# Get input file descriptors and add callbacks to the ui-updating function
fds = ui.get_input_descriptors()
for fd in fds:
gobject.io_add_watch(fd, gobject.IO_IN,app.call_update_ui)
loop.run() loop.run()
# Mostly borrowed from gui.py # Mostly borrowed from gui.py