aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/parsing
diff options
context:
space:
mode:
authorRJ Catalano <catalanor0220@gmail.com>2015-12-17 02:55:52 +0800
committerRJ Catalano <catalanor0220@gmail.com>2015-12-17 02:55:52 +0800
commit0ba24a5289eaaf1941c1e84e774f938353b9b94c (patch)
tree8eab9e138065e69a2b5643db9bec61b771b683d2 /libsolidity/parsing
parentcaa6202f62749567870e38c3e4d284984349ca75 (diff)
downloaddexon-solidity-0ba24a5289eaaf1941c1e84e774f938353b9b94c.tar
dexon-solidity-0ba24a5289eaaf1941c1e84e774f938353b9b94c.tar.gz
dexon-solidity-0ba24a5289eaaf1941c1e84e774f938353b9b94c.tar.bz2
dexon-solidity-0ba24a5289eaaf1941c1e84e774f938353b9b94c.tar.lz
dexon-solidity-0ba24a5289eaaf1941c1e84e774f938353b9b94c.tar.xz
dexon-solidity-0ba24a5289eaaf1941c1e84e774f938353b9b94c.tar.zst
dexon-solidity-0ba24a5289eaaf1941c1e84e774f938353b9b94c.zip
changed a couple of small nuances, made an attempt at fixing the parsing in the inline arrays case (fails), and added test for inline arrays per Chriseth request
Diffstat (limited to 'libsolidity/parsing')
-rw-r--r--libsolidity/parsing/Parser.cpp9
1 files changed, 6 insertions, 3 deletions
diff --git a/libsolidity/parsing/Parser.cpp b/libsolidity/parsing/Parser.cpp
index cb5968e9..e7391dff 100644
--- a/libsolidity/parsing/Parser.cpp
+++ b/libsolidity/parsing/Parser.cpp
@@ -1043,9 +1043,10 @@ ASTPointer<Expression> Parser::parsePrimaryExpression()
m_scanner->next();
vector<ASTPointer<Expression>> components;
Token::Value oppositeToken = (token == Token::LParen ? Token::RParen : Token::RBrack);
- bool isArray = (token == Token::LParen ? false : true);
-
- if (m_scanner->currentToken() != Token::RParen)
+ bool isArray = (token == Token::RBrace ? true : false);
+ if (isArray && (m_scanner->currentToken() == Token::Comma))
+ fatalParserError("Expected value in array cell after '[' .");
+ if (m_scanner->currentToken() != oppositeToken)
while (true)
{
if (m_scanner->currentToken() != Token::Comma && m_scanner->currentToken() != oppositeToken)
@@ -1055,6 +1056,8 @@ ASTPointer<Expression> Parser::parsePrimaryExpression()
if (m_scanner->currentToken() == oppositeToken)
break;
else if (m_scanner->currentToken() == Token::Comma)
+ if (isArray && (m_scanner->peekNextToken() == (Token::Comma || oppositeToken)))
+ fatalParserError("Expected value in array cell after ',' .");
m_scanner->next();
}
nodeFactory.markEndPosition();