From f5d2151d35942b957230c3081a928af3619d9400 Mon Sep 17 00:00:00 2001 From: Nadrieril Date: Sun, 31 Mar 2019 18:47:34 +0200 Subject: Make SubExpr a newtype --- dhall_core/src/text.rs | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) (limited to 'dhall_core/src/text.rs') diff --git a/dhall_core/src/text.rs b/dhall_core/src/text.rs index d377877..eef0797 100644 --- a/dhall_core/src/text.rs +++ b/dhall_core/src/text.rs @@ -1,18 +1,17 @@ use crate::*; use std::iter::FromIterator; use std::ops::Add; -use std::rc::Rc; #[derive(Debug, Clone, PartialEq, Eq)] pub struct InterpolatedText { head: String, - tail: Vec<(Rc>, String)>, + tail: Vec<(SubExpr, String)>, } -impl From<(String, Vec<(Rc>, String)>)> +impl From<(String, Vec<(SubExpr, String)>)> for InterpolatedText { - fn from(x: (String, Vec<(Rc>, String)>)) -> Self { + fn from(x: (String, Vec<(SubExpr, String)>)) -> Self { InterpolatedText { head: x.0, tail: x.1, @@ -38,7 +37,7 @@ pub enum InterpolatedTextContents { impl InterpolatedText { pub fn map(&self, mut f: F) -> InterpolatedText where - F: FnMut(&Rc>) -> Rc>, + F: FnMut(&SubExpr) -> SubExpr, { InterpolatedText { head: self.head.clone(), @@ -52,7 +51,7 @@ impl InterpolatedText { use std::iter::once; once(InterpolatedTextContents::Text(self.head.clone())).chain( self.tail.iter().flat_map(|(e, s)| { - once(InterpolatedTextContents::Expr(Rc::clone(e))) + once(InterpolatedTextContents::Expr(SubExpr::clone(e))) .chain(once(InterpolatedTextContents::Text(s.clone()))) }), ) -- cgit v1.2.3 From 7374d0524ccd53b256107667b213597c05720d2d Mon Sep 17 00:00:00 2001 From: Nadrieril Date: Sun, 31 Mar 2019 19:08:08 +0200 Subject: Move recursion out of Expr --- dhall_core/src/text.rs | 37 ++++++++++++++++++------------------- 1 file changed, 18 insertions(+), 19 deletions(-) (limited to 'dhall_core/src/text.rs') diff --git a/dhall_core/src/text.rs b/dhall_core/src/text.rs index eef0797..d915553 100644 --- a/dhall_core/src/text.rs +++ b/dhall_core/src/text.rs @@ -1,17 +1,16 @@ -use crate::*; use std::iter::FromIterator; use std::ops::Add; #[derive(Debug, Clone, PartialEq, Eq)] -pub struct InterpolatedText { +pub struct InterpolatedText { head: String, - tail: Vec<(SubExpr, String)>, + tail: Vec<(SubExpr, String)>, } -impl From<(String, Vec<(SubExpr, String)>)> - for InterpolatedText +impl From<(String, Vec<(SubExpr, String)>)> + for InterpolatedText { - fn from(x: (String, Vec<(SubExpr, String)>)) -> Self { + fn from(x: (String, Vec<(SubExpr, String)>)) -> Self { InterpolatedText { head: x.0, tail: x.1, @@ -19,7 +18,7 @@ impl From<(String, Vec<(SubExpr, String)>)> } } -impl From for InterpolatedText { +impl From for InterpolatedText { fn from(s: String) -> Self { InterpolatedText { head: s, @@ -29,15 +28,15 @@ impl From for InterpolatedText { } #[derive(Debug, Clone, PartialEq, Eq)] -pub enum InterpolatedTextContents { +pub enum InterpolatedTextContents { Text(String), - Expr(SubExpr), + Expr(SubExpr), } -impl InterpolatedText { - pub fn map(&self, mut f: F) -> InterpolatedText +impl InterpolatedText { + pub fn map(&self, mut f: F) -> InterpolatedText where - F: FnMut(&SubExpr) -> SubExpr, + F: FnMut(&SubExpr) -> SubExpr2, { InterpolatedText { head: self.head.clone(), @@ -47,7 +46,7 @@ impl InterpolatedText { pub fn iter<'a>( &'a self, - ) -> impl Iterator> + 'a { + ) -> impl Iterator> + 'a { use std::iter::once; once(InterpolatedTextContents::Text(self.head.clone())).chain( self.tail.iter().flat_map(|(e, s)| { @@ -58,12 +57,12 @@ impl InterpolatedText { } } -impl<'a, N: 'a, E: 'a> FromIterator> - for InterpolatedText +impl<'a, SubExpr: Clone + 'a> FromIterator> + for InterpolatedText { fn from_iter(iter: T) -> Self where - T: IntoIterator>, + T: IntoIterator>, { let mut res = InterpolatedText { head: "".to_owned(), @@ -83,9 +82,9 @@ impl<'a, N: 'a, E: 'a> FromIterator> } } -impl Add for &InterpolatedText { - type Output = InterpolatedText; - fn add(self, rhs: &InterpolatedText) -> Self::Output { +impl Add for &InterpolatedText { + type Output = InterpolatedText; + fn add(self, rhs: &InterpolatedText) -> Self::Output { self.iter().chain(rhs.iter()).collect() } } -- cgit v1.2.3 From 57ccbfa16f48f373ac5545b8523de56fb996ba3e Mon Sep 17 00:00:00 2001 From: Nadrieril Date: Mon, 1 Apr 2019 00:17:44 +0200 Subject: Refactor and clarify various map methods --- dhall_core/src/text.rs | 24 +++++++++++++++++++----- 1 file changed, 19 insertions(+), 5 deletions(-) (limited to 'dhall_core/src/text.rs') diff --git a/dhall_core/src/text.rs b/dhall_core/src/text.rs index d915553..9500f32 100644 --- a/dhall_core/src/text.rs +++ b/dhall_core/src/text.rs @@ -33,20 +33,34 @@ pub enum InterpolatedTextContents { Expr(SubExpr), } -impl InterpolatedText { - pub fn map(&self, mut f: F) -> InterpolatedText +impl InterpolatedText { + pub fn map(self, mut f: F) -> InterpolatedText where - F: FnMut(&SubExpr) -> SubExpr2, + F: FnMut(SubExpr) -> SubExpr2, { InterpolatedText { head: self.head.clone(), - tail: self.tail.iter().map(|(e, s)| (f(e), s.clone())).collect(), + tail: self + .tail + .into_iter() + .map(|(e, s)| (f(e), s.clone())) + .collect(), + } + } + + pub fn as_ref(&self) -> InterpolatedText<&SubExpr> { + InterpolatedText { + head: self.head.clone(), + tail: self.tail.iter().map(|(e, s)| (e, s.clone())).collect(), } } pub fn iter<'a>( &'a self, - ) -> impl Iterator> + 'a { + ) -> impl Iterator> + 'a + where + SubExpr: Clone, + { use std::iter::once; once(InterpolatedTextContents::Text(self.head.clone())).chain( self.tail.iter().flat_map(|(e, s)| { -- cgit v1.2.3