fix a bunch of bugs in tab handling and attempt to handle closing a tab with multiple children, but all of this is still entirely buggy

This commit is contained in:
Chris Jones 2009-12-08 13:57:29 +00:00
parent f9725242ec
commit 34da8ffe3a
2 changed files with 49 additions and 9 deletions

View File

@ -67,6 +67,8 @@ class Container(object):
if self.cnxids.has_key(widget): if self.cnxids.has_key(widget):
for cnxid in self.cnxids[widget]: for cnxid in self.cnxids[widget]:
# FIXME: Look up the IDs to print a useful debugging message # FIXME: Look up the IDs to print a useful debugging message
dbg('Container::disconnect_child: removing handler on %s' %
widget.__class__.__name__)
widget.disconnect(cnxid) widget.disconnect(cnxid)
del(self.cnxids[widget]) del(self.cnxids[widget])
@ -107,6 +109,7 @@ class Container(object):
pass pass
if not self.remove(widget): if not self.remove(widget):
dbg('Container::closeterm: self.remove() failed for %s' % widget)
return(False) return(False)
self.terminator.deregister_terminal(widget) self.terminator.deregister_terminal(widget)

View File

@ -12,7 +12,7 @@ from factory import Factory
from container import Container from container import Container
from editablelabel import EditableLabel from editablelabel import EditableLabel
from translation import _ from translation import _
from util import err from util import err, dbg
class Notebook(Container, gtk.Notebook): class Notebook(Container, gtk.Notebook):
"""Class implementing a gtk.Notebook container""" """Class implementing a gtk.Notebook container"""
@ -51,13 +51,14 @@ class Notebook(Container, gtk.Notebook):
self.set_show_tabs(not self.config['hide_tabbar']) self.set_show_tabs(not self.config['hide_tabbar'])
def split_axis(self, widget, vertical=True, sibling=None): def split_axis(self, widget, vertical=True, sibling=None):
"""Default axis splitter. This should be implemented by subclasses""" """Split the axis of a terminal inside us"""
page_num = self.page_num(widget) page_num = self.page_num(widget)
if page_num == -1: if page_num == -1:
err('Notebook::split_axis: %s not found in Notebook' % widget) err('Notebook::split_axis: %s not found in Notebook' % widget)
return return
self.remove_page(page_num) label = self.get_tab_label(widget)
self.remove(widget)
maker = Factory() maker = Factory()
if vertical: if vertical:
@ -71,6 +72,7 @@ class Notebook(Container, gtk.Notebook):
sibling.spawn_child() sibling.spawn_child()
self.insert_page(container, None, page_num) self.insert_page(container, None, page_num)
self.set_tab_label(container, label)
self.show_all() self.show_all()
container.add(widget) container.add(widget)
@ -81,15 +83,17 @@ class Notebook(Container, gtk.Notebook):
def add(self, widget): def add(self, widget):
"""Add a widget to the container""" """Add a widget to the container"""
raise NotImplementedError('add') self.newtab(widget)
def remove(self, widget): def remove(self, widget):
"""Remove a widget from the container""" """Remove a widget from the container"""
page_num = self.page_num(widget) page_num = self.page_num(widget)
if page_num == -1: if page_num == -1:
err('Notebook::remove: %s not found in Notebook' % widget) err('Notebook::remove: %s not found in Notebook. Actual parent is: %s' %
(widget, widget.get_parent()))
return(False) return(False)
self.remove_page(page_num) self.remove_page(page_num)
self.disconnect_child(widget)
return(True) return(True)
def newtab(self, widget=None): def newtab(self, widget=None):
@ -130,13 +134,20 @@ class Notebook(Container, gtk.Notebook):
def wrapcloseterm(self, widget): def wrapcloseterm(self, widget):
"""A child terminal has closed""" """A child terminal has closed"""
if self.closeterm(widget): if self.closeterm(widget):
dbg('Notebook::wrapcloseterm: closeterm succeeded')
if self.get_n_pages() == 1: if self.get_n_pages() == 1:
dbg('Notebook::wrapcloseterm: last page, removing self')
child = self.get_nth_page(0) child = self.get_nth_page(0)
self.remove_page(0) self.remove_page(0)
parent = self.get_parent() parent = self.get_parent()
parent.remove(self) parent.remove(self)
parent.add(child) parent.add(child)
del(self) del(self)
else:
dbg('Notebook::wrapcloseterm: %d pages remain' %
self.get_n_pages())
else:
dbg('Notebook::wrapcloseterm: closeterm failed')
def closetab(self, widget, label): def closetab(self, widget, label):
"""Close a tab""" """Close a tab"""
@ -160,16 +171,42 @@ class Notebook(Container, gtk.Notebook):
child = nb.get_nth_page(tabnum) child = nb.get_nth_page(tabnum)
if maker.isinstance(child, 'Terminal'): if maker.isinstance(child, 'Terminal'):
dbg('Notebook::closetab: child is a single Terminal')
child.close() child.close()
elif maker.isinstance(child, 'Container'): elif maker.isinstance(child, 'Container'):
dialog = self.construct_confirm_close(self.get_window(), _('tab')) dbg('Notebook::closetab: child is a Container')
dialog = self.construct_confirm_close(self.window, _('tab'))
result = dialog.run() result = dialog.run()
dialog.destroy() dialog.destroy()
if result is True: if result == gtk.RESPONSE_ACCEPT:
print child.get_children() containers = []
objects = []
for descendant in child.get_children():
if maker.isinstance(descendant, 'Container'):
containers.append(descendant)
elif maker.isinstance(descendant, 'Terminal'):
objects.append(descendant)
while len(containers) > 0:
child = containers.pop()
for descendant in child.get_children():
if maker.isinstance(descendant, 'Container'):
containers.append(descendant)
elif maker.isinstance(descendant, 'Terminal'):
objects.append(descendant)
for descendant in objects:
descendant.close()
while gtk.events_pending():
gtk.main_iteration()
return
else: else:
err('Notebook::closetab: Unknown child type %s' % child) dbg('Notebook::closetab: user cancelled request')
return
else:
err('Notebook::closetab: child is unknown type %s' % child)
return
nb.remove_page(tabnum) nb.remove_page(tabnum)
del(label) del(label)