aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-12-06 23:49:52 +0800
committerGitHub <noreply@github.com>2018-12-06 23:49:52 +0800
commit4b2a64306a6b85407210245a47a7df1e0a5e0cbf (patch)
tree9ac2098d84315977e5659987c5398344d52ae813
parente1e578d71e22577dc7313214143b81aa24f5ebab (diff)
parentc8e201e520b874439f2525e6cfe02d387654b2c1 (diff)
downloaddexon-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.cpp2
-rw-r--r--libyul/CMakeLists.txt1
-rw-r--r--libyul/Dialect.cpp76
-rw-r--r--libyul/Dialect.h1
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.