Review Request: backports to support imap4flags in cyrus-imapd-2.4
James Cassell
fedoraproject at cyberpear.com
Fri Oct 31 14:51:50 EDT 2014
Hello,
I've backported six strarray_t patches to cyrus-imapd-2.4.17 to support
the sieve imap4flags extension. Are these patches a reasonable backport
to 2.4?
I started the imap4flags extension on 2.4, but rebased it onto master
and completed the work there. I have since backported it to 2.4, but it
relied on the strarray_t in several places. Is it better to have these
strarray_t patches backported, or should I do the backport so that it
won't require these extra patches. The latter will require more work.
The former is already complete.
I'm mostly concerned about the strarray_t patches I've backported, but
if there any comments on the imap4flags code itself, I'm all ears.
Thanks.
V/r,
James Cassell
The following changes since commit
d1df8aff4ab1b916a7794b39ca4be8e72b1548af:
Bump version for cyrus-imapd to 2.4.17 (2012-12-01 19:57:54 +0000)
are available in the git repository at:
git://git.cyrusimap.org/git/cyrus-imapd
dev/cassell/for-review-imap4flags-2.4
for you to fetch changes up to a67c68d95d09aa7006eab1e2fa5b1cfbebbc0274:
[sieve] bump bytecode version for imap4flags extension (2014-10-31
14:14:37 -0400)
----------------------------------------------------------------
Bron Gondwana (1):
strarray: add flags support to _split*
Greg Banks (6):
use strarray_t for appendstage.flags[]
Fix compile b0rkage in nntpd.c
Use strarray_t in cmd_store() index_store()
Replace struct boundary with strarray_t
Replace struct sieve_imapflags_t with strarray_t
Replace stringlist_t with strarray_t.
James Cassell (40):
[sieve] add imap4flags reference
[sieve] add parser support for imap4flags
[sieve] add imap4flags awareness to sieve interpreter
[sieve] update bytecode to support imap4flags
[sieve] imap4flags support for bytecode generator
[sieve] imap4flags support for bytecode emitter
[sieve] imap4flags support for bytecode decompiler
[sieve] bc_emit.c: fix comment
[sieve] only 'fileinto' once per folder (RFC 3028)
[sieve] fileinto: ensure last flag list value wins (RFC 5232)
[sieve] keep: ensure last flag list value wins (RFC 5232)
[sieve] bc_generate,bc_emit: put new parameter first
[sieve] message.c: add :copy support to keep action
[sieve] make sieve_{add,remove}flag() functions case insensitive
[sieve] bc_eval.c: support for :flags parameter on KEEP and
FILEINTO
[sieve] bc_emit.c: add comments for B_FILEINTO
[sieve] add legacy test cases for :flags argument to fileinto and
keep
[sieve] bc_eval: track current value of internal flags variable
[sieve] bc_eval.c: support for imap4flags hasflag test
[sieve] update sieve_fileinto() and sieve_keep() to use :flags
parameter
[sieve] sieve.y: verify :flags parameter is a valid list of flags
[sieve] sieve.y: free_ftags(): free flags stringlist
[sieve] sieve.y: support for space-separated flags within a string
[sieve] tree.c: free flags stringlists in free_tree() and
free_test()
[sieve] sieve.y: 'require' imap4flags for hasflag test and :flags
arg
[sieve] Anticipate bytecode changes for VARIABLES extension
[sieve] bc_dump.c: support imap4flags keep, fileinto, hasflag
[sieve] sieved: update bytecode decompiler for imap4flags
[sieve] added varlist.{c,h} in anticipation of the variables
extension
[sieve] remove dependence on actionflags parameter
[sieve] bc_eval.c: add :count match-type support to hasflag test
[sieve] move verify_flaglist() to flags.c for reuse elsewhere
[sieve] sieve.y: an invalid flag should not cause a parsing error
[sieve] properly handle NULL flag lists
Revert "[sieve] update sieve_fileinto() and sieve_keep() to use
:flags parameter"
[sieve] complete removal of no-longer-used actionflags parameter
[sieve] remove superfluous sieve_addflag() and _removeflag()
functions
[sieve] sieve.y: remove bytecode dependence on sieve.y
[sieve] add legacy test cases for hasflag test
[sieve] bump bytecode version for imap4flags extension
doc/specs.html | 2 +
imap/append.c | 17 +-
imap/append.h | 3 +-
imap/global.c | 2 +-
imap/imapd.c | 53 +---
imap/index.c | 8 +-
imap/index.h | 3 +-
imap/lmtp_sieve.c | 12 +-
imap/lmtpd.c | 17 +-
imap/lmtpd.h | 6 +-
imap/message.c | 62 ++---
imap/nntpd.c | 2 +-
lib/imapoptions | 2 +-
lib/strarray.c | 23 +-
lib/strarray.h | 7 +-
sieve/Makefile.in | 2 +-
sieve/README | 3 +
sieve/bc_dump.c | 33 ++-
sieve/bc_emit.c | 60 ++++-
sieve/bc_eval.c | 212
+++++++++++++--
sieve/bc_generate.c | 58 +++--
sieve/bytecode.h | 63 ++++-
sieve/flags.c | 59 +++++
sieve/flags.h | 15 ++
sieve/interp.c | 14 +-
sieve/interp.h | 2 +-
sieve/message.c | 78 ++++--
sieve/message.h | 8 +-
sieve/script.c | 115 +++------
sieve/script.h | 1 +
sieve/sieve-lex.l | 2 +
sieve/sieve.y | 285
++++++++++++++-------
sieve/sieve_interface.h | 14 +-
sieve/sieved.c | 40 ++-
sieve/test.c | 28 +-
.../actionExtensions/serverm/ueamail-imap4flags | 11 +
.../actionExtensions/testm/ueatest-imap4flags | 6 +
.../actionExtensions/uberExtensionActionScript.key | 12 +
.../actionExtensions/uberExtensionActionScript.s | 21 +-
sieve/tests/testExtension/serverm/uetmail-hasflag | 11 +
sieve/tests/testExtension/testm/uetest-hasflag | 7 +
.../testExtension/uberExtensionTestScript.key | 14 +
.../tests/testExtension/uberExtensionTestScript.s | 92 ++++++-
sieve/tree.c | 62 ++---
sieve/tree.h | 39 ++-
sieve/varlist.c | 79 ++++++
sieve/varlist.h | 32 +++
47 files changed, 1205 insertions(+), 492 deletions(-)
create mode 100644 sieve/flags.c
create mode 100644 sieve/flags.h
create mode 100644
sieve/tests/actionExtensions/serverm/ueamail-imap4flags
create mode 100644
sieve/tests/actionExtensions/testm/ueatest-imap4flags
create mode 100644 sieve/tests/testExtension/serverm/uetmail-hasflag
create mode 100644 sieve/tests/testExtension/testm/uetest-hasflag
create mode 100644 sieve/varlist.c
create mode 100644 sieve/varlist.h
More information about the Cyrus-devel
mailing list