From c253a90fc46a9ec39db8e4bd57efad767dc2bd0e Mon Sep 17 00:00:00 2001 From: Christian Date: Mon, 20 Oct 2014 13:02:06 +0200 Subject: [PATCH] Coding style cleanup: const and vecptr. --- libsolidity/AST.cpp | 2 +- libsolidity/AST.h | 40 +++++++++++++++++++------------------- libsolidity/ASTForward.h | 2 -- libsolidity/ASTPrinter.cpp | 6 +++--- libsolidity/Parser.cpp | 30 ++++++++++++++-------------- libsolidity/Parser.h | 4 ++-- libsolidity/Scanner.cpp | 16 +++++++-------- libsolidity/Scanner.h | 6 +++--- libsolidity/Token.cpp | 8 ++++---- libsolidity/Token.h | 12 ++++++------ libsolidity/Types.cpp | 14 ++++++------- libsolidity/Types.h | 10 +++++----- 12 files changed, 74 insertions(+), 76 deletions(-) diff --git a/libsolidity/AST.cpp b/libsolidity/AST.cpp index c1a3faa55..8555d8c6d 100644 --- a/libsolidity/AST.cpp +++ b/libsolidity/AST.cpp @@ -394,7 +394,7 @@ ptr FunctionCall::checkTypeRequirements() FunctionType* function = dynamic_cast(expressionType.get()); BOOST_ASSERT(function != nullptr); FunctionDefinition const& fun = function->getFunction(); - vecptr const& parameters = fun.getParameters(); + std::vector> const& parameters = fun.getParameters(); if (parameters.size() != m_arguments.size()) BOOST_THROW_EXCEPTION(TypeError() << errinfo_comment("Wrong argument count for " "function call.")); diff --git a/libsolidity/AST.h b/libsolidity/AST.h index 8da3f529d..661e10a7e 100644 --- a/libsolidity/AST.h +++ b/libsolidity/AST.h @@ -51,7 +51,7 @@ public: virtual void accept(ASTVisitor& _visitor) = 0; template - static void listAccept(vecptr& _list, ASTVisitor& _visitor) + static void listAccept(std::vector>& _list, ASTVisitor& _visitor) { for (ptr& element: _list) element->accept(_visitor); @@ -78,9 +78,9 @@ class ContractDefinition: public Declaration public: ContractDefinition(Location const& _location, ptr const& _name, - vecptr const& _definedStructs, - vecptr const& _stateVariables, - vecptr const& _definedFunctions) + std::vector> const& _definedStructs, + std::vector> const& _stateVariables, + std::vector> const& _definedFunctions) : Declaration(_location, _name), m_definedStructs(_definedStructs), m_stateVariables(_stateVariables), @@ -89,13 +89,13 @@ public: virtual void accept(ASTVisitor& _visitor) override; - vecptr const& getDefinedStructs() { return m_definedStructs; } - vecptr const& getStateVariables() { return m_stateVariables; } - vecptr const& getDefinedFunctions() { return m_definedFunctions; } + std::vector> const& getDefinedStructs() { return m_definedStructs; } + std::vector> const& getStateVariables() { return m_stateVariables; } + std::vector> const& getDefinedFunctions() { return m_definedFunctions; } private: - vecptr m_definedStructs; - vecptr m_stateVariables; - vecptr m_definedFunctions; + std::vector> m_definedStructs; + std::vector> m_stateVariables; + std::vector> m_definedFunctions; }; class StructDefinition: public Declaration @@ -103,12 +103,12 @@ class StructDefinition: public Declaration public: StructDefinition(Location const& _location, ptr const& _name, - vecptr const& _members) + std::vector> const& _members) : Declaration(_location, _name), m_members(_members) {} virtual void accept(ASTVisitor& _visitor) override; private: - vecptr m_members; + std::vector> m_members; }; /// Used as function parameter list and return list @@ -117,13 +117,13 @@ private: class ParameterList: public ASTNode { public: - ParameterList(Location const& _location, vecptr const& _parameters) + ParameterList(Location const& _location, std::vector> const& _parameters) : ASTNode(_location), m_parameters(_parameters) {} virtual void accept(ASTVisitor& _visitor) override; - vecptr const& getParameters() { return m_parameters; } + std::vector> const& getParameters() { return m_parameters; } private: - vecptr m_parameters; + std::vector> m_parameters; }; class FunctionDefinition: public Declaration @@ -141,7 +141,7 @@ public: bool isPublic() const { return m_isPublic; } bool isDeclaredConst() const { return m_isDeclaredConst; } - vecptr const& getParameters() const { return m_parameters->getParameters(); } + std::vector> const& getParameters() const { return m_parameters->getParameters(); } ParameterList& getParameterList() { return *m_parameters; } ptr const& getReturnParameterList() const { return m_returnParameters; } Block& getBody() { return *m_body; } @@ -254,13 +254,13 @@ protected: class Block: public Statement { public: - Block(Location const& _location, vecptr const& _statements) + Block(Location const& _location, std::vector> const& _statements) : Statement(_location), m_statements(_statements) {} virtual void accept(ASTVisitor& _visitor) override; virtual ptr checkTypeRequirements() override; private: - vecptr m_statements; + std::vector> m_statements; }; class IfStatement: public Statement @@ -415,13 +415,13 @@ class FunctionCall: public Expression { public: FunctionCall(Location const& _location, ptr const& _expression, - vecptr const& _arguments) + std::vector> const& _arguments) : Expression(_location), m_expression(_expression), m_arguments(_arguments) {} virtual void accept(ASTVisitor& _visitor) override; virtual ptr checkTypeRequirements() override; private: ptr m_expression; - vecptr m_arguments; + std::vector> m_arguments; }; class MemberAccess: public Expression diff --git a/libsolidity/ASTForward.h b/libsolidity/ASTForward.h index 0397cadda..46fe8393a 100644 --- a/libsolidity/ASTForward.h +++ b/libsolidity/ASTForward.h @@ -70,8 +70,6 @@ class Literal; // explicitly. template using ptr = std::shared_ptr; -template -using vecptr = std::vector>; using ASTString = std::string; diff --git a/libsolidity/ASTPrinter.cpp b/libsolidity/ASTPrinter.cpp index cd8263f2c..1ff0c52e7 100644 --- a/libsolidity/ASTPrinter.cpp +++ b/libsolidity/ASTPrinter.cpp @@ -28,7 +28,7 @@ namespace dev namespace solidity { -ASTPrinter::ASTPrinter(ptr _ast, const std::string& _source) +ASTPrinter::ASTPrinter(ptr _ast, std::string const& _source) : m_indentation(0), m_source(_source), m_ast(_ast) { } @@ -242,7 +242,7 @@ bool ASTPrinter::visit(ElementaryTypeNameExpression& _node) bool ASTPrinter::visit(Literal& _node) { - const char* tokenString = Token::toString(_node.getToken()); + char const* tokenString = Token::toString(_node.getToken()); if (tokenString == nullptr) tokenString = "[no token]"; writeLine(std::string("Literal, token: ") + tokenString + " value: " + _node.getValue()); @@ -415,7 +415,7 @@ std::string ASTPrinter::getIndentation() const return std::string(m_indentation * 2, ' '); } -void ASTPrinter::writeLine(const std::string& _line) +void ASTPrinter::writeLine(std::string const& _line) { *m_ostream << getIndentation() << _line << '\n'; } diff --git a/libsolidity/Parser.cpp b/libsolidity/Parser.cpp index 945cec0f7..4716c55df 100644 --- a/libsolidity/Parser.cpp +++ b/libsolidity/Parser.cpp @@ -43,12 +43,12 @@ ptr Parser::parse(std::shared_ptr const& _scanner) class Parser::ASTNodeFactory { public: - ASTNodeFactory(const Parser& _parser) : m_parser(_parser), m_location(_parser.getPosition(), -1) {} + ASTNodeFactory(Parser const& _parser) : m_parser(_parser), m_location(_parser.getPosition(), -1) {} void markEndPosition() { m_location.end = m_parser.getEndPosition(); } void setLocationEmpty() { m_location.end = m_location.start; } /// Set the end position to the one of the given node. - void setEndPositionFromNode(const ptr& _node) { m_location.end = _node->getLocation().end; } + void setEndPositionFromNode(ptr const& _node) { m_location.end = _node->getLocation().end; } template ptr createNode(Args&& ... _args) @@ -59,7 +59,7 @@ public: } private: - const Parser& m_parser; + Parser const& m_parser; Location m_location; }; @@ -80,9 +80,9 @@ ptr Parser::parseContractDefinition() expectToken(Token::CONTRACT); ptr name = expectIdentifierToken(); expectToken(Token::LBRACE); - vecptr structs; - vecptr stateVariables; - vecptr functions; + std::vector> structs; + std::vector> stateVariables; + std::vector> functions; bool visibilityIsPublic = true; while (true) { @@ -130,7 +130,7 @@ ptr Parser::parseFunctionDefinition(bool _isPublic) ptr returnParameters; if (m_scanner->getCurrentToken() == Token::RETURNS) { - const bool permitEmptyParameterList = false; + bool const permitEmptyParameterList = false; m_scanner->next(); returnParameters = parseParameterList(permitEmptyParameterList); } @@ -139,7 +139,7 @@ ptr Parser::parseFunctionDefinition(bool _isPublic) // create an empty parameter list at a zero-length location ASTNodeFactory nodeFactory(*this); nodeFactory.setLocationEmpty(); - returnParameters = nodeFactory.createNode(vecptr()); + returnParameters = nodeFactory.createNode(std::vector>()); } ptr block = parseBlock(); nodeFactory.setEndPositionFromNode(block); @@ -152,7 +152,7 @@ ptr Parser::parseStructDefinition() ASTNodeFactory nodeFactory(*this); expectToken(Token::STRUCT); ptr name = expectIdentifierToken(); - vecptr members; + std::vector> members; expectToken(Token::LBRACE); while (m_scanner->getCurrentToken() != Token::RBRACE) { @@ -224,7 +224,7 @@ ptr Parser::parseMapping() ptr Parser::parseParameterList(bool _allowEmpty) { ASTNodeFactory nodeFactory(*this); - vecptr parameters; + std::vector> parameters; expectToken(Token::LPAREN); if (!_allowEmpty || m_scanner->getCurrentToken() != Token::RPAREN) { @@ -245,7 +245,7 @@ ptr Parser::parseBlock() { ASTNodeFactory nodeFactory(*this); expectToken(Token::LBRACE); - vecptr statements; + std::vector> statements; while (m_scanner->getCurrentToken() != Token::RBRACE) statements.push_back(parseStatement()); nodeFactory.markEndPosition(); @@ -433,7 +433,7 @@ ptr Parser::parseLeftHandSideExpression() case Token::LPAREN: { m_scanner->next(); - vecptr arguments = parseFunctionCallArguments(); + std::vector> arguments = parseFunctionCallArguments(); nodeFactory.markEndPosition(); expectToken(Token::RPAREN); expression = nodeFactory.createNode(expression, arguments); @@ -490,9 +490,9 @@ ptr Parser::parsePrimaryExpression() return expression; } -vecptr Parser::parseFunctionCallArguments() +std::vector> Parser::parseFunctionCallArguments() { - vecptr arguments; + std::vector> arguments; if (m_scanner->getCurrentToken() != Token::RPAREN) { arguments.push_back(parseExpression()); @@ -535,7 +535,7 @@ ptr Parser::getLiteralAndAdvance() return identifier; } -void Parser::throwExpectationError(const std::string& _description) +void Parser::throwExpectationError(std::string const& _description) { //@todo put some of this stuff into ParserError int line, column; diff --git a/libsolidity/Parser.h b/libsolidity/Parser.h index 174ed7120..2a8613216 100644 --- a/libsolidity/Parser.h +++ b/libsolidity/Parser.h @@ -63,7 +63,7 @@ private: ptr parseUnaryExpression(); ptr parseLeftHandSideExpression(); ptr parsePrimaryExpression(); - vecptr parseFunctionCallArguments(); + std::vector> parseFunctionCallArguments(); /// @} /// Helper functions @@ -73,7 +73,7 @@ private: Token::Value expectAssignmentOperator(); ptr expectIdentifierToken(); ptr getLiteralAndAdvance(); - void throwExpectationError(const std::string& _description); + void throwExpectationError(std::string const& _description); /// @} std::shared_ptr m_scanner; diff --git a/libsolidity/Scanner.cpp b/libsolidity/Scanner.cpp index 236498fd5..b65c0545b 100644 --- a/libsolidity/Scanner.cpp +++ b/libsolidity/Scanner.cpp @@ -88,12 +88,12 @@ int HexValue(char c) } } -Scanner::Scanner(const CharStream& _source) +Scanner::Scanner(CharStream const& _source) { reset(_source); } -void Scanner::reset(const CharStream& _source) +void Scanner::reset(CharStream const& _source) { m_source = _source; m_char = m_source.get(); @@ -145,7 +145,7 @@ Token::Value Scanner::selectToken(char _next, Token::Value _then, Token::Value _ bool Scanner::skipWhitespace() { - const int start_position = getSourcePos(); + int const start_position = getSourcePos(); while (IsWhiteSpace(m_char)) advance(); // Return whether or not we skipped any characters. @@ -425,7 +425,7 @@ bool Scanner::scanEscape() Token::Value Scanner::scanString() { - const char quote = m_char; + char const quote = m_char; advance(); // consume quote LiteralScope literal(this); while (m_char != quote && !isSourcePastEndOfInput() && !IsLineTerminator(m_char)) @@ -592,11 +592,11 @@ Token::Value Scanner::scanNumber(bool _periodSeen) KEYWORD("while", Token::WHILE) \ -static Token::Value KeywordOrIdentifierToken(const std::string& input) +static Token::Value KeywordOrIdentifierToken(std::string const& input) { BOOST_ASSERT(!input.empty()); - const int kMinLength = 2; - const int kMaxLength = 10; + int const kMinLength = 2; + int const kMaxLength = 10; if (input.size() < kMinLength || input.size() > kMaxLength) return Token::IDENTIFIER; switch (input[0]) @@ -609,7 +609,7 @@ case ch: { \ /* 'keyword' is a char array, so sizeof(keyword) is */ \ /* strlen(keyword) plus 1 for the NUL char. */ \ - const int keyword_length = sizeof(keyword) - 1; \ + int const keyword_length = sizeof(keyword) - 1; \ BOOST_STATIC_ASSERT(keyword_length >= kMinLength); \ BOOST_STATIC_ASSERT(keyword_length <= kMaxLength); \ if (input == keyword) { \ diff --git a/libsolidity/Scanner.h b/libsolidity/Scanner.h index f4fec5236..e71fb6347 100644 --- a/libsolidity/Scanner.h +++ b/libsolidity/Scanner.h @@ -64,7 +64,7 @@ class CharStream { public: CharStream() : m_pos(0) {} - explicit CharStream(const std::string& _source): m_source(_source), m_pos(0) {} + explicit CharStream(std::string const& _source): m_source(_source), m_pos(0) {} int getPos() const { return m_pos; } bool isPastEndOfInput() const { return m_pos >= m_source.size(); } char get() const { return m_source[m_pos]; } @@ -100,10 +100,10 @@ public: bool complete_; }; - explicit Scanner(const CharStream& _source); + explicit Scanner(CharStream const& _source); /// Resets the scanner as if newly constructed with _input as input. - void reset(const CharStream& _source); + void reset(CharStream const& _source); /// Returns the next token and advances input. Token::Value next(); diff --git a/libsolidity/Token.cpp b/libsolidity/Token.cpp index 564be734a..093bd9c1d 100644 --- a/libsolidity/Token.cpp +++ b/libsolidity/Token.cpp @@ -48,7 +48,7 @@ namespace solidity { #define T(name, string, precedence) #name, -const char* const Token::m_name[NUM_TOKENS] = +char const* const Token::m_name[NUM_TOKENS] = { TOKEN_LIST(T, T) }; @@ -56,7 +56,7 @@ const char* const Token::m_name[NUM_TOKENS] = #define T(name, string, precedence) string, -const char* const Token::m_string[NUM_TOKENS] = +char const* const Token::m_string[NUM_TOKENS] = { TOKEN_LIST(T, T) }; @@ -64,7 +64,7 @@ const char* const Token::m_string[NUM_TOKENS] = #define T(name, string, precedence) precedence, -const int8_t Token::m_precedence[NUM_TOKENS] = +int8_t const Token::m_precedence[NUM_TOKENS] = { TOKEN_LIST(T, T) }; @@ -73,7 +73,7 @@ const int8_t Token::m_precedence[NUM_TOKENS] = #define KT(a, b, c) 'T', #define KK(a, b, c) 'K', -const char Token::m_tokenType[] = +char const Token::m_tokenType[] = { TOKEN_LIST(KT, KK) }; diff --git a/libsolidity/Token.h b/libsolidity/Token.h index 726c36eb6..2db6e05de 100644 --- a/libsolidity/Token.h +++ b/libsolidity/Token.h @@ -223,7 +223,7 @@ public: // Returns a string corresponding to the C++ token name // (e.g. "LT" for the token LT). - static const char* getName(Value tok) + static char const* getName(Value tok) { BOOST_ASSERT(tok < NUM_TOKENS); // tok is unsigned return m_name[tok]; @@ -309,7 +309,7 @@ public: // Returns a string corresponding to the JS token string // (.e., "<" for the token LT) or NULL if the token doesn't // have a (unique) string (e.g. an IDENTIFIER). - static const char* toString(Value tok) + static char const* toString(Value tok) { BOOST_ASSERT(tok < NUM_TOKENS); // tok is unsigned. return m_string[tok]; @@ -324,10 +324,10 @@ public: } private: - static const char* const m_name[NUM_TOKENS]; - static const char* const m_string[NUM_TOKENS]; - static const int8_t m_precedence[NUM_TOKENS]; - static const char m_tokenType[NUM_TOKENS]; + static char const* const m_name[NUM_TOKENS]; + static char const* const m_string[NUM_TOKENS]; + static int8_t const m_precedence[NUM_TOKENS]; + static char const m_tokenType[NUM_TOKENS]; }; } diff --git a/libsolidity/Types.cpp b/libsolidity/Types.cpp index c5ee40cb8..8ca2c6342 100644 --- a/libsolidity/Types.cpp +++ b/libsolidity/Types.cpp @@ -52,18 +52,18 @@ ptr Type::fromElementaryTypeName(Token::Value _typeToken) BOOST_ASSERT(false); // @todo add other tyes } -ptr Type::fromUserDefinedTypeName(const UserDefinedTypeName& _typeName) +ptr Type::fromUserDefinedTypeName(UserDefinedTypeName const& _typeName) { return std::make_shared(*_typeName.getReferencedStruct()); } -ptr Type::fromMapping(const Mapping&) +ptr Type::fromMapping(Mapping const&) { BOOST_ASSERT(false); //@todo not yet implemented return ptr(); } -ptr Type::forLiteral(const Literal& _literal) +ptr Type::forLiteral(Literal const& _literal) { switch (_literal.getToken()) { @@ -110,7 +110,7 @@ bool IntegerType::isImplicitlyConvertibleTo(Type const& _convertTo) const return !convertTo.isSigned() || convertTo.m_bits > m_bits; } -bool IntegerType::isExplicitlyConvertibleTo(const Type& _convertTo) const +bool IntegerType::isExplicitlyConvertibleTo(Type const& _convertTo) const { return _convertTo.getCategory() == Category::INTEGER; } @@ -130,7 +130,7 @@ bool IntegerType::acceptsUnaryOperator(Token::Value _operator) const return _operator == Token::DELETE || (!isAddress() && _operator == Token::BIT_NOT); } -bool BoolType::isExplicitlyConvertibleTo(const Type& _convertTo) const +bool BoolType::isExplicitlyConvertibleTo(Type const& _convertTo) const { // conversion to integer is fine, but not to address // this is an example of explicit conversions being not transitive (though implicit should be) @@ -143,7 +143,7 @@ bool BoolType::isExplicitlyConvertibleTo(const Type& _convertTo) const return isImplicitlyConvertibleTo(_convertTo); } -bool ContractType::isImplicitlyConvertibleTo(const Type& _convertTo) const +bool ContractType::isImplicitlyConvertibleTo(Type const& _convertTo) const { if (_convertTo.getCategory() != Category::CONTRACT) return false; @@ -151,7 +151,7 @@ bool ContractType::isImplicitlyConvertibleTo(const Type& _convertTo) const return &m_contract == &convertTo.m_contract; } -bool StructType::isImplicitlyConvertibleTo(const Type& _convertTo) const +bool StructType::isImplicitlyConvertibleTo(Type const& _convertTo) const { if (_convertTo.getCategory() != Category::STRUCT) return false; diff --git a/libsolidity/Types.h b/libsolidity/Types.h index d9455a501..9ab710942 100644 --- a/libsolidity/Types.h +++ b/libsolidity/Types.h @@ -64,8 +64,8 @@ public: static ptr forLiteral(Literal const& _literal); virtual Category getCategory() const = 0; - virtual bool isImplicitlyConvertibleTo(const Type&) const { return false; } - virtual bool isExplicitlyConvertibleTo(const Type& _convertTo) const + virtual bool isImplicitlyConvertibleTo(Type const&) const { return false; } + virtual bool isExplicitlyConvertibleTo(Type const& _convertTo) const { return isImplicitlyConvertibleTo(_convertTo); } @@ -87,7 +87,7 @@ public: explicit IntegerType(int _bits, Modifier _modifier = Modifier::UNSIGNED); virtual bool isImplicitlyConvertibleTo(Type const& _convertTo) const override; - virtual bool isExplicitlyConvertibleTo(const Type& _convertTo) const override; + virtual bool isExplicitlyConvertibleTo(Type const& _convertTo) const override; virtual bool acceptsBinaryOperator(Token::Value _operator) const override; virtual bool acceptsUnaryOperator(Token::Value _operator) const override; @@ -104,11 +104,11 @@ class BoolType: public Type { public: virtual Category getCategory() const { return Category::BOOL; } - virtual bool isImplicitlyConvertibleTo(const Type& _convertTo) const override + virtual bool isImplicitlyConvertibleTo(Type const& _convertTo) const override { return _convertTo.getCategory() == Category::BOOL; } - virtual bool isExplicitlyConvertibleTo(const Type& _convertTo) const override; + virtual bool isExplicitlyConvertibleTo(Type const& _convertTo) const override; virtual bool acceptsBinaryOperator(Token::Value _operator) const override { return _operator == Token::AND || _operator == Token::OR;