mirror of
https://github.com/ProvableHQ/leo.git
synced 2025-01-07 03:00:50 +03:00
Refactor TupleTyple
This commit is contained in:
parent
072ab7b930
commit
5b2e73d419
@ -18,7 +18,6 @@ use crate::{GroupLiteral, IntegerType};
|
|||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
// TODO: Refactor integer literals to use `IntegerType`.
|
|
||||||
/// A literal.
|
/// A literal.
|
||||||
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
|
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
|
||||||
pub enum Literal {
|
pub enum Literal {
|
||||||
|
@ -53,7 +53,7 @@ impl Finalize {
|
|||||||
let output_type = match output.len() {
|
let output_type = match output.len() {
|
||||||
0 => Type::Unit,
|
0 => Type::Unit,
|
||||||
1 => output[0].type_(),
|
1 => output[0].type_(),
|
||||||
_ => Type::Tuple(TupleType(output.iter().map(|output| output.type_()).collect())),
|
_ => Type::Tuple(TupleType::new(output.iter().map(|output| output.type_()).collect())),
|
||||||
};
|
};
|
||||||
|
|
||||||
Self { identifier, input, output, output_type, block, span, id }
|
Self { identifier, input, output, output_type, block, span, id }
|
||||||
|
@ -100,7 +100,7 @@ impl Function {
|
|||||||
let output_type = match output.len() {
|
let output_type = match output.len() {
|
||||||
0 => Type::Unit,
|
0 => Type::Unit,
|
||||||
1 => get_output_type(&output[0]),
|
1 => get_output_type(&output[0]),
|
||||||
_ => Type::Tuple(TupleType(output.iter().map(get_output_type).collect())),
|
_ => Type::Tuple(TupleType::new(output.iter().map(get_output_type).collect())),
|
||||||
};
|
};
|
||||||
|
|
||||||
Function { annotations, variant, identifier, input, output, output_type, block, finalize, span, id }
|
Function { annotations, variant, identifier, input, output, output_type, block, finalize, span, id }
|
||||||
|
@ -17,24 +17,33 @@
|
|||||||
use crate::Type;
|
use crate::Type;
|
||||||
|
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::{fmt, ops::Deref};
|
use std::fmt;
|
||||||
|
|
||||||
// TODO: Consider defining a safe interface for constructing a tuple type.
|
|
||||||
|
|
||||||
/// A type list of at least two types.
|
/// A type list of at least two types.
|
||||||
#[derive(Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)]
|
#[derive(Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)]
|
||||||
pub struct TupleType(pub Vec<Type>);
|
pub struct TupleType {
|
||||||
|
elements: Vec<Type>,
|
||||||
|
}
|
||||||
|
|
||||||
impl Deref for TupleType {
|
impl TupleType {
|
||||||
type Target = Vec<Type>;
|
/// Creates a new tuple type.
|
||||||
|
pub fn new(elements: Vec<Type>) -> Self {
|
||||||
|
Self { elements }
|
||||||
|
}
|
||||||
|
|
||||||
fn deref(&self) -> &Self::Target {
|
/// Returns the elements of the tuple type.
|
||||||
&self.0
|
pub fn elements(&self) -> &[Type] {
|
||||||
|
&self.elements
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns the length of the tuple type.
|
||||||
|
pub fn length(&self) -> usize {
|
||||||
|
self.elements.len()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl fmt::Display for TupleType {
|
impl fmt::Display for TupleType {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
write!(f, "({})", self.0.iter().map(|x| x.to_string()).collect::<Vec<_>>().join(","))
|
write!(f, "({})", self.elements.iter().map(|x| x.to_string()).collect::<Vec<_>>().join(","))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -78,9 +78,11 @@ impl Type {
|
|||||||
(Type::Mapping(left), Type::Mapping(right)) => {
|
(Type::Mapping(left), Type::Mapping(right)) => {
|
||||||
left.key.eq_flat(&right.key) && left.value.eq_flat(&right.value)
|
left.key.eq_flat(&right.key) && left.value.eq_flat(&right.value)
|
||||||
}
|
}
|
||||||
(Type::Tuple(left), Type::Tuple(right)) if left.len() == right.len() => {
|
(Type::Tuple(left), Type::Tuple(right)) if left.length() == right.length() => left
|
||||||
left.iter().zip_eq(right.iter()).all(|(left_type, right_type)| left_type.eq_flat(right_type))
|
.elements()
|
||||||
}
|
.iter()
|
||||||
|
.zip_eq(right.elements().iter())
|
||||||
|
.all(|(left_type, right_type)| left_type.eq_flat(right_type)),
|
||||||
_ => false,
|
_ => false,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user