mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Mark a lot of functions const (where possible)
This commit is contained in:
parent
c94b1f8173
commit
e2cfc9ee92
@ -124,7 +124,7 @@ void ConstantOptimisationMethod::replaceConstants(
|
||||
_items = std::move(replaced);
|
||||
}
|
||||
|
||||
bigint LiteralMethod::gasNeeded()
|
||||
bigint LiteralMethod::gasNeeded() const
|
||||
{
|
||||
return combineGas(
|
||||
simpleRunGas({Instruction::PUSH1}),
|
||||
@ -139,7 +139,7 @@ CodeCopyMethod::CodeCopyMethod(Params const& _params, u256 const& _value):
|
||||
{
|
||||
}
|
||||
|
||||
bigint CodeCopyMethod::gasNeeded()
|
||||
bigint CodeCopyMethod::gasNeeded() const
|
||||
{
|
||||
return combineGas(
|
||||
// Run gas: we ignore memory increase costs
|
||||
@ -151,7 +151,7 @@ bigint CodeCopyMethod::gasNeeded()
|
||||
);
|
||||
}
|
||||
|
||||
AssemblyItems CodeCopyMethod::execute(Assembly& _assembly)
|
||||
AssemblyItems CodeCopyMethod::execute(Assembly& _assembly) const
|
||||
{
|
||||
bytes data = toBigEndian(m_value);
|
||||
AssemblyItems actualCopyRoutine = copyRoutine();
|
||||
@ -234,7 +234,7 @@ AssemblyItems ComputeMethod::findRepresentation(u256 const& _value)
|
||||
}
|
||||
}
|
||||
|
||||
bool ComputeMethod::checkRepresentation(u256 const& _value, AssemblyItems const& _routine)
|
||||
bool ComputeMethod::checkRepresentation(u256 const& _value, AssemblyItems const& _routine) const
|
||||
{
|
||||
// This is a tiny EVM that can only evaluate some instructions.
|
||||
vector<u256> stack;
|
||||
@ -282,7 +282,7 @@ bool ComputeMethod::checkRepresentation(u256 const& _value, AssemblyItems const&
|
||||
return stack.size() == 1 && stack.front() == _value;
|
||||
}
|
||||
|
||||
bigint ComputeMethod::gasNeeded(AssemblyItems const& _routine)
|
||||
bigint ComputeMethod::gasNeeded(AssemblyItems const& _routine) const
|
||||
{
|
||||
size_t numExps = count(_routine.begin(), _routine.end(), Instruction::EXP);
|
||||
return combineGas(
|
||||
|
@ -63,11 +63,11 @@ public:
|
||||
|
||||
explicit ConstantOptimisationMethod(Params const& _params, u256 const& _value):
|
||||
m_params(_params), m_value(_value) {}
|
||||
virtual bigint gasNeeded() = 0;
|
||||
virtual bigint gasNeeded() const = 0;
|
||||
/// Executes the method, potentially appending to the assembly and returns a vector of
|
||||
/// assembly items the constant should be relpaced with in one sweep.
|
||||
/// If the vector is empty, the constants will not be deleted.
|
||||
virtual AssemblyItems execute(Assembly& _assembly) = 0;
|
||||
virtual AssemblyItems execute(Assembly& _assembly) const = 0;
|
||||
|
||||
protected:
|
||||
size_t dataSize() const { return std::max<size_t>(1, dev::bytesRequired(m_value)); }
|
||||
@ -84,7 +84,7 @@ protected:
|
||||
bigint const& _runGas,
|
||||
bigint const& _repeatedDataGas,
|
||||
bigint const& _uniqueDataGas
|
||||
)
|
||||
) const
|
||||
{
|
||||
// _runGas is not multiplied by _multiplicity because the runs are "per opcode"
|
||||
return m_params.runs * _runGas + m_params.multiplicity * _repeatedDataGas + _uniqueDataGas;
|
||||
@ -106,8 +106,8 @@ class LiteralMethod: public ConstantOptimisationMethod
|
||||
public:
|
||||
explicit LiteralMethod(Params const& _params, u256 const& _value):
|
||||
ConstantOptimisationMethod(_params, _value) {}
|
||||
virtual bigint gasNeeded() override;
|
||||
virtual AssemblyItems execute(Assembly&) override { return AssemblyItems{}; }
|
||||
virtual bigint gasNeeded() const override;
|
||||
virtual AssemblyItems execute(Assembly&) const override { return AssemblyItems{}; }
|
||||
};
|
||||
|
||||
/**
|
||||
@ -117,8 +117,8 @@ class CodeCopyMethod: public ConstantOptimisationMethod
|
||||
{
|
||||
public:
|
||||
explicit CodeCopyMethod(Params const& _params, u256 const& _value);
|
||||
virtual bigint gasNeeded() override;
|
||||
virtual AssemblyItems execute(Assembly& _assembly) override;
|
||||
virtual bigint gasNeeded() const override;
|
||||
virtual AssemblyItems execute(Assembly& _assembly) const override;
|
||||
|
||||
protected:
|
||||
AssemblyItems const& copyRoutine() const;
|
||||
@ -141,8 +141,8 @@ public:
|
||||
);
|
||||
}
|
||||
|
||||
virtual bigint gasNeeded() override { return gasNeeded(m_routine); }
|
||||
virtual AssemblyItems execute(Assembly&) override
|
||||
virtual bigint gasNeeded() const override { return gasNeeded(m_routine); }
|
||||
virtual AssemblyItems execute(Assembly&) const override
|
||||
{
|
||||
return m_routine;
|
||||
}
|
||||
@ -151,8 +151,8 @@ protected:
|
||||
/// Tries to recursively find a way to compute @a _value.
|
||||
AssemblyItems findRepresentation(u256 const& _value);
|
||||
/// Recomputes the value from the calculated representation and checks for correctness.
|
||||
bool checkRepresentation(u256 const& _value, AssemblyItems const& _routine);
|
||||
bigint gasNeeded(AssemblyItems const& _routine);
|
||||
bool checkRepresentation(u256 const& _value, AssemblyItems const& _routine) const;
|
||||
bigint gasNeeded(AssemblyItems const& _routine) const;
|
||||
|
||||
/// Counter for the complexity of optimization, will stop when it reaches zero.
|
||||
size_t m_maxSteps = 10000;
|
||||
|
@ -30,7 +30,7 @@ CompilerState::CompilerState()
|
||||
{
|
||||
}
|
||||
|
||||
CodeFragment const& CompilerState::getDef(std::string const& _s)
|
||||
CodeFragment const& CompilerState::getDef(std::string const& _s) const
|
||||
{
|
||||
if (defs.count(_s))
|
||||
return defs.at(_s);
|
||||
|
@ -40,7 +40,7 @@ struct CompilerState
|
||||
{
|
||||
CompilerState();
|
||||
|
||||
CodeFragment const& getDef(std::string const& _s);
|
||||
CodeFragment const& getDef(std::string const& _s) const;
|
||||
void populateStandard();
|
||||
|
||||
unsigned stackSize = 128;
|
||||
|
@ -119,7 +119,7 @@ private:
|
||||
);
|
||||
std::string sourceLocationToString(SourceLocation const& _location) const;
|
||||
std::string namePathToString(std::vector<ASTString> const& _namePath) const;
|
||||
Json::Value idOrNull(ASTNode const* _pt)
|
||||
Json::Value idOrNull(ASTNode const* _pt) const
|
||||
{
|
||||
return _pt ? Json::Value(nodeId(*_pt)) : Json::nullValue;
|
||||
}
|
||||
@ -134,12 +134,12 @@ private:
|
||||
std::string literalTokenKind(Token::Value _token);
|
||||
std::string type(Expression const& _expression);
|
||||
std::string type(VariableDeclaration const& _varDecl);
|
||||
int nodeId(ASTNode const& _node)
|
||||
int nodeId(ASTNode const& _node) const
|
||||
{
|
||||
return _node.id();
|
||||
}
|
||||
template<class Container>
|
||||
Json::Value getContainerIds(Container const& container)
|
||||
Json::Value getContainerIds(Container const& container) const
|
||||
{
|
||||
Json::Value tmp(Json::arrayValue);
|
||||
for (auto const& element: container)
|
||||
|
@ -1056,7 +1056,7 @@ string ABIFunctions::createFunction(string const& _name, function<string ()> con
|
||||
return _name;
|
||||
}
|
||||
|
||||
size_t ABIFunctions::headSize(TypePointers const& _targetTypes)
|
||||
size_t ABIFunctions::headSize(TypePointers const& _targetTypes) const
|
||||
{
|
||||
size_t headSize = 0;
|
||||
for (auto const& t: _targetTypes)
|
||||
|
@ -162,7 +162,7 @@ private:
|
||||
std::string createFunction(std::string const& _name, std::function<std::string()> const& _creator);
|
||||
|
||||
/// @returns the size of the static part of the encoding of the given types.
|
||||
size_t headSize(TypePointers const& _targetTypes);
|
||||
size_t headSize(TypePointers const& _targetTypes) const;
|
||||
|
||||
/// Map from function name to code for a multi-use function.
|
||||
std::map<std::string, std::string> m_requestedFunctions;
|
||||
|
@ -51,9 +51,9 @@ public:
|
||||
ContractDefinition const& _contract,
|
||||
std::map<ContractDefinition const*, eth::Assembly const*> const& _contracts
|
||||
);
|
||||
eth::Assembly const& assembly() { return m_context.assembly(); }
|
||||
eth::LinkerObject assembledObject() { return m_context.assembledObject(); }
|
||||
eth::LinkerObject runtimeObject() { return m_context.assembledRuntimeObject(m_runtimeSub); }
|
||||
eth::Assembly const& assembly() const { return m_context.assembly(); }
|
||||
eth::LinkerObject assembledObject() const { return m_context.assembledObject(); }
|
||||
eth::LinkerObject runtimeObject() const { return m_context.assembledRuntimeObject(m_runtimeSub); }
|
||||
/// @arg _sourceCodes is the map of input files to source code strings
|
||||
/// @arg _inJsonFromat shows whether the out should be in Json format
|
||||
Json::Value streamAssembly(std::ostream& _stream, StringMap const& _sourceCodes = StringMap(), bool _inJsonFormat = false) const
|
||||
|
@ -208,8 +208,8 @@ public:
|
||||
return m_asm->stream(_stream, "", _sourceCodes, _inJsonFormat);
|
||||
}
|
||||
|
||||
eth::LinkerObject const& assembledObject() { return m_asm->assemble(); }
|
||||
eth::LinkerObject const& assembledRuntimeObject(size_t _subIndex) { return m_asm->sub(_subIndex).assemble(); }
|
||||
eth::LinkerObject const& assembledObject() const { return m_asm->assemble(); }
|
||||
eth::LinkerObject const& assembledRuntimeObject(size_t _subIndex) const { return m_asm->sub(_subIndex).assemble(); }
|
||||
|
||||
/**
|
||||
* Helper class to pop the visited nodes stack when a scope closes
|
||||
|
@ -1811,7 +1811,7 @@ void ExpressionCompiler::setLValueToStorageItem(Expression const& _expression)
|
||||
setLValue<StorageItem>(_expression, *_expression.annotation().type);
|
||||
}
|
||||
|
||||
bool ExpressionCompiler::cleanupNeededForOp(Type::Category _type, Token::Value _op)
|
||||
bool ExpressionCompiler::cleanupNeededForOp(Type::Category _type, Token::Value _op) const
|
||||
{
|
||||
if (Token::isCompareOp(_op) || Token::isShiftOp(_op))
|
||||
return true;
|
||||
|
@ -119,7 +119,7 @@ private:
|
||||
|
||||
/// @returns true if the operator applied to the given type requires a cleanup prior to the
|
||||
/// operation.
|
||||
bool cleanupNeededForOp(Type::Category _type, Token::Value _op);
|
||||
bool cleanupNeededForOp(Type::Category _type, Token::Value _op) const;
|
||||
|
||||
/// @returns the CompilerUtils object containing the current context.
|
||||
CompilerUtils utils();
|
||||
|
@ -45,7 +45,7 @@ public:
|
||||
|
||||
protected:
|
||||
/// Creates an inline assembly node with the given source location.
|
||||
template <class T> T createWithLocation(SourceLocation const& _loc = SourceLocation())
|
||||
template <class T> T createWithLocation(SourceLocation const& _loc = SourceLocation()) const
|
||||
{
|
||||
T r;
|
||||
r.location = _loc;
|
||||
|
@ -209,7 +209,7 @@ string AsmPrinter::operator()(Block const& _block)
|
||||
return "{\n " + body + "\n}";
|
||||
}
|
||||
|
||||
string AsmPrinter::appendTypeName(std::string const& _type)
|
||||
string AsmPrinter::appendTypeName(std::string const& _type) const
|
||||
{
|
||||
if (m_julia)
|
||||
return ":" + _type;
|
||||
|
@ -53,7 +53,7 @@ public:
|
||||
std::string operator()(assembly::Block const& _block);
|
||||
|
||||
private:
|
||||
std::string appendTypeName(std::string const& _type);
|
||||
std::string appendTypeName(std::string const& _type) const;
|
||||
|
||||
bool m_julia = false;
|
||||
};
|
||||
|
@ -70,7 +70,7 @@ Scope::Identifier* Scope::lookup(string const& _name)
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
bool Scope::exists(string const& _name)
|
||||
bool Scope::exists(string const& _name) const
|
||||
{
|
||||
if (identifiers.count(_name))
|
||||
return true;
|
||||
|
@ -107,7 +107,7 @@ struct Scope
|
||||
}
|
||||
/// @returns true if the name exists in this scope or in super scopes (also searches
|
||||
/// across function and assembly boundaries).
|
||||
bool exists(std::string const& _name);
|
||||
bool exists(std::string const& _name) const;
|
||||
|
||||
/// @returns the number of variables directly registered inside the scope.
|
||||
size_t numberOfVariables() const;
|
||||
|
@ -88,7 +88,7 @@ public:
|
||||
m_errorReporter(m_errorList) {}
|
||||
|
||||
/// @returns the list of errors that occured during parsing and type checking.
|
||||
ErrorList const& errors() { return m_errorReporter.errors(); }
|
||||
ErrorList const& errors() const { return m_errorReporter.errors(); }
|
||||
|
||||
/// @returns the current state.
|
||||
State state() const { return m_stackState; }
|
||||
|
@ -118,11 +118,11 @@ public:
|
||||
///@name Information about the current token
|
||||
|
||||
/// @returns the current token
|
||||
Token::Value currentToken()
|
||||
Token::Value currentToken() const
|
||||
{
|
||||
return m_currentToken.token;
|
||||
}
|
||||
ElementaryTypeNameToken currentElementaryTypeNameToken()
|
||||
ElementaryTypeNameToken currentElementaryTypeNameToken() const
|
||||
{
|
||||
unsigned firstSize;
|
||||
unsigned secondSize;
|
||||
@ -219,8 +219,8 @@ private:
|
||||
bool scanEscape();
|
||||
|
||||
/// Return the current source position.
|
||||
int sourcePos() { return m_source.position(); }
|
||||
bool isSourcePastEndOfInput() { return m_source.isPastEndOfInput(); }
|
||||
int sourcePos() const { return m_source.position(); }
|
||||
bool isSourcePastEndOfInput() const { return m_source.isPastEndOfInput(); }
|
||||
|
||||
TokenDesc m_skippedComment; // desc for current skipped comment
|
||||
TokenDesc m_nextSkippedComment; // desc for next skiped comment
|
||||
|
Loading…
Reference in New Issue
Block a user