diff options
author | chriseth <chris@ethereum.org> | 2018-12-06 23:49:52 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-12-06 23:49:52 +0800 |
commit | 4b2a64306a6b85407210245a47a7df1e0a5e0cbf (patch) | |
tree | 9ac2098d84315977e5659987c5398344d52ae813 | |
parent | e1e578d71e22577dc7313214143b81aa24f5ebab (diff) | |
parent | c8e201e520b874439f2525e6cfe02d387654b2c1 (diff) | |
download | dexon-solidity-4b2a64306a6b85407210245a47a7df1e0a5e0cbf.tar dexon-solidity-4b2a64306a6b85407210245a47a7df1e0a5e0cbf.tar.gz dexon-solidity-4b2a64306a6b85407210245a47a7df1e0a5e0cbf.tar.bz2 dexon-solidity-4b2a64306a6b85407210245a47a7df1e0a5e0cbf.tar.lz dexon-solidity-4b2a64306a6b85407210245a47a7df1e0a5e0cbf.tar.xz dexon-solidity-4b2a64306a6b85407210245a47a7df1e0a5e0cbf.tar.zst dexon-solidity-4b2a64306a6b85407210245a47a7df1e0a5e0cbf.zip |
Merge pull request #5587 from ethereum/yulCodeBuiltins
Builtin functions to access Yul objects.
-rw-r--r-- | libsolidity/interface/AssemblyStack.cpp | 2 | ||||
-rw-r--r-- | libyul/CMakeLists.txt | 1 | ||||
-rw-r--r-- | libyul/Dialect.cpp | 76 | ||||
-rw-r--r-- | libyul/Dialect.h | 1 |
4 files changed, 79 insertions, 1 deletions
diff --git a/libsolidity/interface/AssemblyStack.cpp b/libsolidity/interface/AssemblyStack.cpp index 0fe57a45..fbfb3472 100644 --- a/libsolidity/interface/AssemblyStack.cpp +++ b/libsolidity/interface/AssemblyStack.cpp @@ -52,7 +52,7 @@ yul::Dialect languageToDialect(AssemblyStack::Language _language) case AssemblyStack::Language::Assembly: return yul::Dialect::looseAssemblyForEVM(); case AssemblyStack::Language::StrictAssembly: - return yul::Dialect::strictAssemblyForEVM(); + return yul::Dialect::strictAssemblyForEVMObjects(); case AssemblyStack::Language::Yul: return yul::Dialect::yul(); } diff --git a/libyul/CMakeLists.txt b/libyul/CMakeLists.txt index 4be8155f..4bc8200c 100644 --- a/libyul/CMakeLists.txt +++ b/libyul/CMakeLists.txt @@ -5,6 +5,7 @@ add_library(yul AsmPrinter.cpp AsmScope.cpp AsmScopeFiller.cpp + Dialect.cpp Object.cpp ObjectParser.cpp backends/evm/EVMAssembly.cpp diff --git a/libyul/Dialect.cpp b/libyul/Dialect.cpp new file mode 100644 index 00000000..99718787 --- /dev/null +++ b/libyul/Dialect.cpp @@ -0,0 +1,76 @@ +/* + This file is part of solidity. + + solidity is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + solidity is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with solidity. If not, see <http://www.gnu.org/licenses/>. +*/ +/** + * Yul dialect. + */ + +#include <libyul/Dialect.h> + +#include <map> + +using namespace yul; +using namespace std; + +namespace +{ + +void addFunction( + map<YulString, BuiltinFunction>& _repository, + string const& _name, + size_t _params, + size_t _returns, + bool _movable +) +{ + _repository[YulString{_name}] = BuiltinFunction{ + YulString{_name}, + vector<Type>(_params), + vector<Type>(_returns), + _movable + }; +} + +class GenericBuiltins: public Builtins +{ +public: + GenericBuiltins(map<YulString, BuiltinFunction> const& _functions): m_functions(_functions) {} + BuiltinFunction const* query(YulString _name) const + { + auto it = m_functions.find(_name); + if (it != end(m_functions)) + return &it->second; + else + return nullptr; + } +private: + map<YulString, BuiltinFunction> const& m_functions; +}; + +} + +Dialect Dialect::strictAssemblyForEVMObjects() +{ + static map<YulString, BuiltinFunction> functions; + if (functions.empty()) + { + addFunction(functions, "datasize", 1, 1, true); + addFunction(functions, "dataoffset", 1, 1, true); + addFunction(functions, "datacopy", 3, 0, false); + } + // The EVM instructions will be moved to builtins at some point. + return Dialect{AsmFlavour::Strict, std::make_shared<GenericBuiltins>(functions)}; +} diff --git a/libyul/Dialect.h b/libyul/Dialect.h index 3ea16014..b78f1aaf 100644 --- a/libyul/Dialect.h +++ b/libyul/Dialect.h @@ -72,6 +72,7 @@ struct Dialect // The EVM instructions will be moved to builtins at some point. return Dialect{AsmFlavour::Strict, std::make_shared<Builtins>()}; } + static Dialect strictAssemblyForEVMObjects(); static Dialect yul() { // Will have to add builtins later. |