/offlineimap/head: changeset 363
Fixed ability to resize windows under Curses.
This commit is contained in:
parent
3af9200226
commit
a09ff54b6e
@ -15,10 +15,12 @@
|
|||||||
# along with this program; if not, write to the Free Software
|
# along with this program; if not, write to the Free Software
|
||||||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
|
DEBUGLOG = open("/tmp/debug", "wt")
|
||||||
|
|
||||||
from Blinkenlights import BlinkenBase
|
from Blinkenlights import BlinkenBase
|
||||||
from UIBase import UIBase
|
from UIBase import UIBase
|
||||||
from threading import *
|
from threading import *
|
||||||
import thread, time, sys, os
|
import thread, time, sys, os, signal, time
|
||||||
from offlineimap import version, threadutil
|
from offlineimap import version, threadutil
|
||||||
from offlineimap.threadutil import MultiLock
|
from offlineimap.threadutil import MultiLock
|
||||||
|
|
||||||
@ -121,8 +123,14 @@ class CursesUtil:
|
|||||||
del self.stdscr
|
del self.stdscr
|
||||||
|
|
||||||
def reset(self):
|
def reset(self):
|
||||||
|
DEBUGLOG.write(" in reset...\n")
|
||||||
|
DEBUGLOG.flush()
|
||||||
self.stop()
|
self.stop()
|
||||||
|
DEBUGLOG.write(" stop done...\n")
|
||||||
|
DEBUGLOG.flush()
|
||||||
self.start()
|
self.start()
|
||||||
|
DEBUGLOG.write(" start done...\n")
|
||||||
|
DEBUGLOG.flush()
|
||||||
|
|
||||||
class CursesAccountFrame:
|
class CursesAccountFrame:
|
||||||
def __init__(s, master, accountname):
|
def __init__(s, master, accountname):
|
||||||
@ -318,6 +326,46 @@ class Blinkenlights(BlinkenBase, UIBase):
|
|||||||
s.gettf().setcolor('red')
|
s.gettf().setcolor('red')
|
||||||
s._msg(version.banner)
|
s._msg(version.banner)
|
||||||
s.inputhandler.set_bgchar(s.keypress)
|
s.inputhandler.set_bgchar(s.keypress)
|
||||||
|
signal.signal(signal.SIGWINCH, s.resizehandler)
|
||||||
|
s.resizelock = Lock()
|
||||||
|
s.resizecount = 0
|
||||||
|
|
||||||
|
def resizehandler(s, signum, frame):
|
||||||
|
s.resizeterm()
|
||||||
|
|
||||||
|
def resizeterm(s, dosleep = 1):
|
||||||
|
DEBUGLOG.write("\nResizeterm called...\n")
|
||||||
|
DEBUGLOG.write("pid: %d\n" % os.getpid())
|
||||||
|
if not s.resizelock.acquire(0):
|
||||||
|
s.resizecount += 1
|
||||||
|
DEBUGLOG.write("Already resizing; aborting.\n")
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
DEBUGLOG.write("Got the lock\n")
|
||||||
|
signal.signal(signal.SIGWINCH, signal.SIG_IGN)
|
||||||
|
s.aflock.acquire()
|
||||||
|
s.c.lock()
|
||||||
|
DEBUGLOG.write("locks acquired...\n")
|
||||||
|
s.resizecount += 1
|
||||||
|
DEBUGLOG.write("at top of try\n")
|
||||||
|
while s.resizecount:
|
||||||
|
DEBUGLOG.write("in while loop\n")
|
||||||
|
s.c.reset()
|
||||||
|
DEBUGLOG.write("reset done...\n")
|
||||||
|
DEBUGLOG.write("sleep done...\n")
|
||||||
|
DEBUGLOG.flush()
|
||||||
|
s.setupwindows()
|
||||||
|
DEBUGLOG.write("setupwindows done...\n")
|
||||||
|
s.resizecount -= 1
|
||||||
|
DEBUGLOG.write("exiting while loop...\n")
|
||||||
|
DEBUGLOG.write("in finally section...\n")
|
||||||
|
s.c.unlock()
|
||||||
|
s.aflock.release()
|
||||||
|
s.resizelock.release()
|
||||||
|
signal.signal(signal.SIGWINCH, s.resizehandler)
|
||||||
|
if dosleep:
|
||||||
|
time.sleep(1)
|
||||||
|
s.resizeterm(0)
|
||||||
|
|
||||||
def isusable(s):
|
def isusable(s):
|
||||||
# Not a terminal? Can't use curses.
|
# Not a terminal? Can't use curses.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user