diff options
author | Dominick Allen <dominick.allen1989@gmail.com> | 2020-06-27 20:08:45 -0500 |
---|---|---|
committer | Dominick Allen <dominick.allen1989@gmail.com> | 2020-06-27 20:08:45 -0500 |
commit | 566339318db89bcc434c248f86375708239d235d (patch) | |
tree | 9b50e7f4cfd2048e8dd25dbc76149606f7049781 /src/lib/tokenize.rs | |
parent | 390e5932483613c07aefae9a062c1db28fd56f4d (diff) |
Fixed tokenize.v0.1.1
Diffstat (limited to 'src/lib/tokenize.rs')
-rw-r--r-- | src/lib/tokenize.rs | 22 |
1 files changed, 10 insertions, 12 deletions
diff --git a/src/lib/tokenize.rs b/src/lib/tokenize.rs index 384b04f..0a50036 100644 --- a/src/lib/tokenize.rs +++ b/src/lib/tokenize.rs @@ -1,7 +1,7 @@ use super::types::Type; use super::types::Number; use super::types::Op; -use super::types::SEXP; +use super::sexpr::SExpr; pub type MaybeToken = (Option<Result<Token, String>>, usize); @@ -134,7 +134,7 @@ fn analyze2(expr: &str) -> MaybeToken { (Some(Ok(Token::Value(Type::Bool(true)))), 4) } else if word == "false" { (Some(Ok(Token::Value(Type::Bool(false)))), 5) - } else if let Ok(op) = word.tokenize::<Op>() { + } else if let Ok(op) = word.parse::<Op>() { (Some(Ok(Token::Value(Type::Operator(op)))), word.len()) } else if c.is_alphabetic() { (Some(Ok(Token::Value(Type::Symbol(word.to_string())))), word.len()) @@ -170,7 +170,7 @@ pub fn is_paren(expr: &str) -> MaybeToken { pub fn is_op(expr: &str) -> MaybeToken { let word = make_word(expr); - match word.tokenize::<Op>() { + match word.parse::<Op>() { Ok(op) => (Some(Ok(Token::Value(Type::Operator(op)))), word.len()), _ => (None, 0) } @@ -235,22 +235,20 @@ pub fn is_number(expr: &str) -> MaybeToken { } pub fn is_int(word: &str) -> MaybeToken { - //let word = make_word(expr); - match word.tokenize::<isize>() { + match word.parse::<isize>() { Ok(x) => (Some(Ok(Token::Value(Type::Number(Number::Int(x))))), word.len()), _ => (None, 0) } } pub fn is_float(word: &str) -> MaybeToken { - //let word = make_word(expr); - match word.tokenize::<f32>() { + match word.parse::<f32>() { Ok(x) => (Some(Ok(Token::Value(Type::Number(Number::Float(x))))), word.len()), _ => (None, 0) } } -pub fn tokenize(expr: &str) -> Result<SEXP, String> { +pub fn tokenize(expr: &str) -> Result<SExpr, String> { let mut tokenstream = TokenStream::default(expr); match tokenstream.peek() { Some(Ok(Token::LParen)) => { @@ -258,13 +256,13 @@ pub fn tokenize(expr: &str) -> Result<SEXP, String> { descend(&mut tokenstream) }, Some(Ok(Token::RParen)) => Err("Malformed expression".to_string()), - Some(Ok(Token::Value(x))) => Ok(SEXP::Atom(x)), + Some(Ok(Token::Value(x))) => Ok(SExpr::Atom(x)), Some(Err(f)) => Err(f), None => Err("Empty expression".to_string()) } } -pub fn descend(tokenstream: &mut TokenStream) -> Result<SEXP, String> { +pub fn descend(tokenstream: &mut TokenStream) -> Result<SExpr, String> { let mut sexp = Vec::new(); loop { let token = match tokenstream.next() { @@ -286,11 +284,11 @@ pub fn descend(tokenstream: &mut TokenStream) -> Result<SEXP, String> { break; }, Token::Value(atom) => { - sexp.push(SEXP::Atom(atom)); + sexp.push(SExpr::Atom(atom)); continue; } } } - Ok(SEXP::Sexpr(sexp)) + Ok(SExpr::Sexpr(sexp)) } |