X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=ginac%2Fparser%2Flexer.cpp;h=3545ba9ac393ac4a6c8b6adf62e026de2428c2f8;hp=d8c49b8cf4b35da972b19074b506aa0380c3725e;hb=cca88b51436e4b654d16a4d60cd0d1c66fcf5dd6;hpb=b8150271ff497c2ef0c2a8748f5f53b4f1bab7c8 diff --git a/ginac/parser/lexer.cpp b/ginac/parser/lexer.cpp index d8c49b8c..3545ba9a 100644 --- a/ginac/parser/lexer.cpp +++ b/ginac/parser/lexer.cpp @@ -1,11 +1,35 @@ -#include +/** @file lexer.cpp + * + * Implementation of GiNaC's lexer. */ + +/* + * GiNaC Copyright (C) 1999-2014 Johannes Gutenberg University Mainz, Germany + * + * 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, or + * (at your option) any later version. + * + * 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, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#include "lexer.h" +#include "compiler.h" + #include #include -#include "lexer.hpp" -#include "compiler.h" +#include +#include + +namespace GiNaC { -namespace GiNaC -{ /// Skip to the end of line static int skipline(std::istream* s); /// Skip to the next non-whitespace character @@ -19,12 +43,12 @@ int lexer::gettok() // Skip any whitespace. c = skipspace(input, c, line_num); - // identifier: [a-zA-Z][a-zA-Z0-9]* + // identifier: [a-zA-Z][a-zA-Z0-9_]* if (isalpha(c)) { str = c; do { c = input->get(); - if (isalnum(c)) + if ( isalnum(c) || c=='_' ) str += c; else break; @@ -35,13 +59,23 @@ int lexer::gettok() return token_type::identifier; } - // Number: [0-9.]+ + // Number: [0-9]+([.][0-9]*(eE[+-][0-9]+)*)* if (isdigit(c) || c == '.') { str = ""; do { str += c; c = input->get(); } while (isdigit(c) || c == '.'); + if (c == 'E' || c == 'e') { + str += 'E'; + c = input->get(); + if (isdigit(c)) + str += '+'; + do { + str += c; + c = input->get(); + } while (isdigit(c)); + } return token_type::number; } @@ -144,4 +178,3 @@ std::string lexer::tok2str(const int tok) const } } // namespace GiNaC -