X-Git-Url: https://git.madduck.net/etc/offlineimap.git/blobdiff_plain/60b6943f1562471884e69d277785a57303cff155..6ce71d5f2eebf215f78bcb66ce5a50d109980d38:/.offlineimap/helper.py diff --git a/.offlineimap/helper.py b/.offlineimap/helper.py index 840896f..3eb2346 100644 --- a/.offlineimap/helper.py +++ b/.offlineimap/helper.py @@ -1,37 +1,47 @@ # -*- coding: utf-8 -*- -import re, os, stat, time, atexit +import re -base_excludes = ['delayed', 'outgoing', 'Trash', 'Sent', 'Queue'] -full_excludes_re = ['discard', 'spool', 'spam', 'store\..+'] -prioritised = ['outgoing','resubmit','drafts','inbox','ardex','debian','sudetia','admin','retrain'] +base_excludes = ['delayed', 'outgoing', 'Trash', 'Queue', 'inbox'] +base_excludes_re = [ '[Ss]ent.*' ] +full_excludes_re = ['discard', 'spool', 'spam', 'store/.+'] +prioritised = ['outgoing','resubmit','drafts','INBOX','ardex','kbkg','toni','immo','uniwh','mkch','debian','sudetia','admin','retrain'] deprioritised = ['discard','spam','store','spool'] def py_foldersort_main(x, y): for prefix in prioritised: - if x.startswith(prefix): + if x.name.startswith(prefix): return -1 - elif y.startswith(prefix): + elif y.name.startswith(prefix): return +1 for prefix in deprioritised: - if x.startswith(prefix): + if x.name.startswith(prefix): return +1 - elif y.startswith(prefix): + elif y.name.startswith(prefix): return -1 return cmp(x, y) -def py_nametrans_main(x): +def py_nametrans(x): return re.sub('^INBOX', 'inbox', x) def py_folderfilter_main(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 True +def py_foldersort_bulk(x, y): + if x == 'spool': return -1 + if y == 'spool': return 1 + if x in ('discard', 'spam'): return 1 + if y in ('discard', 'spam'): return -1 + def py_folderfilter_bulk(x): if re.search('^(' + '|'.join(full_excludes_re) + ')', x): return True @@ -40,5 +50,5 @@ def py_folderfilter_bulk(x): def py_folderfilter_mbnames(acct, x): full_excludes_re_mbnames = ['retrain/(sp|h)am'] + full_excludes_re - return acct in ['madduck.net', 'madduck.net-bulk'] \ + return acct in ['madduck.net', 'madduck.net_bulk'] \ and not re.search('^(' + '|'.join(full_excludes_re_mbnames) + ')', x)