amath  1.8.5
Simple command line calculator
token.cpp
Go to the documentation of this file.
1 /*-
2  * Copyright (c) 2014-2018 Carsten Sonne Larsen <cs@innolan.net>
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
15  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
16  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
17  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
18  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
19  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
20  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
21  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
23  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  *
25  * Project homepage:
26  * https://amath.innolan.net
27  *
28  */
29 
30 #include "amathc.h"
31 #include "main/token.h"
32 
33 #if __GNUC__ > 2
34 #pragma GCC diagnostic ignored "-Wshadow"
35 #endif
36 
37 Token::Token(Token* last, Symbol symbol, int pos)
38 {
39  this->last = last;
40  this->symbol = symbol;
41  this->pos = pos;
42  this->text = nullptr;
43  this->next = nullptr;
44 }
45 
46 Token::Token(Token* last, Symbol symbol, const char* text, int pos)
47 {
48  this->last = last;
49  this->symbol = symbol;
50  this->pos = pos;
51  this->next = nullptr;
52  AllocAndCopy(&this->text, text);
53 }
54 
56 {
57  if (text != nullptr)
58  {
59  delete [] text;
60  }
61 
62  if (next != nullptr)
63  {
64  delete next;
65  }
66 }
67 
69 {
70  return last;
71 }
72 
74 {
75  // Always return a token if requested
76  if (next == nullptr)
77  {
78  next = new Token(this, symend, pos);
79  }
80 
81  return next;
82 }
83 
84 char* Token::GetText() const
85 {
86  return text;
87 }
88 
89 int Token::GetPos() const
90 {
91  return pos;
92 }
Token(Token *last, Symbol symbol, int pos)
Definition: token.cpp:37
Token * last
Definition: token.h:62
char * text
Definition: token.h:61
Tokens are created by the Lexical Analyzer and provides an intermediate state for input consumed by t...
Definition: token.h:46
Symbol symbol
Definition: token.h:53
char * GetText() const
Definition: token.cpp:84
int GetPos() const
Definition: token.cpp:89
Token * GetLastToken() const
Definition: token.cpp:68
int pos
Definition: token.h:60
Token * GetNextToken()
Definition: token.cpp:73
Definition: symbol.h:81
~Token()
Definition: token.cpp:55
Token * next
Definition: token.h:63
unsigned int AllocAndCopy(char **destination, const char *source)
Allocate memory and copy a string into the array.
Definition: alloccpy.c:40
Token(Token *last, Symbol symbol, const char *text, int pos)
Definition: token.cpp:46