import re
-base_excludes = ['delayed', 'outgoing', 'Trash', 'Sent', 'Queue', 'sent', 'inbox']
-full_excludes_re = ['discard', 'spool', 'spam', '(store|[Ss]ent)/.+']
-prioritised = ['outgoing','resubmit','drafts','INBOX','ardex','kbkg','toni','immo','uniwh','mkch','debian','sudetia','admin','retrain']
+base_excludes = ['delayed', 'outgoing', 'Trash', 'Queue', 'inbox', 'Spam', 'Drafts', 'scratch']
+base_excludes_re = [ '[Ss]ent.*' ]
+full_excludes_re = ['discard', 'spool', 'spam', 'store/.+']
+prioritised = ['resubmit','drafts','inbox','ardex','kbkg','toni','tahi','debian','mtfk','admin','retrain']
deprioritised = ['discard','spam','store','spool']
def py_foldersort_main(x, y):
for prefix in prioritised:
- if x.name.startswith(prefix):
+ if x.startswith(prefix):
return -1
- elif y.name.startswith(prefix):
+ elif y.startswith(prefix):
return +1
for prefix in deprioritised:
- if x.name.startswith(prefix):
+ if x.startswith(prefix):
return +1
- elif y.name.startswith(prefix):
+ elif y.startswith(prefix):
return -1
- return cmp(x, y)
+ return (x > y) - (x < y)
def py_nametrans(x):
return re.sub('^INBOX', 'inbox', x)
if x in base_excludes:
return False
+ elif re.search('^(' + '|'.join(base_excludes_re) + ')', x):
+ return False
+
elif re.search('^(' + '|'.join(full_excludes_re) + ')', x):
return False
return False
def py_folderfilter_mbnames(acct, x):
- full_excludes_re_mbnames = ['retrain/(sp|h)am'] + full_excludes_re
+ full_excludes_re_mbnames = ['retrain(/(sp|h)am)?$'] + full_excludes_re
return acct in ['madduck.net', 'madduck.net_bulk'] \
and not re.search('^(' + '|'.join(full_excludes_re_mbnames) + ')', x)