dust/dust-lang/src/value.rs

899 lines
25 KiB
Rust
Raw Normal View History

2024-02-25 18:49:26 +00:00
use std::{
2024-02-25 19:26:22 +00:00
cmp::Ordering,
2024-02-28 23:36:47 +00:00
collections::BTreeMap,
2024-03-06 20:36:58 +00:00
fmt::{self, Display, Formatter},
2024-02-25 18:49:26 +00:00
ops::Range,
2024-03-23 12:15:48 +00:00
sync::Arc,
2024-02-25 18:49:26 +00:00
};
2024-06-19 08:56:56 +00:00
use chumsky::container::Container;
use log::{debug, trace};
use serde::{
de::Visitor,
ser::{SerializeMap, SerializeSeq, SerializeStruct, SerializeTuple},
Deserialize, Deserializer, Serialize,
};
2024-06-04 18:47:15 +00:00
2024-03-06 22:32:31 +00:00
use crate::{
2024-07-28 16:52:07 +00:00
abstract_tree::{AbstractNode, Block, BuiltInFunction, Evaluation, SourcePosition, Type},
2024-03-09 03:34:17 +00:00
context::Context,
2024-06-28 19:35:18 +00:00
error::{RuntimeError, ValidationError},
2024-03-25 04:16:55 +00:00
identifier::Identifier,
2024-03-06 22:32:31 +00:00
};
2024-02-25 18:49:26 +00:00
#[derive(Clone, Debug, PartialEq)]
pub struct Value(Arc<ValueInner>);
impl Value {
pub fn inner(&self) -> &Arc<ValueInner> {
&self.0
}
pub fn boolean(boolean: bool) -> Self {
Value(Arc::new(ValueInner::Boolean(boolean)))
}
2024-06-24 13:09:38 +00:00
pub fn built_in_function(function: BuiltInFunction) -> Self {
Value(Arc::new(ValueInner::BuiltInFunction(function)))
}
2024-06-19 14:48:22 +00:00
pub fn enum_instance(
type_name: Identifier,
2024-07-12 15:08:53 +00:00
type_arguments: Option<Vec<Type>>,
2024-06-19 14:48:22 +00:00
variant: Identifier,
2024-07-12 15:08:53 +00:00
content: Option<Value>,
2024-06-19 14:48:22 +00:00
) -> Self {
Value(Arc::new(ValueInner::EnumInstance {
type_name,
2024-07-12 15:08:53 +00:00
type_arguments,
2024-06-19 14:48:22 +00:00
variant,
content,
}))
}
2024-02-25 18:49:26 +00:00
pub fn float(float: f64) -> Self {
Value(Arc::new(ValueInner::Float(float)))
}
pub fn integer(integer: i64) -> Self {
Value(Arc::new(ValueInner::Integer(integer)))
}
2024-06-19 08:56:56 +00:00
pub fn list(list: Vec<Value>) -> Self {
2024-02-25 18:49:26 +00:00
Value(Arc::new(ValueInner::List(list)))
}
2024-02-28 23:36:47 +00:00
pub fn map(map: BTreeMap<Identifier, Value>) -> Self {
Value(Arc::new(ValueInner::Map(map)))
}
2024-02-25 18:49:26 +00:00
pub fn range(range: Range<i64>) -> Self {
Value(Arc::new(ValueInner::Range(range)))
}
2024-03-24 14:58:09 +00:00
pub fn string<T: ToString>(to_string: T) -> Self {
Value(Arc::new(ValueInner::String(to_string.to_string())))
2024-02-25 18:49:26 +00:00
}
2024-03-17 05:26:05 +00:00
pub fn function(
2024-06-17 14:10:06 +00:00
type_parameters: Option<Vec<Identifier>>,
2024-06-24 02:39:33 +00:00
value_parameters: Option<Vec<(Identifier, Type)>>,
2024-06-22 04:58:30 +00:00
return_type: Option<Type>,
2024-06-17 14:10:06 +00:00
body: Block,
2024-03-17 05:26:05 +00:00
) -> Self {
Value(Arc::new(ValueInner::Function(Function::new(
2024-06-17 14:10:06 +00:00
type_parameters,
value_parameters,
2024-04-21 21:00:08 +00:00
return_type,
body,
))))
2024-03-08 21:14:47 +00:00
}
2024-07-28 16:52:07 +00:00
pub fn structure(name: Identifier, fields: Vec<(Identifier, Value)>) -> Self {
2024-03-19 23:16:33 +00:00
Value(Arc::new(ValueInner::Structure { name, fields }))
}
2024-03-19 22:31:52 +00:00
pub fn r#type(&self, context: &Context) -> Result<Type, ValidationError> {
2024-03-20 12:36:18 +00:00
self.0.r#type(context)
2024-03-06 22:32:31 +00:00
}
2024-03-17 20:59:52 +00:00
pub fn as_boolean(&self) -> Option<bool> {
2024-02-25 19:26:22 +00:00
if let ValueInner::Boolean(boolean) = self.0.as_ref() {
2024-03-17 20:59:52 +00:00
Some(*boolean)
} else {
None
2024-03-09 13:10:54 +00:00
}
}
2024-06-19 08:56:56 +00:00
pub fn as_list(&self) -> Option<&Vec<Value>> {
2024-03-07 17:29:07 +00:00
if let ValueInner::List(list) = self.inner().as_ref() {
Some(list)
} else {
None
}
}
pub fn as_integer(&self) -> Option<i64> {
if let ValueInner::Integer(integer) = self.inner().as_ref() {
Some(*integer)
} else {
None
}
}
2024-03-06 20:36:58 +00:00
}
impl Display for Value {
fn fmt(&self, f: &mut Formatter) -> fmt::Result {
match self.inner().as_ref() {
2024-03-08 21:14:47 +00:00
ValueInner::Boolean(boolean) => write!(f, "{boolean}"),
2024-06-19 14:48:22 +00:00
ValueInner::EnumInstance {
type_name,
2024-07-12 15:08:53 +00:00
type_arguments,
2024-06-19 14:48:22 +00:00
variant,
content,
} => {
2024-07-12 15:08:53 +00:00
write!(f, "{type_name}::")?;
2024-06-19 14:48:22 +00:00
2024-07-12 15:08:53 +00:00
if let Some(types) = type_arguments {
write!(f, "::<")?;
for r#type in types {
write!(f, "{type}, ")?;
2024-06-19 14:48:22 +00:00
}
2024-07-12 15:08:53 +00:00
write!(f, ">")?;
}
write!(f, "::{variant}(")?;
if let Some(value) = content {
write!(f, "{value}")?;
2024-06-19 14:48:22 +00:00
}
2024-07-12 15:08:53 +00:00
write!(f, ")")
2024-06-19 14:48:22 +00:00
}
2024-06-24 18:44:10 +00:00
ValueInner::Float(float) => {
write!(f, "{float}")?;
if &float.floor() == float {
write!(f, ".0")?;
}
Ok(())
}
2024-03-08 21:14:47 +00:00
ValueInner::Integer(integer) => write!(f, "{integer}"),
ValueInner::List(list) => {
write!(f, "[")?;
2024-03-08 03:20:59 +00:00
2024-07-12 14:20:52 +00:00
for (index, value) in list.iter().enumerate() {
if index == list.len() - 1 {
2024-06-19 08:56:56 +00:00
write!(f, "{}", value)?;
} else {
2024-06-19 08:56:56 +00:00
write!(f, "{}, ", value)?;
}
2024-03-08 03:20:59 +00:00
}
write!(f, "]")
2024-03-08 03:20:59 +00:00
}
2024-03-08 21:14:47 +00:00
ValueInner::Map(map) => {
2024-06-24 08:16:05 +00:00
write!(f, "{{ ")?;
2024-07-12 14:20:52 +00:00
for (index, (key, value)) in map.iter().enumerate() {
write!(f, "{key} = {value}")?;
2024-03-07 21:19:24 +00:00
2024-06-24 08:16:05 +00:00
if index != map.len() - 1 {
write!(f, ", ")?;
}
2024-03-07 21:19:24 +00:00
}
2024-06-24 08:16:05 +00:00
write!(f, " }}")
2024-03-07 21:19:24 +00:00
}
2024-06-26 15:35:39 +00:00
ValueInner::Range(range) => write!(f, "{}..{}", range.start, range.end),
2024-03-08 21:14:47 +00:00
ValueInner::String(string) => write!(f, "{string}"),
2024-04-21 21:00:08 +00:00
ValueInner::Function(Function {
2024-06-17 14:10:06 +00:00
type_parameters,
2024-06-24 02:39:33 +00:00
value_parameters,
2024-03-08 21:14:47 +00:00
return_type,
body,
2024-06-22 17:55:43 +00:00
..
2024-04-21 21:00:08 +00:00
}) => {
2024-06-26 15:35:39 +00:00
write!(f, "fn ")?;
2024-06-17 14:10:06 +00:00
if let Some(type_parameters) = type_parameters {
2024-06-26 18:44:23 +00:00
write!(f, "<")?;
2024-03-24 13:10:49 +00:00
2024-07-12 14:20:52 +00:00
for (index, identifier) in type_parameters.iter().enumerate() {
2024-06-17 14:10:06 +00:00
if index == type_parameters.len() - 1 {
2024-06-26 15:35:39 +00:00
write!(f, "{}", identifier)?;
2024-03-24 13:10:49 +00:00
} else {
2024-06-26 15:35:39 +00:00
write!(f, "{} ", identifier)?;
2024-03-24 13:10:49 +00:00
}
}
2024-06-26 18:44:23 +00:00
write!(f, ">")?;
2024-03-24 13:10:49 +00:00
}
2024-03-08 21:14:47 +00:00
write!(f, "(")?;
2024-06-24 02:39:33 +00:00
if let Some(value_parameters) = value_parameters {
for (identifier, r#type) in value_parameters {
write!(f, "{identifier}: {}", r#type)?;
}
2024-03-08 21:14:47 +00:00
}
2024-03-08 03:20:59 +00:00
2024-06-22 04:58:30 +00:00
write!(f, ")")?;
if let Some(return_type) = return_type {
2024-06-26 21:35:30 +00:00
write!(f, " -> {return_type}")?
2024-06-22 04:58:30 +00:00
}
2024-06-26 21:35:30 +00:00
write!(f, " {body}")
2024-03-08 21:14:47 +00:00
}
2024-03-19 23:33:02 +00:00
ValueInner::Structure { name, fields } => {
2024-07-28 16:52:07 +00:00
write!(f, "{name} {{")?;
2024-03-19 23:33:02 +00:00
for (key, value) in fields {
2024-07-28 16:52:07 +00:00
write!(f, "{key} = {value},")?;
2024-03-19 23:33:02 +00:00
}
write!(f, "}}")
2024-03-19 23:33:02 +00:00
}
2024-06-26 15:35:39 +00:00
ValueInner::BuiltInFunction(built_in_function) => write!(f, "{built_in_function}"),
2024-03-06 20:36:58 +00:00
}
}
2024-02-25 19:26:22 +00:00
}
impl Eq for Value {}
impl PartialOrd for Value {
fn partial_cmp(&self, other: &Self) -> Option<std::cmp::Ordering> {
Some(self.cmp(other))
}
}
impl Ord for Value {
fn cmp(&self, other: &Self) -> std::cmp::Ordering {
self.0.as_ref().cmp(other.0.as_ref())
}
2024-02-25 18:49:26 +00:00
}
2024-06-04 18:47:15 +00:00
impl Serialize for Value {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
2024-06-04 18:47:15 +00:00
where
S: serde::Serializer,
{
match self.0.as_ref() {
ValueInner::Boolean(boolean) => serializer.serialize_bool(*boolean),
2024-06-19 14:48:22 +00:00
ValueInner::EnumInstance {
type_name,
2024-07-12 15:08:53 +00:00
type_arguments,
2024-06-19 14:48:22 +00:00
variant,
content,
} => {
let mut struct_ser = serializer.serialize_struct("EnumInstance", 3)?;
struct_ser.serialize_field("type_name", type_name)?;
2024-07-12 15:08:53 +00:00
struct_ser.serialize_field("type_arguments", type_arguments)?;
2024-06-19 14:48:22 +00:00
struct_ser.serialize_field("variant", variant)?;
struct_ser.serialize_field("content", content)?;
struct_ser.end()
}
ValueInner::Float(float) => serializer.serialize_f64(*float),
ValueInner::Function(Function {
type_parameters,
value_parameters,
return_type,
body,
2024-06-22 17:55:43 +00:00
..
}) => {
let mut struct_ser = serializer.serialize_struct("Function", 4)?;
struct_ser.serialize_field("type_parameters", type_parameters)?;
struct_ser.serialize_field("value_parameters", value_parameters)?;
struct_ser.serialize_field("return_type", return_type)?;
struct_ser.serialize_field("body", body)?;
struct_ser.end()
}
ValueInner::Integer(integer) => serializer.serialize_i64(*integer),
ValueInner::List(list) => {
let mut list_ser = serializer.serialize_seq(Some(list.len()))?;
for item in list {
2024-06-19 08:56:56 +00:00
list_ser.serialize_element(&item)?;
}
list_ser.end()
}
ValueInner::Map(map) => {
let mut map_ser = serializer.serialize_map(Some(map.len()))?;
for (identifier, value) in map {
map_ser.serialize_entry(identifier, value)?;
}
map_ser.end()
}
ValueInner::Range(range) => {
let mut tuple_ser = serializer.serialize_tuple(2)?;
tuple_ser.serialize_element(&range.start)?;
tuple_ser.serialize_element(&range.end)?;
tuple_ser.end()
}
ValueInner::String(string) => serializer.serialize_str(string),
ValueInner::Structure { name, fields } => {
let mut struct_ser = serializer.serialize_struct("Structure", 2)?;
struct_ser.serialize_field("name", name)?;
struct_ser.serialize_field("fields", fields)?;
struct_ser.end()
}
2024-06-24 11:13:54 +00:00
ValueInner::BuiltInFunction(_) => todo!(),
}
}
}
struct ValueVisitor;
impl<'de> Visitor<'de> for ValueVisitor {
type Value = Value;
fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
formatter
.write_str("a boolean, float, function, integer, list, map, range, string or structure")
}
fn visit_bool<E>(self, v: bool) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
2024-06-19 08:56:56 +00:00
Ok(Value::boolean(v))
}
fn visit_i8<E>(self, v: i8) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_i64(v as i64)
}
fn visit_i16<E>(self, v: i16) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_i64(v as i64)
}
fn visit_i32<E>(self, v: i32) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_i64(v as i64)
}
fn visit_i64<E>(self, v: i64) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
Ok(Value::integer(v))
}
2024-06-19 08:56:56 +00:00
fn visit_i128<E>(self, _: i128) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
todo!()
}
fn visit_u8<E>(self, v: u8) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_u64(v as u64)
}
fn visit_u16<E>(self, v: u16) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_u64(v as u64)
}
fn visit_u32<E>(self, v: u32) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_u64(v as u64)
}
fn visit_u64<E>(self, v: u64) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
Ok(Value::integer(v as i64))
}
2024-06-19 08:56:56 +00:00
fn visit_u128<E>(self, _: u128) -> Result<Self::Value, E>
where
E: serde::de::Error,
2024-06-04 18:47:15 +00:00
{
todo!()
}
fn visit_f32<E>(self, v: f32) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_f64(v as f64)
}
fn visit_f64<E>(self, v: f64) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
2024-06-19 08:56:56 +00:00
Ok(Value::float(v))
}
fn visit_char<E>(self, v: char) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_str(v.encode_utf8(&mut [0u8; 4]))
}
fn visit_str<E>(self, v: &str) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
2024-06-19 08:56:56 +00:00
Ok(Value::string(v))
}
fn visit_borrowed_str<E>(self, v: &'de str) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_str(v)
}
fn visit_string<E>(self, v: String) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_str(&v)
}
fn visit_bytes<E>(self, v: &[u8]) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
Err(serde::de::Error::invalid_type(
serde::de::Unexpected::Bytes(v),
&self,
))
}
fn visit_borrowed_bytes<E>(self, v: &'de [u8]) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_bytes(v)
}
fn visit_byte_buf<E>(self, v: Vec<u8>) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
self.visit_bytes(&v)
}
fn visit_none<E>(self) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
Err(serde::de::Error::invalid_type(
serde::de::Unexpected::Option,
&self,
))
}
fn visit_some<D>(self, deserializer: D) -> Result<Self::Value, D::Error>
where
D: Deserializer<'de>,
{
let _ = deserializer;
Err(serde::de::Error::invalid_type(
serde::de::Unexpected::Option,
&self,
))
}
fn visit_unit<E>(self) -> Result<Self::Value, E>
where
E: serde::de::Error,
{
Err(serde::de::Error::invalid_type(
serde::de::Unexpected::Unit,
&self,
))
}
fn visit_newtype_struct<D>(self, deserializer: D) -> Result<Self::Value, D::Error>
where
D: Deserializer<'de>,
{
let _ = deserializer;
Err(serde::de::Error::invalid_type(
serde::de::Unexpected::NewtypeStruct,
&self,
))
}
2024-06-19 08:56:56 +00:00
fn visit_seq<A>(self, mut seq: A) -> Result<Self::Value, A::Error>
where
A: serde::de::SeqAccess<'de>,
{
2024-06-19 08:56:56 +00:00
let mut list = Vec::with_capacity(seq.size_hint().unwrap_or(10));
while let Some(element) = seq.next_element()? {
list.push(element);
}
Ok(Value::list(list))
}
2024-06-19 08:56:56 +00:00
fn visit_map<A>(self, mut map: A) -> Result<Self::Value, A::Error>
where
A: serde::de::MapAccess<'de>,
{
2024-06-19 08:56:56 +00:00
let mut btree = BTreeMap::with_capacity(map.size_hint().unwrap_or(10));
while let Some((key, value)) = map.next_entry()? {
btree.insert(key, value);
}
Ok(Value::map(btree))
}
fn visit_enum<A>(self, data: A) -> Result<Self::Value, A::Error>
where
A: serde::de::EnumAccess<'de>,
{
let _ = data;
Err(serde::de::Error::invalid_type(
serde::de::Unexpected::Enum,
&self,
))
}
2024-06-04 18:47:15 +00:00
}
impl<'de> Deserialize<'de> for Value {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
2024-06-04 18:47:15 +00:00
where
D: Deserializer<'de>,
2024-06-04 18:47:15 +00:00
{
deserializer.deserialize_any(ValueVisitor)
2024-06-04 18:47:15 +00:00
}
}
2024-06-22 17:55:43 +00:00
#[derive(Clone, Debug, PartialEq)]
2024-02-25 18:49:26 +00:00
pub enum ValueInner {
Boolean(bool),
2024-06-24 11:13:54 +00:00
BuiltInFunction(BuiltInFunction),
2024-06-19 14:48:22 +00:00
EnumInstance {
type_name: Identifier,
2024-07-12 15:08:53 +00:00
type_arguments: Option<Vec<Type>>,
2024-06-19 14:48:22 +00:00
variant: Identifier,
2024-07-12 15:08:53 +00:00
content: Option<Value>,
2024-06-19 14:48:22 +00:00
},
2024-02-25 18:49:26 +00:00
Float(f64),
2024-03-08 21:14:47 +00:00
Function(Function),
2024-02-25 18:49:26 +00:00
Integer(i64),
2024-06-19 08:56:56 +00:00
List(Vec<Value>),
2024-02-28 23:36:47 +00:00
Map(BTreeMap<Identifier, Value>),
2024-02-25 18:49:26 +00:00
Range(Range<i64>),
String(String),
2024-03-19 22:31:52 +00:00
Structure {
2024-07-28 16:52:07 +00:00
name: Identifier,
2024-03-19 23:16:33 +00:00
fields: Vec<(Identifier, Value)>,
2024-03-19 22:31:52 +00:00
},
2024-02-25 18:49:26 +00:00
}
2024-03-20 12:36:18 +00:00
impl ValueInner {
pub fn r#type(&self, context: &Context) -> Result<Type, ValidationError> {
let r#type = match self {
ValueInner::Boolean(_) => Type::Boolean,
2024-06-19 14:48:22 +00:00
ValueInner::EnumInstance { type_name, .. } => {
if let Some(r#type) = context.get_type(type_name)? {
r#type
} else {
return Err(ValidationError::EnumDefinitionNotFound {
identifier: type_name.clone(),
position: None,
});
2024-06-19 14:48:22 +00:00
}
}
2024-03-20 12:36:18 +00:00
ValueInner::Float(_) => Type::Float,
ValueInner::Integer(_) => Type::Integer,
ValueInner::List(values) => {
2024-06-19 08:56:56 +00:00
let item_type = values.first().unwrap().r#type(context)?;
2024-03-20 12:36:18 +00:00
2024-06-17 14:10:06 +00:00
Type::List {
length: values.len(),
item_type: Box::new(item_type),
2024-03-20 12:36:18 +00:00
}
}
2024-06-24 08:02:44 +00:00
ValueInner::Map(value_map) => {
let mut type_map = BTreeMap::with_capacity(value_map.len());
for (identifier, value) in value_map {
let r#type = value.r#type(context)?;
type_map.insert(identifier.clone(), r#type);
}
Type::Map(type_map)
}
2024-03-20 12:36:18 +00:00
ValueInner::Range(_) => Type::Range,
ValueInner::String(_) => Type::String,
2024-06-19 02:01:18 +00:00
ValueInner::Function(function) => {
2024-07-12 14:20:52 +00:00
let return_type = function.return_type.clone().map(Box::new);
2024-06-19 02:01:18 +00:00
Type::Function {
type_parameters: function.type_parameters().clone(),
2024-06-24 02:39:33 +00:00
value_parameters: function.value_parameters().clone(),
2024-06-22 04:58:30 +00:00
return_type,
2024-06-19 02:01:18 +00:00
}
}
2024-03-20 12:36:18 +00:00
ValueInner::Structure { name, .. } => {
2024-08-02 19:21:15 +00:00
if let Some(r#type) = context.get_type(name)? {
2024-03-20 12:36:18 +00:00
r#type
} else {
2024-07-28 16:52:07 +00:00
return Err(ValidationError::StructDefinitionNotFound {
identifier: name.clone(),
position: None,
2024-03-25 04:16:55 +00:00
});
2024-03-20 12:36:18 +00:00
}
}
2024-06-24 13:09:38 +00:00
ValueInner::BuiltInFunction(function) => function.r#type(),
2024-03-20 12:36:18 +00:00
};
Ok(r#type)
}
}
2024-02-25 19:26:22 +00:00
impl Eq for ValueInner {}
impl PartialOrd for ValueInner {
fn partial_cmp(&self, other: &Self) -> Option<Ordering> {
Some(self.cmp(other))
}
}
impl Ord for ValueInner {
fn cmp(&self, other: &Self) -> Ordering {
use ValueInner::*;
match (self, other) {
(Boolean(left), Boolean(right)) => left.cmp(right),
(Boolean(_), _) => Ordering::Greater,
(Float(left), Float(right)) => left.total_cmp(right),
(Float(_), _) => Ordering::Greater,
(Integer(left), Integer(right)) => left.cmp(right),
(Integer(_), _) => Ordering::Greater,
(List(left), List(right)) => left.cmp(right),
(List(_), _) => Ordering::Greater,
2024-02-28 23:36:47 +00:00
(Map(left), Map(right)) => left.cmp(right),
(Map(_), _) => Ordering::Greater,
2024-02-25 19:26:22 +00:00
(Range(left), Range(right)) => {
let start_cmp = left.start.cmp(&right.start);
if start_cmp.is_eq() {
left.end.cmp(&right.end)
} else {
start_cmp
}
}
(Range(_), _) => Ordering::Greater,
(String(left), String(right)) => left.cmp(right),
(String(_), _) => Ordering::Greater,
2024-06-19 14:48:22 +00:00
(
EnumInstance {
type_name: left_name,
2024-07-12 15:08:53 +00:00
type_arguments: left_arguments,
2024-06-19 14:48:22 +00:00
variant: left_variant,
content: left_content,
},
EnumInstance {
type_name: right_name,
2024-07-12 15:08:53 +00:00
type_arguments: right_arguments,
2024-06-19 14:48:22 +00:00
variant: right_variant,
content: right_content,
},
) => {
let name_cmp = left_name.cmp(right_name);
if name_cmp.is_eq() {
2024-07-12 15:08:53 +00:00
let argument_cmp = left_arguments.cmp(right_arguments);
if argument_cmp.is_eq() {
let variant_cmp = left_variant.cmp(right_variant);
2024-06-19 14:48:22 +00:00
2024-07-12 15:08:53 +00:00
if variant_cmp.is_eq() {
left_content.cmp(right_content)
} else {
variant_cmp
}
2024-06-19 14:48:22 +00:00
} else {
2024-07-12 15:08:53 +00:00
argument_cmp
2024-06-19 14:48:22 +00:00
}
} else {
name_cmp
}
}
(EnumInstance { .. }, _) => Ordering::Greater,
2024-03-08 21:14:47 +00:00
(Function(left), Function(right)) => left.cmp(right),
(Function(_), _) => Ordering::Greater,
2024-03-19 22:31:52 +00:00
(
Structure {
name: left_name,
fields: left_fields,
},
Structure {
name: right_name,
fields: right_fields,
},
) => {
let name_cmp = left_name.cmp(right_name);
if name_cmp.is_eq() {
left_fields.cmp(right_fields)
} else {
name_cmp
}
}
(Structure { .. }, _) => Ordering::Greater,
2024-06-24 11:13:54 +00:00
(BuiltInFunction(left), BuiltInFunction(right)) => left.cmp(right),
(BuiltInFunction(_), _) => Ordering::Greater,
2024-02-25 19:26:22 +00:00
}
}
}
2024-03-08 21:14:47 +00:00
2024-07-11 21:22:30 +00:00
#[derive(Debug)]
2024-04-21 21:00:08 +00:00
pub struct Function {
2024-06-17 14:10:06 +00:00
type_parameters: Option<Vec<Identifier>>,
2024-06-24 02:39:33 +00:00
value_parameters: Option<Vec<(Identifier, Type)>>,
2024-06-22 04:58:30 +00:00
return_type: Option<Type>,
2024-06-17 14:10:06 +00:00
body: Block,
context: Context,
2024-03-09 03:34:17 +00:00
}
2024-03-09 13:10:54 +00:00
impl Function {
2024-06-22 21:17:35 +00:00
pub fn new(
type_parameters: Option<Vec<Identifier>>,
2024-06-24 02:39:33 +00:00
value_parameters: Option<Vec<(Identifier, Type)>>,
2024-06-22 21:17:35 +00:00
return_type: Option<Type>,
body: Block,
) -> Self {
Self {
type_parameters,
value_parameters,
return_type,
body,
context: Context::new(),
2024-06-22 21:17:35 +00:00
}
}
2024-06-17 14:10:06 +00:00
pub fn type_parameters(&self) -> &Option<Vec<Identifier>> {
2024-04-21 21:00:08 +00:00
&self.type_parameters
}
2024-03-09 13:10:54 +00:00
2024-06-24 02:39:33 +00:00
pub fn value_parameters(&self) -> &Option<Vec<(Identifier, Type)>> {
2024-06-19 02:01:18 +00:00
&self.value_parameters
}
2024-06-19 06:32:17 +00:00
pub fn body(&self) -> &Block {
&self.body
}
pub fn call(
self,
outer_context: Option<&Context>,
type_arguments: Option<Vec<Type>>,
value_arguments: Option<Vec<Value>>,
2024-06-22 03:37:25 +00:00
) -> Result<Option<Evaluation>, RuntimeError> {
trace!("Setting function call variables");
if let Some(outer_context) = outer_context {
if &self.context == outer_context {
log::debug!("Recursion detected");
}
self.context.inherit_variables_from(outer_context)?;
}
if let (Some(type_parameters), Some(type_arguments)) =
(self.type_parameters, type_arguments)
{
for (identifier, r#type) in type_parameters.into_iter().zip(type_arguments.into_iter())
{
self.context
.set_type(identifier.clone(), r#type, SourcePosition(0, usize::MAX))?;
}
}
if let (Some(value_parameters), Some(value_arguments)) =
(self.value_parameters, value_arguments)
{
for ((identifier, _), value) in value_parameters
.into_iter()
.zip(value_arguments.into_iter())
{
self.context
.set_value(identifier.clone(), value, SourcePosition(0, usize::MAX))?;
}
}
debug!("Calling function");
2024-07-04 18:39:45 +00:00
self.body
.evaluate(&self.context, false, SourcePosition(0, usize::MAX))
}
}
2024-07-11 21:22:30 +00:00
impl Clone for Function {
fn clone(&self) -> Self {
Function {
type_parameters: self.type_parameters.clone(),
value_parameters: self.value_parameters.clone(),
return_type: self.return_type.clone(),
body: self.body.clone(),
context: Context::new(),
}
}
}
impl Eq for Function {}
impl PartialEq for Function {
fn eq(&self, other: &Self) -> bool {
self.type_parameters == other.type_parameters
&& self.value_parameters == other.value_parameters
&& self.return_type == other.return_type
&& self.body == other.body
}
}
impl PartialOrd for Function {
fn partial_cmp(&self, other: &Self) -> Option<Ordering> {
Some(self.cmp(other))
}
}
impl Ord for Function {
fn cmp(&self, other: &Self) -> Ordering {
2024-07-12 14:20:52 +00:00
let type_param_cmp = self.type_parameters().cmp(&other.type_parameters);
if type_param_cmp.is_eq() {
let value_param_cmp = self.value_parameters.cmp(&other.value_parameters);
if value_param_cmp.is_eq() {
let return_type_cmp = self.return_type.cmp(&other.return_type);
if return_type_cmp.is_eq() {
self.body.cmp(&other.body)
} else {
return_type_cmp
}
} else {
value_param_cmp
}
} else {
type_param_cmp
}
2024-06-22 17:55:43 +00:00
}
2024-03-09 13:10:54 +00:00
}