1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
use types::*;
use value::*;
use cookie_factory::*;
pub fn gen_value<'a>(x: (&'a mut [u8], usize), v: &AMQPValue) -> Result<(&'a mut [u8], usize), GenError> {
match *v {
AMQPValue::Boolean(ref b) => do_gen!(x, gen_type(&v.get_type()) >> gen_boolean(b)),
AMQPValue::ShortShortInt(ref i) => do_gen!(x, gen_type(&v.get_type()) >> gen_short_short_int(i)),
AMQPValue::ShortShortUInt(ref u) => do_gen!(x, gen_type(&v.get_type()) >> gen_short_short_uint(u)),
AMQPValue::ShortInt(ref i) => do_gen!(x, gen_type(&v.get_type()) >> gen_short_int(i)),
AMQPValue::ShortUInt(ref u) => do_gen!(x, gen_type(&v.get_type()) >> gen_short_uint(u)),
AMQPValue::LongInt(ref i) => do_gen!(x, gen_type(&v.get_type()) >> gen_long_int(i)),
AMQPValue::LongUInt(ref u) => do_gen!(x, gen_type(&v.get_type()) >> gen_long_uint(u)),
AMQPValue::LongLongInt(ref i) => do_gen!(x, gen_type(&v.get_type()) >> gen_long_long_int(i)),
AMQPValue::LongLongUInt(ref u) => do_gen!(x, gen_type(&v.get_type()) >> gen_long_long_uint(u)),
AMQPValue::Float(ref f) => do_gen!(x, gen_type(&v.get_type()) >> gen_float(f)),
AMQPValue::Double(ref d) => do_gen!(x, gen_type(&v.get_type()) >> gen_double(d)),
AMQPValue::DecimalValue(ref d) => do_gen!(x, gen_type(&v.get_type()) >> gen_decimal_value(d)),
AMQPValue::ShortString(ref s) => do_gen!(x, gen_type(&v.get_type()) >> gen_short_string(s)),
AMQPValue::LongString(ref s) => do_gen!(x, gen_type(&v.get_type()) >> gen_long_string(s)),
AMQPValue::FieldArray(ref a) => do_gen!(x, gen_type(&v.get_type()) >> gen_field_array(a)),
AMQPValue::Timestamp(ref t) => do_gen!(x, gen_type(&v.get_type()) >> gen_timestamp(t)),
AMQPValue::FieldTable(ref t) => do_gen!(x, gen_type(&v.get_type()) >> gen_field_table(t)),
AMQPValue::Void => gen_type(x, &v.get_type()),
}
}
pub fn gen_type<'a>(x: (&'a mut [u8], usize), t: &AMQPType) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_u8!(x, t.get_id() as u8)
}
pub fn gen_boolean<'a>(x: (&'a mut [u8], usize), b: &Boolean) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_u8!(x, if *b { 1 } else { 0 })
}
pub fn gen_short_short_int<'a>(x: (&'a mut [u8], usize), i: &ShortShortInt) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_i8!(x, *i)
}
pub fn gen_short_short_uint<'a>(x: (&'a mut [u8], usize), u: &ShortShortUInt) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_u8!(x, *u)
}
pub fn gen_short_int<'a>(x: (&'a mut [u8], usize), i: &ShortInt) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_i16!(x, *i)
}
pub fn gen_short_uint<'a>(x: (&'a mut [u8], usize), u: &ShortUInt) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_u16!(x, *u)
}
pub fn gen_long_int<'a>(x: (&'a mut [u8], usize), i: &LongInt) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_i32!(x, *i)
}
pub fn gen_long_uint<'a>(x: (&'a mut [u8], usize), u: &LongUInt) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_u32!(x, *u)
}
pub fn gen_long_long_int<'a>(x: (&'a mut [u8], usize), i: &LongLongInt) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_i64!(x, *i)
}
pub fn gen_long_long_uint<'a>(x: (&'a mut [u8], usize), u: &LongLongUInt) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_u64!(x, *u)
}
pub fn gen_float<'a>(x: (&'a mut [u8], usize), f: &Float) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_f32!(x, *f)
}
pub fn gen_double<'a>(x: (&'a mut [u8], usize), d: &Double) -> Result<(&'a mut [u8], usize), GenError> {
gen_be_f64!(x, *d)
}
pub fn gen_decimal_value<'a>(x: (&'a mut [u8], usize), d: &DecimalValue) -> Result<(&'a mut [u8], usize), GenError> {
do_gen!(x, gen_short_short_uint(&d.scale) >> gen_long_uint(&d.value))
}
pub fn gen_short_string<'a>(x: (&'a mut [u8], usize), s: &ShortString) -> Result<(&'a mut [u8], usize), GenError> {
do_gen!(x, gen_short_short_uint(&(s.len() as ShortShortUInt)) >> gen_slice!(s.as_bytes()))
}
pub fn gen_long_string<'a>(x: (&'a mut [u8], usize), s: &LongString) -> Result<(&'a mut [u8], usize), GenError> {
do_gen!(x, gen_long_uint(&(s.len() as LongUInt)) >> gen_slice!(s.as_bytes()))
}
pub fn gen_field_array<'a>(x: (&'a mut [u8], usize), a: &FieldArray) -> Result<(&'a mut [u8], usize), GenError> {
let (x1, index1) = x;
gen_many_ref!((x1, index1 + 4), a, gen_value).and_then(|(x2, index2)| {
gen_long_uint((x2, index1), &((index2 - index1 - 4) as LongUInt)).and_then(|(x3, _)| Ok((x3, index2)))
})
}
pub fn gen_timestamp<'a>(x: (&'a mut [u8], usize), t: &Timestamp) -> Result<(&'a mut [u8], usize), GenError> {
gen_long_long_uint(x, t)
}
pub fn gen_field_table<'a>(x: (&'a mut [u8], usize), t: &FieldTable) -> Result<(&'a mut [u8], usize), GenError> {
let (x1, index1) = x;
gen_many_ref!((x1, index1 + 4), t, gen_field_entry).and_then(|(x2, index2)| {
gen_long_uint((x2, index1), &((index2 - index1 - 4) as LongUInt)).and_then(|(x3, _)| Ok((x3, index2)))
})
}
fn gen_field_entry<'a>(x: (&'a mut [u8], usize), e: &(&ShortString, &AMQPValue)) -> Result<(&'a mut [u8], usize), GenError> {
do_gen!(x, gen_short_string(e.0) >> gen_value(e.1))
}
#[cfg(test)]
mod test {
use super::*;
#[test]
fn test_gen_type() {
assert_eq!(gen_type((&mut [0], 0), &AMQPType::ShortShortInt).unwrap(), (&mut [98][..], 1));
assert_eq!(gen_type((&mut [0], 0), &AMQPType::ShortInt).unwrap(), (&mut [85][..], 1));
}
#[test]
fn test_gen_boolean() {
assert_eq!(gen_boolean((&mut [0], 0), &false).unwrap(), (&mut [0][..], 1));
assert_eq!(gen_boolean((&mut [0], 0), &true).unwrap(), (&mut [1][..], 1));
}
#[test]
fn test_gen_short_short_int() {
assert_eq!(gen_short_short_int((&mut [0], 0), &0).unwrap(), (&mut [0][..], 1));
assert_eq!(gen_short_short_int((&mut [0], 0), &-1).unwrap(), (&mut [255][..], 1));
}
#[test]
fn test_gen_short_short_uint() {
assert_eq!(gen_short_short_uint((&mut [0], 0), &0).unwrap(), (&mut [0][..], 1));
assert_eq!(gen_short_short_uint((&mut [0], 0), &255).unwrap(), (&mut [255][..], 1));
}
#[test]
fn test_gen_short_int() {
assert_eq!(gen_short_int((&mut [0, 0], 0), &0).unwrap(), (&mut [0, 0][..], 2));
assert_eq!(gen_short_int((&mut [0, 0], 0), &-1).unwrap(), (&mut [255, 255][..], 2));
}
#[test]
fn test_gen_short_uint() {
assert_eq!(gen_short_uint((&mut [0, 0], 0), &0).unwrap(), (&mut [0, 0][..], 2));
assert_eq!(gen_short_uint((&mut [0, 0], 0), &65535).unwrap(), (&mut [255, 255][..], 2));
}
#[test]
fn test_gen_long_int() {
assert_eq!(gen_long_int((&mut [0, 0, 0, 0], 0), &0).unwrap(), (&mut [0, 0, 0, 0][..], 4));
assert_eq!(gen_long_int((&mut [0, 0, 0, 0], 0), &-1).unwrap(), (&mut [255, 255, 255, 255][..], 4));
}
#[test]
fn test_gen_long_uint() {
assert_eq!(gen_long_uint((&mut [0, 0, 0, 0], 0), &0).unwrap(), (&mut [0, 0, 0, 0][..], 4));
assert_eq!(gen_long_uint((&mut [0, 0, 0, 0], 0), &4294967295).unwrap(), (&mut [255, 255, 255, 255][..], 4));
}
#[test]
fn test_gen_long_long_int() {
assert_eq!(gen_long_long_int((&mut [0, 0, 0, 0, 0, 0, 0, 0], 0), &0).unwrap(), (&mut [0, 0, 0, 0, 0, 0, 0, 0][..], 8));
assert_eq!(gen_long_long_int((&mut [0, 0, 0, 0, 0, 0, 0, 0], 0), &-1).unwrap(), (&mut [255, 255, 255, 255, 255, 255, 255, 255][..], 8));
}
#[test]
fn test_gen_long_long_uint() {
assert_eq!(gen_long_long_uint((&mut [0, 0, 0, 0, 0, 0, 0, 0], 0), &0).unwrap(), (&mut [0, 0, 0, 0, 0, 0, 0, 0][..], 8));
assert_eq!(gen_long_long_uint((&mut [0, 0, 0, 0, 0, 0, 0, 0], 0), &18446744073709551615).unwrap(), (&mut [255, 255, 255, 255, 255, 255, 255, 255][..], 8));
}
#[test]
fn test_gen_float() {
assert_eq!(gen_float((&mut [0, 0, 0, 0], 0), &0.).unwrap(), (&mut [0, 0, 0, 0][..], 4));
assert_eq!(gen_float((&mut [0, 0, 0, 0], 0), &42.42).unwrap(), (&mut [66, 41, 174, 20][..], 4));
}
#[test]
fn test_gen_double() {
assert_eq!(gen_double((&mut [0, 0, 0, 0, 0, 0, 0, 0], 0), &0.).unwrap(), (&mut [0, 0, 0, 0, 0, 0, 0, 0][..], 8));
assert_eq!(gen_double((&mut [0, 0, 0, 0, 0, 0, 0, 0], 0), &42.42).unwrap(), (&mut [64, 69, 53, 194, 143, 92, 40, 246][..], 8));
}
#[test]
fn test_gen_decimal_value() {
assert_eq!(gen_decimal_value((&mut [0, 0, 0, 0, 0], 0), &DecimalValue { scale: 0, value: 0 }).unwrap(), (&mut [0, 0, 0, 0, 0][..], 5));
assert_eq!(gen_decimal_value((&mut [0, 0, 0, 0, 0], 0), &DecimalValue { scale: 2, value: 42 }).unwrap(), (&mut [2, 0, 0, 0, 42][..], 5));
}
#[test]
fn test_gen_field_array() {
assert_eq!(gen_field_array((&mut [0, 0, 0, 0], 0), &FieldArray::new()).unwrap(), (&mut [0, 0, 0, 0][..], 4));
assert_eq!(gen_field_array((&mut [0, 0, 0, 0, 0, 0], 0), &vec![AMQPValue::Boolean(true)]).unwrap(), (&mut [0, 0, 0, 2, 116, 1][..], 6));
}
#[test]
fn test_gen_timestamp() {
assert_eq!(gen_timestamp((&mut [0, 0, 0, 0, 0, 0, 0, 0], 0), &0).unwrap(), (&mut [0, 0, 0, 0, 0, 0, 0, 0][..], 8));
assert_eq!(gen_timestamp((&mut [0, 0, 0, 0, 0, 0, 0, 0], 0), &18446744073709551615).unwrap(), (&mut [255, 255, 255, 255, 255, 255, 255, 255][..], 8));
}
#[test]
fn test_gen_field_table() {
let mut table = FieldTable::new();
table.insert("test".to_string(), AMQPValue::Float(42.42));
table.insert("tt".to_string(), AMQPValue::LongLongInt(42));
assert_eq!(gen_field_table((&mut [0, 0, 0, 0], 0), &FieldTable::new()).unwrap(), (&mut [0, 0, 0, 0][..], 4));
assert_eq!(gen_field_table((&mut [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 0), &table).unwrap(), (&mut [0, 0, 0, 22, 4, 116, 101, 115, 116, 102, 66, 41, 174, 20, 2, 116, 116, 76, 0, 0, 0, 0, 0, 0, 0, 42][..], 26));
}
}