summaryrefslogtreecommitdiff
path: root/mail/offlineimap
diff options
context:
space:
mode:
authorNeil Blakey-Milner <nbm@FreeBSD.org>2003-01-20 09:43:20 +0000
committerNeil Blakey-Milner <nbm@FreeBSD.org>2003-01-20 09:43:20 +0000
commitf7fcd3d76d49657981dffcad56de279c061143de (patch)
tree9b48059d26d9bf4eb283891473ca3c69cb617d3c /mail/offlineimap
parentf5fae5654d7f5089a9575f75ca8b64d57da70b1d (diff)
downloadfreebsd-ports-f7fcd3d76d49657981dffcad56de279c061143de.zip
Fix curses bug in mail/offlineimap 3.99.7
PR: 47013 Submitted by: Sergei Kolobov <sergei@kolobov.com>
Diffstat (limited to 'mail/offlineimap')
-rw-r--r--mail/offlineimap/Makefile1
-rw-r--r--mail/offlineimap/files/patch-ui::Curses.py101
2 files changed, 102 insertions, 0 deletions
diff --git a/mail/offlineimap/Makefile b/mail/offlineimap/Makefile
index dd63344d2893..d2cc33c14aab 100644
--- a/mail/offlineimap/Makefile
+++ b/mail/offlineimap/Makefile
@@ -7,6 +7,7 @@
PORTNAME= offlineimap
PORTVERSION= 3.99.7
+PORTREVISION= 1
CATEGORIES= mail python
MASTER_SITES= http://gopher.quux.org:70/devel/offlineimap/
DISTNAME= ${PORTNAME}_${PORTVERSION}
diff --git a/mail/offlineimap/files/patch-ui::Curses.py b/mail/offlineimap/files/patch-ui::Curses.py
new file mode 100644
index 000000000000..d2a30f30c345
--- /dev/null
+++ b/mail/offlineimap/files/patch-ui::Curses.py
@@ -0,0 +1,101 @@
+--- offlineimap/ui/Curses.py (original)
++++ offlineimap/ui/Curses.py Fri Jan 10 11:47:36 2003
+@@ -29,12 +29,18 @@
+
+ class CursesUtil:
+ def __init__(self):
+- self.pairs = {self._getpairindex(curses.COLOR_WHITE,
+- curses.COLOR_BLACK): 0}
+- self.start()
+- self.nextpair = 1
+ self.pairlock = Lock()
+ self.iolock = MultiLock()
++ self.start()
++
++ def initpairs(self):
++ self.pairlock.acquire()
++ try:
++ self.pairs = {self._getpairindex(curses.COLOR_WHITE,
++ curses.COLOR_BLACK): 0}
++ self.nextpair = 1
++ finally:
++ self.pairlock.release()
+
+ def lock(self):
+ self.iolock.acquire()
+@@ -63,6 +69,8 @@
+ return '%d/%d' % (fg,bg)
+
+ def getpair(self, fg, bg):
++ if not self.has_color:
++ return 0
+ pindex = self._getpairindex(fg, bg)
+ self.pairlock.acquire()
+ try:
+@@ -96,6 +104,7 @@
+ self.stdscr.clear()
+ self.stdscr.refresh()
+ (self.height, self.width) = self.stdscr.getmaxyx()
++ self.initpairs()
+
+ def stop(self):
+ if not hasattr(self, 'stdscr'):
+@@ -200,7 +209,10 @@
+
+ def display(self):
+ def lockedstuff():
+- self.window.addstr(self.y, self.x, '.', self.color)
++ if self.getcolor() == 'black':
++ self.window.addstr(self.y, self.x, ' ', self.color)
++ else:
++ self.window.addstr(self.y, self.x, '.', self.color)
+ self.c.stdscr.move(self.c.height - 1, self.c.width - 1)
+ self.window.refresh()
+ self.c.locked(lockedstuff)
+@@ -406,9 +418,12 @@
+ s.c.unlock()
+
+ def setupwindow_drawbanner(s):
+- s.bannerwindow.bkgd(' ', curses.A_BOLD | \
+- s.c.getpair(curses.COLOR_WHITE,
+- curses.COLOR_BLUE))
++ if s.c.has_color:
++ color = s.c.getpair(curses.COLOR_WHITE, curses.COLOR_BLUE) | \
++ curses.A_BOLD
++ else:
++ color = curses.A_REVERSE
++ s.bannerwindow.bkgd(' ', color) # Fill background with that color
+ s.bannerwindow.addstr("%s %s" % (version.productname,
+ version.versionstr))
+ s.bannerwindow.addstr(0, s.bannerwindow.getmaxyx()[1] - len(version.copyright) - 1,
+@@ -417,7 +432,11 @@
+ s.bannerwindow.noutrefresh()
+
+ def setupwindow_drawlog(s):
+- s.logwindow.bkgd(' ', s.c.getpair(curses.COLOR_WHITE, curses.COLOR_BLACK))
++ if s.c.has_color:
++ color = s.c.getpair(curses.COLOR_WHITE, curses.COLOR_BLACK)
++ else:
++ color = curses.A_NORMAL
++ s.logwindow.bkgd(' ', color)
+ for line, color in s.text:
+ s.logwindow.addstr("\n" + line, color)
+ s.logwindow.noutrefresh()
+@@ -501,7 +520,7 @@
+ x = Blinkenlights(None)
+ x.init_banner()
+ import time
+- time.sleep(10)
++ time.sleep(5)
+ x.c.stop()
+ fgs = {'black': curses.COLOR_BLACK, 'red': curses.COLOR_RED,
+ 'green': curses.COLOR_GREEN, 'yellow': curses.COLOR_YELLOW,
+@@ -536,7 +555,7 @@
+ win4.refresh()
+ x.stdscr.refresh()
+ import time
+- time.sleep(40)
++ time.sleep(5)
+ x.stop()
+ print x.has_color
+ print x.height