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
use crate::datatypes::DataType::*;
use crate::datatypes::Schema;
use crate::ipc;
use flatbuffers::FlatBufferBuilder;
fn schema_to_fb(schema: &Schema) -> FlatBufferBuilder {
let mut fbb = FlatBufferBuilder::new();
let mut fields = vec![];
for field in schema.fields() {
let fb_field_name = fbb.create_string(field.name().as_str());
let mut field_builder = ipc::FieldBuilder::new(&mut fbb);
field_builder.add_name(fb_field_name);
let ipc_type = match field.data_type() {
Boolean => ipc::Type::Bool,
UInt8 | UInt16 | UInt32 | UInt64 => ipc::Type::Int,
Int8 | Int16 | Int32 | Int64 => ipc::Type::Int,
Float32 | Float64 => ipc::Type::FloatingPoint,
Utf8 => ipc::Type::Utf8,
Date32(_) | Date64(_) => ipc::Type::Date,
Time32(_) | Time64(_) => ipc::Type::Time,
Timestamp(_) => ipc::Type::Timestamp,
_ => ipc::Type::NONE,
};
field_builder.add_type_type(ipc_type);
field_builder.add_nullable(field.is_nullable());
fields.push(field_builder.finish());
}
let fb_field_list = fbb.create_vector(&fields);
let root = {
let mut builder = ipc::SchemaBuilder::new(&mut fbb);
builder.add_fields(fb_field_list);
builder.finish()
};
fbb.finish(root, None);
fbb
}
#[cfg(test)]
mod tests {
use super::*;
use crate::datatypes::{DataType, Field, Schema};
#[test]
fn convert_schema() {
let schema = Schema::new(vec![Field::new("a", DataType::UInt32, false)]);
let ipc = schema_to_fb(&schema);
assert_eq!(60, ipc.finished_data().len());
}
}