/** Serene --- Yet an other Lisp * * Copyright (c) 2020 Sameer Rahmani * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 2 of the License. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ use crate::namespace::Namespace; use crate::types::{ExprResult, Expression, List, Number, Symbol}; #[derive(Debug, Eq, PartialEq, Clone)] pub enum Expr { Sym(Symbol), Str(String), Num(Number), Comment, Error(String), Cons(List), Nil, NoMatch, } impl<'a> Expr { pub fn make_list(first: Expr, rest: Expr) -> Expr { Expr::Cons(List::::new(Box::new(first), Box::new(rest))) } pub fn make_symbol(v: String) -> Expr { Expr::Sym(Symbol::new(v)) } pub fn make_string(v: String) -> Expr { Expr::Str(v) } pub fn make_number(n: Number) -> Expr { Expr::Num(n) } } impl<'a> Expression<'a> for Expr { fn eval() {} fn code_gen(&self, ns: &Namespace) -> ExprResult<'a> { match self { Expr::Sym(s) => s.code_gen(ns), _ => Err("NotImplemented".to_string()), } } }