imaputil.py: factorize the flag map

Instead of repeating a mapping table twice, once for each direction, it is only
stored once.  This is safer and faster.

As the patch stands, it makes no custom flags available.  The behaviour
is exactly as before.

Patch-written-by: Dan Christensen <jdc@uwo.ca>
Signed-off-by: Nicolas Sebrecht <nicolas.s-dev@laposte.net>
This commit is contained in:
Nicolas Sebrecht 2010-12-08 18:46:46 +01:00
parent 1b32d374b5
commit b8aaf4cf43

View File

@ -147,30 +147,26 @@ def imapsplit(imapstring):
debug("imapsplit() returning:", retval) debug("imapsplit() returning:", retval)
return retval return retval
flagmap = [('\\Seen', 'S'),
('\\Answered', 'R'),
('\\Flagged', 'F'),
('\\Deleted', 'T'),
('\\Draft', 'D')]
def flagsimap2maildir(flagstring): def flagsimap2maildir(flagstring):
flagmap = {'\\seen': 'S',
'\\answered': 'R',
'\\flagged': 'F',
'\\deleted': 'T',
'\\draft': 'D'}
retval = [] retval = []
imapflaglist = [x.lower() for x in flagstring[1:-1].split()] imapflaglist = [x.lower() for x in flagstring[1:-1].split()]
for imapflag in imapflaglist: for imapflag, maildirflag in flagmap:
if flagmap.has_key(imapflag): if imapflag.lower() in imapflaglist:
retval.append(flagmap[imapflag]) retval.append(maildirflag)
retval.sort() retval.sort()
return retval return retval
def flagsmaildir2imap(list): def flagsmaildir2imap(maildirflaglist):
flagmap = {'S': '\\Seen',
'R': '\\Answered',
'F': '\\Flagged',
'T': '\\Deleted',
'D': '\\Draft'}
retval = [] retval = []
for mdflag in list: for imapflag, maildirflag in flagmap:
if flagmap.has_key(mdflag): if maildirflag in maildirflaglist:
retval.append(flagmap[mdflag]) retval.append(imapflag)
retval.sort() retval.sort()
return '(' + ' '.join(retval) + ')' return '(' + ' '.join(retval) + ')'