diff options
author | chriseth <chris@ethereum.org> | 2018-04-12 04:25:36 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-04-12 04:25:36 +0800 |
commit | ee5d0ef79bee71a47249ed36081738dd34707900 (patch) | |
tree | fcc1d4e910eef36fef15fca3e036f3039146450c /libsolidity/parsing/Parser.cpp | |
parent | 7626c8ab7276266c3721310d41455c393d1ee888 (diff) | |
parent | b5a696ad48780bf0614eef2a737a2e89963d4640 (diff) | |
download | dexon-solidity-ee5d0ef79bee71a47249ed36081738dd34707900.tar dexon-solidity-ee5d0ef79bee71a47249ed36081738dd34707900.tar.gz dexon-solidity-ee5d0ef79bee71a47249ed36081738dd34707900.tar.bz2 dexon-solidity-ee5d0ef79bee71a47249ed36081738dd34707900.tar.lz dexon-solidity-ee5d0ef79bee71a47249ed36081738dd34707900.tar.xz dexon-solidity-ee5d0ef79bee71a47249ed36081738dd34707900.tar.zst dexon-solidity-ee5d0ef79bee71a47249ed36081738dd34707900.zip |
Merge pull request #3752 from ethereum/fixStateVariableParsing
Fix state variable parsing
Diffstat (limited to 'libsolidity/parsing/Parser.cpp')
-rw-r--r-- | libsolidity/parsing/Parser.cpp | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/libsolidity/parsing/Parser.cpp b/libsolidity/parsing/Parser.cpp index 18ef740a..2d8ca7d3 100644 --- a/libsolidity/parsing/Parser.cpp +++ b/libsolidity/parsing/Parser.cpp @@ -365,12 +365,13 @@ Parser::FunctionHeaderParserResult Parser::parseFunctionHeader( Token::Value token = m_scanner->currentToken(); if (_allowModifiers && token == Token::Identifier) { - // This can either be a modifier (function declaration) or the name of the - // variable (function type name plus variable). - if ( + // If the name is empty (and this is not a constructor), + // then this can either be a modifier (fallback function declaration) + // or the name of the state variable (function type name plus variable). + if ((result.name->empty() && !result.isConstructor) && ( m_scanner->peekNextToken() == Token::Semicolon || m_scanner->peekNextToken() == Token::Assign - ) + )) // Variable declaration, break here. break; else @@ -380,6 +381,14 @@ Parser::FunctionHeaderParserResult Parser::parseFunctionHeader( { if (result.visibility != Declaration::Visibility::Default) { + // There is the special case of a public state variable of function type. + // Detect this and return early. + if ( + (result.visibility == Declaration::Visibility::External || result.visibility == Declaration::Visibility::Internal) && + result.modifiers.empty() && + (result.name->empty() && !result.isConstructor) + ) + break; parserError(string( "Visibility already specified as \"" + Declaration::visibilityToString(result.visibility) + @@ -429,6 +438,7 @@ ASTPointer<ASTNode> Parser::parseFunctionDefinitionOrFunctionTypeStateVariable(A FunctionHeaderParserResult header = parseFunctionHeader(false, true, _contractName); if ( + header.isConstructor || !header.modifiers.empty() || !header.name->empty() || m_scanner->currentToken() == Token::Semicolon || @@ -794,6 +804,7 @@ ASTPointer<FunctionTypeName> Parser::parseFunctionType() RecursionGuard recursionGuard(*this); ASTNodeFactory nodeFactory(*this); FunctionHeaderParserResult header = parseFunctionHeader(true, false); + solAssert(!header.isConstructor, "Tried to parse type as constructor."); return nodeFactory.createNode<FunctionTypeName>( header.parameters, header.returnParameters, |