diff --git a/src/lib-sieve/sieve-commands.h b/src/lib-sieve/sieve-commands.h index 50c8e0101b3e8075d0ff94d58d607c7ce483c780..4cfa91f608db7fe99d554964fd99471d82940eb1 100644 --- a/src/lib-sieve/sieve-commands.h +++ b/src/lib-sieve/sieve-commands.h @@ -13,8 +13,14 @@ * Argument definition */ +enum sieve_argument_flag { + /* More than one of this (type of) tagged argument is allowed */ + SIEVE_ARGUMENT_FLAG_MULTIPLE = (1 << 0) +}; + struct sieve_argument_def { const char *identifier; + enum sieve_argument_flag flags; bool (*is_instance_of) (struct sieve_validator *valdtr, struct sieve_command *cmd, diff --git a/src/lib-sieve/sieve-validator.c b/src/lib-sieve/sieve-validator.c index 777a8ce34353d99dea73f9a89e5cd74e56f3bc5c..58dceddb4af68fc26ba291a2cd64fdc2056bbd3c 100644 --- a/src/lib-sieve/sieve-validator.c +++ b/src/lib-sieve/sieve-validator.c @@ -939,28 +939,30 @@ static bool sieve_validate_command_arguments struct sieve_ast_argument *parg; /* Scan backwards for any duplicates */ - parg = sieve_ast_argument_prev(arg); - while ( parg != NULL ) { - if ( (sieve_ast_argument_type(parg) == SAAT_TAG && - parg->argument->def == tag_def) - || (arg->argument->id_code > 0 && parg->argument != NULL && - parg->argument->id_code == arg->argument->id_code) ) - { - const char *tag_id = sieve_ast_argument_tag(arg); - const char *tag_desc = - strcmp(tag_def->identifier, tag_id) != 0 ? - t_strdup_printf("%s argument (:%s)", tag_def->identifier, tag_id) : - t_strdup_printf(":%s argument", tag_def->identifier); - - sieve_argument_validate_error(valdtr, arg, - "encountered duplicate %s for the %s %s", - tag_desc, sieve_command_identifier(cmd), - sieve_command_type_name(cmd)); + if ( (tag_def->flags & SIEVE_ARGUMENT_FLAG_MULTIPLE) == 0 ) { + parg = sieve_ast_argument_prev(arg); + while ( parg != NULL ) { + if ( (sieve_ast_argument_type(parg) == SAAT_TAG && + parg->argument->def == tag_def) + || (arg->argument->id_code > 0 && parg->argument != NULL && + parg->argument->id_code == arg->argument->id_code) ) + { + const char *tag_id = sieve_ast_argument_tag(arg); + const char *tag_desc = + strcmp(tag_def->identifier, tag_id) != 0 ? + t_strdup_printf("%s argument (:%s)", tag_def->identifier, tag_id) : + t_strdup_printf(":%s argument", tag_def->identifier); + + sieve_argument_validate_error(valdtr, arg, + "encountered duplicate %s for the %s %s", + tag_desc, sieve_command_identifier(cmd), + sieve_command_type_name(cmd)); + + return FALSE; + } - return FALSE; + parg = sieve_ast_argument_prev(parg); } - - parg = sieve_ast_argument_prev(parg); } /* Call the validation function for the tag (if present)