Merge pull request #89 from chriseth/fixCombinedJson

Fix "combined json" output.
This commit is contained in:
chriseth 2015-09-23 15:55:14 +02:00
commit 09f1f1e595

View File

@ -74,6 +74,7 @@ static string const g_stdinFileName = "<stdin>";
/// Possible arguments to for --combined-json /// Possible arguments to for --combined-json
static set<string> const g_combinedJsonArgs{ static set<string> const g_combinedJsonArgs{
"bin", "bin",
"bin-runtime",
"clone-bin", "clone-bin",
"opcodes", "opcodes",
"abi", "abi",
@ -144,7 +145,7 @@ void CommandLineInterface::handleBinary(string const& _contract)
if (m_args.count(g_argRuntimeBinaryStr)) if (m_args.count(g_argRuntimeBinaryStr))
{ {
if (m_args.count("output-dir")) if (m_args.count("output-dir"))
createFile(_contract + ".bin", m_compiler->runtimeObject(_contract).toHex()); createFile(_contract + ".bin-runtime", m_compiler->runtimeObject(_contract).toHex());
else else
{ {
cout << "Binary of the runtime part: " << endl; cout << "Binary of the runtime part: " << endl;
@ -550,6 +551,7 @@ void CommandLineInterface::handleCombinedJSON()
Json::Value output(Json::objectValue); Json::Value output(Json::objectValue);
output["version"] = ::dev::solidity::VersionString;
set<string> requests; set<string> requests;
boost::split(requests, m_args["combined-json"].as<string>(), boost::is_any_of(",")); boost::split(requests, m_args["combined-json"].as<string>(), boost::is_any_of(","));
vector<string> contracts = m_compiler->contractNames(); vector<string> contracts = m_compiler->contractNames();
@ -564,7 +566,9 @@ void CommandLineInterface::handleCombinedJSON()
if (requests.count("abi")) if (requests.count("abi"))
contractData["abi"] = m_compiler->interface(contractName); contractData["abi"] = m_compiler->interface(contractName);
if (requests.count("bin")) if (requests.count("bin"))
contractData["bin"] = m_compiler->runtimeObject(contractName).toHex(); contractData["bin"] = m_compiler->object(contractName).toHex();
if (requests.count("bin-runtime"))
contractData["bin-runtime"] = m_compiler->runtimeObject(contractName).toHex();
if (requests.count("clone-bin")) if (requests.count("clone-bin"))
contractData["clone-bin"] = m_compiler->cloneObject(contractName).toHex(); contractData["clone-bin"] = m_compiler->cloneObject(contractName).toHex();
if (requests.count("opcodes")) if (requests.count("opcodes"))