-
Notifications
You must be signed in to change notification settings - Fork 46
/
Copy pathoperational_point.rs
120 lines (105 loc) · 3.12 KB
/
operational_point.rs
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
use crate::primitives::NonBlankString;
use derivative::Derivative;
use serde::Deserialize;
use serde::Serialize;
use utoipa::ToSchema;
use super::TrackOffset;
use crate::primitives::Identifier;
use crate::primitives::OSRDIdentified;
use crate::primitives::OSRDTyped;
use crate::primitives::ObjectType;
editoast_common::schemas! {
OperationalPoint,
OperationalPointPart,
}
#[derive(Debug, Derivative, Clone, Deserialize, Serialize, PartialEq, ToSchema)]
#[serde(deny_unknown_fields)]
#[derivative(Default)]
pub struct OperationalPoint {
#[schema(inline)]
pub id: Identifier,
pub parts: Vec<OperationalPointPart>,
#[serde(default)]
#[schema(inline)]
pub extensions: OperationalPointExtensions,
}
#[derive(Debug, Derivative, Clone, Deserialize, Serialize, ToSchema)]
#[serde(deny_unknown_fields)]
#[derivative(Default, PartialEq)]
pub struct OperationalPointPart {
#[derivative(Default(value = r#""InvalidRef".into()"#))]
#[schema(inline)]
pub track: Identifier,
pub position: f64,
#[serde(default)]
#[schema(inline)]
pub extensions: OperationalPointPartExtension,
}
#[derive(Debug, Default, Clone, Deserialize, Serialize, PartialEq, Eq, ToSchema)]
#[serde(deny_unknown_fields)]
pub struct OperationalPointPartExtension {
#[schema(inline)]
pub sncf: Option<OperationalPointPartSncfExtension>,
}
#[derive(Debug, Default, Clone, Deserialize, Serialize, PartialEq, Eq, ToSchema)]
#[serde(deny_unknown_fields)]
pub struct OperationalPointPartSncfExtension {
pub kp: String,
}
#[derive(Debug, Default, Clone, Deserialize, Serialize, PartialEq, Eq, ToSchema)]
#[serde(deny_unknown_fields)]
pub struct OperationalPointExtensions {
#[schema(inline)]
pub sncf: Option<OperationalPointSncfExtension>,
#[schema(inline)]
pub identifier: Option<OperationalPointIdentifierExtension>,
}
#[derive(Debug, Default, Clone, Deserialize, Serialize, PartialEq, Eq, ToSchema)]
#[serde(deny_unknown_fields)]
pub struct OperationalPointSncfExtension {
pub ci: i64,
pub ch: String,
#[schema(inline)]
pub ch_short_label: NonBlankString,
#[schema(inline)]
pub ch_long_label: NonBlankString,
pub trigram: String,
}
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, Eq, ToSchema)]
#[serde(deny_unknown_fields)]
pub struct OperationalPointIdentifierExtension {
#[schema(inline)]
pub name: NonBlankString,
pub uic: i64,
}
impl OSRDTyped for OperationalPoint {
fn get_type() -> ObjectType {
ObjectType::OperationalPoint
}
}
impl OSRDIdentified for OperationalPoint {
fn get_id(&self) -> &String {
&self.id
}
}
impl OperationalPoint {
pub fn track_offset(&self) -> Vec<TrackOffset> {
self.parts
.clone()
.into_iter()
.map(|el| TrackOffset {
track: el.track,
offset: (el.position * 1000.0) as u64,
})
.collect()
}
}
#[cfg(test)]
mod tests {
use serde_json::from_str;
use super::OperationalPointExtensions;
#[test]
fn test_op_extensions_deserialization() {
from_str::<OperationalPointExtensions>(r#"{}"#).unwrap();
}
}