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