From 13028eb4d698181aef2edf9425f42f3610c75d17 Mon Sep 17 00:00:00 2001 From: NilsForssen Date: Mon, 9 Oct 2023 12:26:31 +0200 Subject: [PATCH] Changed operator parsing and added more string functionality --- src/expression.cc | 60 ++++++++++++++++++++++++----------------------- src/expression.h | 23 ++++-------------- 2 files changed, 35 insertions(+), 48 deletions(-) diff --git a/src/expression.cc b/src/expression.cc index 36e3a25..ed2cd5f 100644 --- a/src/expression.cc +++ b/src/expression.cc @@ -13,8 +13,6 @@ Expression::Expression(const std::string & expression) while (iss >> token) { - std::cout << token << std::endl; - if (token.is_integer()) { new_node = new Const_int{std::stoi(token)}; @@ -29,36 +27,39 @@ Expression::Expression(const std::string & expression) } else if (token.is_operator()) { - Node * lhs{stack.top()}; - stack.pop(); Node * rhs{stack.top()}; stack.pop(); + Node * lhs{stack.top()}; + stack.pop(); if (lhs == nullptr || rhs == nullptr) { throw std::logic_error("Missing operands"); } - switch (operator_string_map[token]) + if (token == "+") { - case ADDITION: new_node = new Addition{*lhs, *rhs}; - break; - case SUBTRACTION: + } + else if (token == "-") + { new_node = new Subtraction{*lhs, *rhs}; - break; - case DIVISION: - new_node = new Division{*lhs, *rhs}; - break; - case MULTIPLICATION: + } + else if (token == "/") + { + new_node = new Division{*lhs, *rhs}; + } + else if (token == "*") + { new_node = new Multiplication{*lhs, *rhs}; - break; - case EXPONENT: + } + else if (token == "^") + { new_node = new Exponent{*lhs, *rhs}; - break; - default: + } + else + { throw std::logic_error("Operator not implemented"); - break; } } else @@ -79,18 +80,19 @@ Expression::Expression(const std::string & expression) expression_root = stack.top(); } -std::string Expression::to_string(StringFormat s_format) const +std::string Expression::to_infix_string() const { - switch(s_format) - { - case PREFIX: - return expression_root->get_prefix(); - case POSTFIX: - return expression_root->get_postfix(); - case INFIX: - default: - return expression_root->get_infix(); - } + return expression_root->get_infix(); +} + +std::string Expression::to_postfix_string() const +{ + return expression_root->get_postfix(); +} + +std::string Expression::to_prefix_string() const +{ + return expression_root->get_prefix(); } double Expression::evaluate() const diff --git a/src/expression.h b/src/expression.h index 0ddab71..7ae5a97 100644 --- a/src/expression.h +++ b/src/expression.h @@ -14,24 +14,6 @@ #include #include -typedef enum -{ - PREFIX, - POSTFIX, - INFIX -} StringFormat; - -typedef enum -{ - ADDITION, - SUBTRACTION, - MULTIPLICATION, - DIVISION, - EXPONENT -} Operator_types; - -std::map operator_string_map; - class Expression { public: @@ -40,7 +22,10 @@ public: Expression(Expression const&) = delete; Expression& operator=(Expression const&) = delete; - std::string to_string(StringFormat s_format=INFIX) const; + std::string to_infix_string() const; + std::string to_postfix_string() const; + std::string to_prefix_string() const; + double evaluate() const; protected: -- 2.30.2