summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMatthew Sackman <matthew@lshift.net>2010-02-04 16:06:25 +0000
committerMatthew Sackman <matthew@lshift.net>2010-02-04 16:06:25 +0000
commit75c480ff41d4568334a5bdc92c6aa6c8ee572516 (patch)
treeb8eed88469ed3a7dd0ca49f331743e91fc9fb3a4 /src
parent2ce7e4b604f2750ee5031d67cee2d20a8f2f5a53 (diff)
parent176938146041104f7c69de8458506bb1834dbe41 (diff)
downloadrabbitmq-server-git-75c480ff41d4568334a5bdc92c6aa6c8ee572516.tar.gz
Merging bug22254 into default
Diffstat (limited to 'src')
-rw-r--r--src/rabbit_binary_generator.erl17
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) ->