From 9b00290d74790bb7204449bc96a0ac3660581912 Mon Sep 17 00:00:00 2001 From: chriseth Date: Fri, 11 Mar 2016 17:42:55 +0100 Subject: Remove timestamp again and some fixes for ufixed parsing. --- libsolidity/parsing/Token.cpp | 32 ++++++++++++++++++-------------- libsolidity/parsing/Token.h | 1 - 2 files changed, 18 insertions(+), 15 deletions(-) diff --git a/libsolidity/parsing/Token.cpp b/libsolidity/parsing/Token.cpp index 158ce516..3812a83f 100644 --- a/libsolidity/parsing/Token.cpp +++ b/libsolidity/parsing/Token.cpp @@ -147,21 +147,25 @@ tuple Token::fromIdentifierOrKeyword(s } else if (keyword == Token::UFixed || keyword == Token::Fixed) { - auto positionN = find_if_not(++positionX, _literal.end(), ::isdigit); - int n = parseSize(++positionX, positionN); if ( - 0 < m + n && - m + n <= 256 && - m % 8 == 0 && - n % 8 == 0 && - positionN == _literal.end() && - *positionX == 'x' - ) - { - if (keyword == Token::UFixed) - return make_tuple(Token::UFixed, m, n); - else - return make_tuple(Token::Fixed, m, n); + positionM < positionX && + positionX < _literal.end() && + *positionX == 'x' && + all_of(positionX + 1, _literal.end(), ::isdigit) + ) { + int n = parseSize(positionX + 1, _literal.end()); + if ( + 0 < m && m < 256 && + 0 < n && n < 256 && + m + n <= 256 && + m % 8 == 0 && + n % 8 == 0 + ) { + if (keyword == Token::UFixed) + return make_tuple(Token::UFixed, m, n); + else + return make_tuple(Token::Fixed, m, n); + } } } return make_tuple(Token::Identifier, 0, 0); diff --git a/libsolidity/parsing/Token.h b/libsolidity/parsing/Token.h index b8ad7471..31646f8d 100644 --- a/libsolidity/parsing/Token.h +++ b/libsolidity/parsing/Token.h @@ -231,7 +231,6 @@ namespace solidity K(Type, "type", 0) \ K(TypeOf, "typeof", 0) \ K(Using, "using", 0) \ - T(Timestamp, "timestamp", 0) \ /* Illegal token - not able to scan. */ \ T(Illegal, "ILLEGAL", 0) \ \ -- cgit