aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2016-01-26 23:25:36 +0800
committerchriseth <c@ethdev.com>2016-01-27 06:25:07 +0800
commitebc1dce073162590fc384e2e851338be89e62cad (patch)
treec9ca803b75ec67d7f775e97dea3c40f56e8afdb7
parent9b9d10b4a824e794a0775021ed6c7349e41cada3 (diff)
downloaddexon-solidity-ebc1dce073162590fc384e2e851338be89e62cad.tar
dexon-solidity-ebc1dce073162590fc384e2e851338be89e62cad.tar.gz
dexon-solidity-ebc1dce073162590fc384e2e851338be89e62cad.tar.bz2
dexon-solidity-ebc1dce073162590fc384e2e851338be89e62cad.tar.lz
dexon-solidity-ebc1dce073162590fc384e2e851338be89e62cad.tar.xz
dexon-solidity-ebc1dce073162590fc384e2e851338be89e62cad.tar.zst
dexon-solidity-ebc1dce073162590fc384e2e851338be89e62cad.zip
Read files via callback.
-rw-r--r--solc/CMakeLists.txt2
-rw-r--r--solc/jsonCompiler.cpp46
2 files changed, 42 insertions, 6 deletions
diff --git a/solc/CMakeLists.txt b/solc/CMakeLists.txt
index 4c26b416..9a914af8 100644
--- a/solc/CMakeLists.txt
+++ b/solc/CMakeLists.txt
@@ -18,7 +18,7 @@ else()
endif()
if (EMSCRIPTEN)
- set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -s EXPORTED_FUNCTIONS='[\"_compileJSON\",\"_version\",\"_compileJSONMulti\"]'")
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -s EXPORTED_FUNCTIONS='[\"_compileJSON\",\"_version\",\"_compileJSONMulti\",\"_compileJSONCallback\"]' -s RESERVED_FUNCTION_POINTERS=20")
add_executable(soljson jsonCompiler.cpp ${HEADERS})
eth_use(soljson REQUIRED Solidity::solidity)
else()
diff --git a/solc/jsonCompiler.cpp b/solc/jsonCompiler.cpp
index a5d86aad..987f8dff 100644
--- a/solc/jsonCompiler.cpp
+++ b/solc/jsonCompiler.cpp
@@ -41,6 +41,12 @@ using namespace std;
using namespace dev;
using namespace solidity;
+extern "C" {
+/// Callback used to retrieve additional source files. "Returns" two pointers that should be
+/// heap-allocated and are free'd by the caller.
+typedef void (*CStyleReadFileCallback)(char const* _path, char** o_contents, char** o_error);
+}
+
string formatError(Exception const& _exception, string const& _name, CompilerStack const& _compiler)
{
ostringstream errorOutput;
@@ -114,11 +120,36 @@ Json::Value estimateGas(CompilerStack const& _compiler, string const& _contract)
return gasEstimates;
}
-string compile(StringMap const& _sources, bool _optimize)
+string compile(StringMap const& _sources, bool _optimize, CStyleReadFileCallback _readCallback)
{
Json::Value output(Json::objectValue);
Json::Value errors(Json::arrayValue);
- CompilerStack compiler;
+ CompilerStack::ReadFileCallback readCallback;
+ if (_readCallback)
+ {
+ readCallback = [=](string const& _path) -> pair<string, string>
+ {
+ char* contents_c = nullptr;
+ char* error_c = nullptr;
+ _readCallback(_path.c_str(), &contents_c, &error_c);
+ string contents;
+ string error;
+ if (!contents_c && !error_c)
+ error = "File not found.";
+ if (contents_c)
+ {
+ contents = string(contents_c);
+ free(contents_c);
+ }
+ if (error_c)
+ {
+ error = string(error_c);
+ free(error_c);
+ }
+ return make_pair(move(contents), move(error));
+ };
+ }
+ CompilerStack compiler(true, readCallback);
bool success = false;
try
{
@@ -188,7 +219,7 @@ string compile(StringMap const& _sources, bool _optimize)
return Json::FastWriter().write(output);
}
-string compileMulti(string const& _input, bool _optimize)
+string compileMulti(string const& _input, bool _optimize, CStyleReadFileCallback _readCallback = nullptr)
{
Json::Reader reader;
Json::Value input;
@@ -207,7 +238,7 @@ string compileMulti(string const& _input, bool _optimize)
if (jsonSources.isObject())
for (auto const& sourceName: jsonSources.getMemberNames())
sources[sourceName] = jsonSources[sourceName].asString();
- return compile(sources, _optimize);
+ return compile(sources, _optimize, _readCallback);
}
}
@@ -215,7 +246,7 @@ string compileSingle(string const& _input, bool _optimize)
{
StringMap sources;
sources[""] = _input;
- return compile(sources, _optimize);
+ return compile(sources, _optimize, nullptr);
}
static string s_outputBuffer;
@@ -236,4 +267,9 @@ extern char const* compileJSONMulti(char const* _input, bool _optimize)
s_outputBuffer = compileMulti(_input, _optimize);
return s_outputBuffer.c_str();
}
+extern char const* compileJSONCallback(char const* _input, bool _optimize, CStyleReadFileCallback _readCallback)
+{
+ s_outputBuffer = compileMulti(_input, _optimize, _readCallback);
+ return s_outputBuffer.c_str();
+}
}