mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Solidity FunctionDefinition used ASTString shared ptr for docstrings
This commit is contained in:
parent
034870b4c0
commit
e3e90c4e6b
15
AST.h
15
AST.h
@ -173,8 +173,9 @@ private:
|
|||||||
class FunctionDefinition: public Declaration
|
class FunctionDefinition: public Declaration
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
FunctionDefinition(Location const& _location, ASTPointer<ASTString> const& _name, bool _isPublic,
|
FunctionDefinition(Location const& _location, ASTPointer<ASTString> const& _name,
|
||||||
std::string const& _documentation,
|
bool _isPublic,
|
||||||
|
ASTPointer<ASTString> const& _documentation,
|
||||||
ASTPointer<ParameterList> const& _parameters,
|
ASTPointer<ParameterList> const& _parameters,
|
||||||
bool _isDeclaredConst,
|
bool _isDeclaredConst,
|
||||||
ASTPointer<ParameterList> const& _returnParameters,
|
ASTPointer<ParameterList> const& _returnParameters,
|
||||||
@ -184,7 +185,9 @@ public:
|
|||||||
m_isDeclaredConst(_isDeclaredConst),
|
m_isDeclaredConst(_isDeclaredConst),
|
||||||
m_returnParameters(_returnParameters),
|
m_returnParameters(_returnParameters),
|
||||||
m_body(_body),
|
m_body(_body),
|
||||||
m_documentation(_documentation) {}
|
m_documentation(_documentation)
|
||||||
|
{}
|
||||||
|
|
||||||
virtual void accept(ASTVisitor& _visitor) override;
|
virtual void accept(ASTVisitor& _visitor) override;
|
||||||
|
|
||||||
bool isPublic() const { return m_isPublic; }
|
bool isPublic() const { return m_isPublic; }
|
||||||
@ -194,7 +197,9 @@ public:
|
|||||||
std::vector<ASTPointer<VariableDeclaration>> const& getReturnParameters() const { return m_returnParameters->getParameters(); }
|
std::vector<ASTPointer<VariableDeclaration>> const& getReturnParameters() const { return m_returnParameters->getParameters(); }
|
||||||
ASTPointer<ParameterList> const& getReturnParameterList() const { return m_returnParameters; }
|
ASTPointer<ParameterList> const& getReturnParameterList() const { return m_returnParameters; }
|
||||||
Block& getBody() { return *m_body; }
|
Block& getBody() { return *m_body; }
|
||||||
std::string& getDocumentation() { return m_documentation; }
|
/// @return A shared pointer of an ASTString.
|
||||||
|
/// Can contain a nullptr in which case indicates absence of documentation
|
||||||
|
ASTPointer<ASTString> const& getDocumentation() { return m_documentation; }
|
||||||
|
|
||||||
void addLocalVariable(VariableDeclaration const& _localVariable) { m_localVariables.push_back(&_localVariable); }
|
void addLocalVariable(VariableDeclaration const& _localVariable) { m_localVariables.push_back(&_localVariable); }
|
||||||
std::vector<VariableDeclaration const*> const& getLocalVariables() const { return m_localVariables; }
|
std::vector<VariableDeclaration const*> const& getLocalVariables() const { return m_localVariables; }
|
||||||
@ -208,7 +213,7 @@ private:
|
|||||||
bool m_isDeclaredConst;
|
bool m_isDeclaredConst;
|
||||||
ASTPointer<ParameterList> m_returnParameters;
|
ASTPointer<ParameterList> m_returnParameters;
|
||||||
ASTPointer<Block> m_body;
|
ASTPointer<Block> m_body;
|
||||||
std::string m_documentation;
|
ASTPointer<ASTString> m_documentation;
|
||||||
|
|
||||||
std::vector<VariableDeclaration const*> m_localVariables;
|
std::vector<VariableDeclaration const*> m_localVariables;
|
||||||
};
|
};
|
||||||
|
@ -117,9 +117,13 @@ ASTPointer<ContractDefinition> Parser::parseContractDefinition()
|
|||||||
ASTPointer<FunctionDefinition> Parser::parseFunctionDefinition(bool _isPublic)
|
ASTPointer<FunctionDefinition> Parser::parseFunctionDefinition(bool _isPublic)
|
||||||
{
|
{
|
||||||
ASTNodeFactory nodeFactory(*this);
|
ASTNodeFactory nodeFactory(*this);
|
||||||
|
ASTPointer<ASTString> docstring;
|
||||||
expectToken(Token::FUNCTION);
|
expectToken(Token::FUNCTION);
|
||||||
std::string docstring = m_scanner->getCurrentCommentLiteral();
|
if (m_scanner->getCurrentCommentLiteral() != "")
|
||||||
|
{
|
||||||
|
docstring = std::make_shared<ASTString>(m_scanner->getCurrentCommentLiteral());
|
||||||
m_scanner->clearCurrentCommentLiteral();
|
m_scanner->clearCurrentCommentLiteral();
|
||||||
|
}
|
||||||
ASTPointer<ASTString> name(expectIdentifierToken());
|
ASTPointer<ASTString> name(expectIdentifierToken());
|
||||||
ASTPointer<ParameterList> parameters(parseParameterList());
|
ASTPointer<ParameterList> parameters(parseParameterList());
|
||||||
bool isDeclaredConst = false;
|
bool isDeclaredConst = false;
|
||||||
|
Loading…
Reference in New Issue
Block a user