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
use crate::scenario_format::{
interpret_trait::{InterpretableFrom, InterpreterContext, IntoRaw},
value_interpreter::interpret_string,
};
use num_bigint::BigUint;
use num_traits::ToPrimitive;
use std::{
cmp::{Ord, Ordering},
fmt,
};
#[derive(Clone, Debug)]
pub struct U64Key {
pub value: u64,
pub original: String,
}
impl PartialEq for U64Key {
fn eq(&self, other: &Self) -> bool {
self.value == other.value
}
}
impl Eq for U64Key {}
impl PartialOrd for U64Key {
fn partial_cmp(&self, other: &Self) -> Option<Ordering> {
self.value.partial_cmp(&other.value)
}
}
impl Ord for U64Key {
fn cmp(&self, other: &Self) -> Ordering {
self.value.cmp(&other.value)
}
}
impl InterpretableFrom<&str> for U64Key {
fn interpret_from(from: &str, context: &InterpreterContext) -> Self {
let bytes = interpret_string(from, context);
let bu = BigUint::from_bytes_be(&bytes);
U64Key {
value: bu.to_u64().unwrap(),
original: from.to_string(),
}
}
}
impl IntoRaw<String> for U64Key {
fn into_raw(self) -> String {
self.original
}
}
impl From<u64> for U64Key {
fn from(from: u64) -> Self {
U64Key {
value: from,
original: from.to_string(),
}
}
}
impl From<u32> for U64Key {
fn from(from: u32) -> Self {
U64Key {
value: from as u64,
original: from.to_string(),
}
}
}
impl From<i32> for U64Key {
fn from(from: i32) -> Self {
assert!(from >= 0, "U64Key cannot be negative");
Self::from(from as u32)
}
}
impl From<&str> for U64Key {
fn from(from: &str) -> Self {
U64Key::interpret_from(from, &InterpreterContext::default())
}
}
impl fmt::Display for U64Key {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
self.original.fmt(f)
}
}