1
0
dust/src/value/map.rs

123 lines
3.0 KiB
Rust
Raw Normal View History

2023-12-11 15:18:46 +00:00
use serde::{ser::SerializeMap, Serialize};
2023-08-22 15:40:50 +00:00
use std::{
2023-10-26 20:00:06 +00:00
cmp::Ordering,
2023-08-22 15:40:50 +00:00
collections::BTreeMap,
fmt::{self, Display, Formatter},
sync::{Arc, RwLock, RwLockReadGuard},
2023-08-22 15:40:50 +00:00
};
2023-12-09 22:15:41 +00:00
use crate::{value::Value, Result, Type};
2023-08-22 15:40:50 +00:00
2023-08-24 04:26:37 +00:00
/// A collection dust variables comprised of key-value pairs.
///
/// The inner value is a BTreeMap in order to allow VariableMap instances to be sorted and compared
/// to one another.
2023-10-26 20:00:06 +00:00
#[derive(Clone, Debug)]
2023-10-25 20:44:50 +00:00
pub struct Map {
2023-12-09 22:15:41 +00:00
variables: Arc<RwLock<BTreeMap<String, (Value, Type)>>>,
2023-08-22 15:40:50 +00:00
}
2023-10-25 20:44:50 +00:00
impl Map {
2023-08-22 15:40:50 +00:00
/// Creates a new instace.
pub fn new() -> Self {
2023-10-25 20:44:50 +00:00
Map {
2023-10-26 20:00:06 +00:00
variables: Arc::new(RwLock::new(BTreeMap::new())),
2023-08-22 15:40:50 +00:00
}
}
2023-11-05 18:54:29 +00:00
pub fn clone_from(other: &Self) -> Result<Self> {
2023-10-27 02:35:59 +00:00
let mut new_map = BTreeMap::new();
2023-12-09 22:15:41 +00:00
for (key, (value, r#type)) in other.variables()?.iter() {
new_map.insert(key.clone(), (value.clone(), r#type.clone()));
2023-10-27 02:35:59 +00:00
}
2023-11-05 18:54:29 +00:00
Ok(Map {
2023-10-27 02:35:59 +00:00
variables: Arc::new(RwLock::new(new_map)),
2023-11-05 18:54:29 +00:00
})
2023-08-22 15:40:50 +00:00
}
2023-12-09 22:15:41 +00:00
pub fn variables(&self) -> Result<RwLockReadGuard<BTreeMap<String, (Value, Type)>>> {
2023-11-05 18:54:29 +00:00
Ok(self.variables.read()?)
2023-08-22 15:40:50 +00:00
}
2023-12-09 23:50:17 +00:00
pub fn set(
&self,
key: String,
value: Value,
r#type: Option<Type>,
) -> Result<Option<(Value, Type)>> {
let value_type = r#type.unwrap_or(value.r#type());
2023-12-09 22:55:47 +00:00
let previous = self
.variables
.write()?
.insert(key, (value, value_type.clone()));
Ok(previous)
}
2023-08-22 15:40:50 +00:00
}
2023-10-25 20:44:50 +00:00
impl Default for Map {
2023-08-22 15:40:50 +00:00
fn default() -> Self {
Self::new()
}
}
2023-10-26 20:00:06 +00:00
impl Eq for Map {}
impl PartialEq for Map {
fn eq(&self, other: &Self) -> bool {
let left = self.variables.read().unwrap().clone().into_iter();
let right = other.variables.read().unwrap().clone().into_iter();
left.eq(right)
}
}
impl Ord for Map {
fn cmp(&self, other: &Self) -> Ordering {
let left = self.variables.read().unwrap().clone().into_iter();
let right = other.variables.read().unwrap().clone().into_iter();
left.cmp(right)
}
}
impl PartialOrd for Map {
fn partial_cmp(&self, other: &Self) -> Option<Ordering> {
let left = self.variables.read().unwrap().clone().into_iter();
let right = other.variables.read().unwrap().clone().into_iter();
left.partial_cmp(right)
}
}
2023-10-25 20:44:50 +00:00
impl Display for Map {
2023-08-22 15:40:50 +00:00
fn fmt(&self, f: &mut Formatter<'_>) -> fmt::Result {
2023-10-30 19:48:43 +00:00
writeln!(f, "{{")?;
2023-10-26 20:00:06 +00:00
let variables = self.variables.read().unwrap().clone().into_iter();
2023-12-09 22:15:41 +00:00
for (key, (value, _)) in variables {
2023-10-30 19:48:43 +00:00
writeln!(f, " {key} = {value}")?;
2023-10-14 18:18:13 +00:00
}
write!(f, "}}")
2023-08-22 15:40:50 +00:00
}
}
2023-10-25 20:44:50 +00:00
impl Serialize for Map {
fn serialize<S>(&self, serializer: S) -> std::result::Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
let variables = self.variables.read().unwrap();
let mut map = serializer.serialize_map(Some(variables.len()))?;
for (key, (value, _type)) in variables.iter() {
map.serialize_entry(key, value)?;
}
map.end()
2023-10-25 20:44:50 +00:00
}
}