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:
parent
f9725242ec
commit
34da8ffe3a
@ -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)
|
||||||
|
@ -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:
|
||||||
|
dbg('Notebook::closetab: user cancelled request')
|
||||||
|
return
|
||||||
else:
|
else:
|
||||||
err('Notebook::closetab: Unknown child type %s' % child)
|
err('Notebook::closetab: child is unknown type %s' % child)
|
||||||
|
return
|
||||||
|
|
||||||
nb.remove_page(tabnum)
|
nb.remove_page(tabnum)
|
||||||
del(label)
|
del(label)
|
||||||
|
Loading…
Reference in New Issue
Block a user