summaryrefslogtreecommitdiff
path: root/src/token.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/token.h')
-rw-r--r--src/token.h95
1 files changed, 47 insertions, 48 deletions
diff --git a/src/token.h b/src/token.h
index 582373cb..13a799cb 100644
--- a/src/token.h
+++ b/src/token.h
@@ -49,52 +49,54 @@ namespace ledger {
struct expr_t::token_t : public noncopyable
{
enum kind_t {
- ERROR, // an error occurred while tokenizing
- VALUE, // any kind of literal value
- IDENT, // [A-Za-z_][-A-Za-z0-9_:]*
- MASK, // /regexp/
-
- LPAREN, // (
- RPAREN, // )
-
- EQUAL, // ==
- NEQUAL, // !=
- LESS, // <
- LESSEQ, // <=
- GREATER, // >
- GREATEREQ, // >=
-
- DEFINE, // :=
- ASSIGN, // =
- MATCH, // =~
- NMATCH, // !~
- MINUS, // -
- PLUS, // +
- STAR, // *
- SLASH, // /
- KW_DIV, // div
-
- EXCLAM, // !, not
- KW_AND, // &, &&, and
- KW_OR, // |, ||, or
- KW_MOD, // %
-
- KW_IF, // if
- KW_ELSE, // else
-
- QUERY, // ?
- COLON, // :
-
- DOT, // .
- COMMA, // ,
- SEMI, // ;
+ ERROR, // an error occurred while tokenizing
+ VALUE, // any kind of literal value
+ IDENT, // [A-Za-z_][-A-Za-z0-9_:]*
+ MASK, // /regexp/
+
+ LPAREN, // (
+ RPAREN, // )
+ LBRACE, // {
+ RBRACE, // }
+
+ EQUAL, // ==
+ NEQUAL, // !=
+ LESS, // <
+ LESSEQ, // <=
+ GREATER, // >
+ GREATEREQ, // >=
+
+ ASSIGN, // =
+ MATCH, // =~
+ NMATCH, // !~
+ MINUS, // -
+ PLUS, // +
+ STAR, // *
+ SLASH, // /
+ ARROW, // ->
+ KW_DIV, // div
+
+ EXCLAM, // !, not
+ KW_AND, // &, &&, and
+ KW_OR, // |, ||, or
+ KW_MOD, // %
+
+ KW_IF, // if
+ KW_ELSE, // else
+
+ QUERY, // ?
+ COLON, // :
+
+ DOT, // .
+ COMMA, // ,
+ SEMI, // ;
TOK_EOF,
UNKNOWN
} kind;
- char symbol[3];
+ char symbol[6];
value_t value;
std::size_t length;
@@ -108,24 +110,21 @@ struct expr_t::token_t : public noncopyable
token_t& operator=(const token_t& other) {
if (&other == this)
return *this;
- assert(false); // only one token object is used at a time
+ assert(false); // only one token object is used at a time
return *this;
}
void clear() {
- kind = UNKNOWN;
- length = 0;
- value = NULL_VALUE;
-
+ kind = UNKNOWN;
+ length = 0;
+ value = NULL_VALUE;
symbol[0] = '\0';
- symbol[1] = '\0';
- symbol[2] = '\0';
}
int parse_reserved_word(std::istream& in);
void parse_ident(std::istream& in);
void next(std::istream& in, const parse_flags_t& flags,
- const char expecting = '\0');
+ const char expecting = '\0');
void rewind(std::istream& in);
void unexpected(const char wanted = '\0');
void expected(const char wanted, char c = '\0');