in src/codec/thrift_cache.rs [375:431]
fn range(rng: &mut SmallRng, keyspace: &Keyspace, buf: &mut Session) {
let key = keyspace.generate_key(rng);
let mut fields = Vec::new();
for _ in 0..keyspace.batch_size() {
fields.push(
keyspace
.generate_inner_key(rng)
.unwrap_or_else(|| b"".to_vec()),
);
}
let mut values = Vec::new();
for _ in 0..keyspace.batch_size() {
values.push(keyspace.generate_value(rng).unwrap_or_else(|| b"".to_vec()));
}
let start = None;
let stop = None;
let mut buffer = thrift::ThriftBuffer::new();
buffer.protocol_header();
buffer.method_name("range");
buffer.sequence_id(0);
buffer.write_bytes(&[thrift::LIST]);
buffer.write_i16(1);
buffer.write_bytes(&[thrift::STRUCT]);
buffer.write_i32(1);
buffer.write_bytes(&[thrift::STRING]);
buffer.write_i16(1);
buffer.write_i32(1);
buffer.write_bytes(b"0");
buffer.write_bytes(&[thrift::STRING]);
buffer.write_i16(2);
buffer.write_i32(key.len() as i32);
buffer.write_bytes(&key);
if let Some(start) = start {
buffer.write_bytes(&[thrift::I32]);
buffer.write_i16(3);
buffer.write_i32(start);
}
if let Some(stop) = stop {
buffer.write_bytes(&[thrift::I32]);
buffer.write_i16(4);
buffer.write_i32(stop);
}
// stop request struct
buffer.stop();
buffer.stop();
buffer.frame();
let _ = buf.write(buffer.as_bytes());
}