docker-offlineimap/head/offlineimap/ui/TTY.py

62 lines
1.9 KiB
Python
Raw Normal View History

2002-06-21 07:42:39 +02:00
from UIBase import UIBase
2002-06-21 07:29:12 +02:00
from getpass import getpass
2002-06-21 09:25:24 +02:00
import select, sys
from threading import *
2002-06-21 07:29:12 +02:00
2002-06-21 07:42:39 +02:00
class TTYUI(UIBase):
def __init__(self, verbose = 0):
self.verbose = 0
self.iswaiting = 0
2002-06-21 07:42:39 +02:00
2002-06-21 07:29:12 +02:00
def _msg(s, msg):
print msg
2002-07-04 04:14:07 +02:00
sys.stdout.flush()
2002-06-21 07:29:12 +02:00
def getpass(s, accountname, config):
2002-06-21 07:42:39 +02:00
return getpass("%s: Enter password for %s on %s: " %
(accountname, config.get(accountname, "remoteuser"),
config.get(accountname, "remotehost")))
2002-06-21 07:42:39 +02:00
def syncingmessages(s, sr, sf, dr, df):
if s.verbose:
UIBase.syncingmessages(s, sr, sf, dr, df)
def loadmessagelist(s, repos, folder):
if s.verbose:
UIBase.syncingmessages(s, repos, folder)
2002-06-21 07:29:12 +02:00
2002-06-21 07:42:39 +02:00
def messagelistloaded(s, repos, folder, count):
if s.verbose:
UIBase.messagelistloaded(s, repos, folder, count)
2002-06-21 09:25:24 +02:00
def sleep(s, sleepsecs):
s.iswaiting = 1
try:
UIBase.sleep(s, sleepsecs)
finally:
s.iswaiting = 0
def mainException(s):
if isinstance(sys.exc_info()[1], KeyboardInterrupt) and \
s.iswaiting:
sys.stdout.write("Timer interrupted at user request; program terminating. \n")
s.terminate()
else:
UIBase.mainException(s)
2002-06-21 09:25:24 +02:00
def sleeping(s, sleepsecs, remainingsecs):
if remainingsecs > 0:
sys.stdout.write("Next sync in %d:%02d (press Enter to sync now, Ctrl-C to abort) \r" % \
2002-06-21 09:25:24 +02:00
(remainingsecs / 60, remainingsecs % 60))
sys.stdout.flush()
else:
sys.stdout.write("Wait done, proceeding with sync.... \n")
2002-06-21 09:25:24 +02:00
if sleepsecs > 0:
if len(select.select([sys.stdin], [], [], sleepsecs)[0]):
sys.stdin.readline()
2002-06-21 09:25:24 +02:00
return 1
return 0
2002-06-21 09:25:24 +02:00