summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorEmile Joubert <emile@rabbitmq.com>2013-02-05 11:38:59 +0000
committerEmile Joubert <emile@rabbitmq.com>2013-02-05 11:38:59 +0000
commit74b0c9eda2321ae8385b56742e63560aabece8b1 (patch)
treead1ff63a95b153d48deb71c9f056dad2b8b1946a /src
parent20da9e08a9f5f9ed6c666801f25c100a453f44e9 (diff)
parent5fd0526da693d44954724cdd24ac64681616c5ed (diff)
downloadrabbitmq-server-git-74b0c9eda2321ae8385b56742e63560aabece8b1.tar.gz
Merged bug25433 into default
Diffstat (limited to 'src')
-rw-r--r--src/rabbit_parameter_validation.erl14
1 files changed, 13 insertions, 1 deletions
diff --git a/src/rabbit_parameter_validation.erl b/src/rabbit_parameter_validation.erl
index 39d0188cba..a4bd50426c 100644
--- a/src/rabbit_parameter_validation.erl
+++ b/src/rabbit_parameter_validation.erl
@@ -16,7 +16,7 @@
-module(rabbit_parameter_validation).
--export([number/2, binary/2, boolean/2, list/2, regex/2, proplist/3]).
+-export([number/2, binary/2, boolean/2, list/2, regex/2, proplist/3, enum/1]).
number(_Name, Term) when is_number(Term) ->
ok;
@@ -73,3 +73,15 @@ proplist(Name, Constraints, Term) when is_list(Term) ->
proplist(Name, _Constraints, Term) ->
{error, "~s not a list ~p", [Name, Term]}.
+
+enum(OptionsA) ->
+ Options = [list_to_binary(atom_to_list(O)) || O <- OptionsA],
+ fun (Name, Term) when is_binary(Term) ->
+ case lists:member(Term, Options) of
+ true -> ok;
+ false -> {error, "~s should be one of ~p, actually was ~p",
+ [Name, Options, Term]}
+ end;
+ (Name, Term) ->
+ {error, "~s should be binary, actually was ~p", [Name, Term]}
+ end.