diff options
| author | Matthew Sackman <matthew@lshift.net> | 2010-02-04 16:06:25 +0000 |
|---|---|---|
| committer | Matthew Sackman <matthew@lshift.net> | 2010-02-04 16:06:25 +0000 |
| commit | 75c480ff41d4568334a5bdc92c6aa6c8ee572516 (patch) | |
| tree | b8eed88469ed3a7dd0ca49f331743e91fc9fb3a4 /src | |
| parent | 2ce7e4b604f2750ee5031d67cee2d20a8f2f5a53 (diff) | |
| parent | 176938146041104f7c69de8458506bb1834dbe41 (diff) | |
| download | rabbitmq-server-git-75c480ff41d4568334a5bdc92c6aa6c8ee572516.tar.gz | |
Merging bug22254 into default
Diffstat (limited to 'src')
| -rw-r--r-- | src/rabbit_binary_generator.erl | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/src/rabbit_binary_generator.erl b/src/rabbit_binary_generator.erl index b8e161a6bd..b903a6eee7 100644 --- a/src/rabbit_binary_generator.erl +++ b/src/rabbit_binary_generator.erl @@ -196,12 +196,16 @@ generate_array(Array) when is_list(Array) -> fun ({Type, Value}) -> field_value_to_binary(Type, Value) end, Array)). -short_string_to_binary(String) when is_binary(String) and (size(String) < 256) -> - [<<(size(String)):8>>, String]; +short_string_to_binary(String) when is_binary(String) -> + Len = size(String), + if Len < 256 -> [<<(size(String)):8>>, String]; + true -> exit(content_properties_shortstr_overflow) + end; short_string_to_binary(String) -> StringLength = length(String), - true = (StringLength < 256), % assertion - [<<StringLength:8>>, String]. + if StringLength < 256 -> [<<StringLength:8>>, String]; + true -> exit(content_properties_shortstr_overflow) + end. long_string_to_binary(String) when is_binary(String) -> [<<(size(String)):32>>, String]; @@ -239,7 +243,10 @@ encode_properties(Bit, [T | TypeList], [Value | ValueList], FirstShortAcc, Flags end. encode_property(shortstr, String) -> - Len = size(String), <<Len:8/unsigned, String:Len/binary>>; + Len = size(String), + if Len < 256 -> <<Len:8/unsigned, String:Len/binary>>; + true -> exit(content_properties_shortstr_overflow) + end; encode_property(longstr, String) -> Len = size(String), <<Len:32/unsigned, String:Len/binary>>; encode_property(octet, Int) -> |
