mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Limit output according to the selected targets in StandardCompiler
This commit is contained in:
parent
d37e6ba1c7
commit
8da245cca3
@ -4,6 +4,7 @@ Features:
|
|||||||
* Allow constant variables to be used as array length
|
* Allow constant variables to be used as array length
|
||||||
* Code Generator: New ABI decoder which supports structs and arbitrarily nested
|
* Code Generator: New ABI decoder which supports structs and arbitrarily nested
|
||||||
arrays and checks input size (activate using ``pragma experimental ABIEncoderV2;``.
|
arrays and checks input size (activate using ``pragma experimental ABIEncoderV2;``.
|
||||||
|
* Standard JSON: Support the ``outputSelection`` field for selective compilation of target artifacts.
|
||||||
* Syntax Checker: Turn the usage of ``callcode`` into an error as experimental 0.5.0 feature.
|
* Syntax Checker: Turn the usage of ``callcode`` into an error as experimental 0.5.0 feature.
|
||||||
* Type Checker: Improve address checksum warning.
|
* Type Checker: Improve address checksum warning.
|
||||||
* Type Checker: More detailed errors for invalid array lengths (such as division by zero).
|
* Type Checker: More detailed errors for invalid array lengths (such as division by zero).
|
||||||
|
@ -452,7 +452,9 @@ Json::Value StandardCompiler::compileInternal(Json::Value const& _input)
|
|||||||
{
|
{
|
||||||
Json::Value sourceResult = Json::objectValue;
|
Json::Value sourceResult = Json::objectValue;
|
||||||
sourceResult["id"] = sourceIndex++;
|
sourceResult["id"] = sourceIndex++;
|
||||||
|
if (isTargetRequired(outputSelection, sourceName, "", "ast"))
|
||||||
sourceResult["ast"] = ASTJsonConverter(false, m_compilerStack.sourceIndices()).toJson(m_compilerStack.ast(sourceName));
|
sourceResult["ast"] = ASTJsonConverter(false, m_compilerStack.sourceIndices()).toJson(m_compilerStack.ast(sourceName));
|
||||||
|
if (isTargetRequired(outputSelection, sourceName, "", "legacyAST"))
|
||||||
sourceResult["legacyAST"] = ASTJsonConverter(true, m_compilerStack.sourceIndices()).toJson(m_compilerStack.ast(sourceName));
|
sourceResult["legacyAST"] = ASTJsonConverter(true, m_compilerStack.sourceIndices()).toJson(m_compilerStack.ast(sourceName));
|
||||||
output["sources"][sourceName] = sourceResult;
|
output["sources"][sourceName] = sourceResult;
|
||||||
}
|
}
|
||||||
@ -467,24 +469,34 @@ Json::Value StandardCompiler::compileInternal(Json::Value const& _input)
|
|||||||
|
|
||||||
// ABI, documentation and metadata
|
// ABI, documentation and metadata
|
||||||
Json::Value contractData(Json::objectValue);
|
Json::Value contractData(Json::objectValue);
|
||||||
|
if (isTargetRequired(outputSelection, file, name, "abi"))
|
||||||
contractData["abi"] = m_compilerStack.contractABI(contractName);
|
contractData["abi"] = m_compilerStack.contractABI(contractName);
|
||||||
|
if (isTargetRequired(outputSelection, file, name, "metadata"))
|
||||||
contractData["metadata"] = m_compilerStack.metadata(contractName);
|
contractData["metadata"] = m_compilerStack.metadata(contractName);
|
||||||
|
if (isTargetRequired(outputSelection, file, name, "userdoc"))
|
||||||
contractData["userdoc"] = m_compilerStack.natspecUser(contractName);
|
contractData["userdoc"] = m_compilerStack.natspecUser(contractName);
|
||||||
|
if (isTargetRequired(outputSelection, file, name, "devdoc"))
|
||||||
contractData["devdoc"] = m_compilerStack.natspecDev(contractName);
|
contractData["devdoc"] = m_compilerStack.natspecDev(contractName);
|
||||||
|
|
||||||
// EVM
|
// EVM
|
||||||
Json::Value evmData(Json::objectValue);
|
Json::Value evmData(Json::objectValue);
|
||||||
// @TODO: add ir
|
// @TODO: add ir
|
||||||
|
if (isTargetRequired(outputSelection, file, name, "evm.assembly"))
|
||||||
evmData["assembly"] = m_compilerStack.assemblyString(contractName, createSourceList(_input));
|
evmData["assembly"] = m_compilerStack.assemblyString(contractName, createSourceList(_input));
|
||||||
|
if (isTargetRequired(outputSelection, file, name, "evm.legacyAssembly"))
|
||||||
evmData["legacyAssembly"] = m_compilerStack.assemblyJSON(contractName, createSourceList(_input));
|
evmData["legacyAssembly"] = m_compilerStack.assemblyJSON(contractName, createSourceList(_input));
|
||||||
|
if (isTargetRequired(outputSelection, file, name, "evm.methodIdentifiers"))
|
||||||
evmData["methodIdentifiers"] = m_compilerStack.methodIdentifiers(contractName);
|
evmData["methodIdentifiers"] = m_compilerStack.methodIdentifiers(contractName);
|
||||||
|
if (isTargetRequired(outputSelection, file, name, "evm.gasEstimates"))
|
||||||
evmData["gasEstimates"] = m_compilerStack.gasEstimates(contractName);
|
evmData["gasEstimates"] = m_compilerStack.gasEstimates(contractName);
|
||||||
|
|
||||||
|
if (isTargetRequired(outputSelection, file, name, "evm.bytecode"))
|
||||||
evmData["bytecode"] = collectEVMObject(
|
evmData["bytecode"] = collectEVMObject(
|
||||||
m_compilerStack.object(contractName),
|
m_compilerStack.object(contractName),
|
||||||
m_compilerStack.sourceMapping(contractName)
|
m_compilerStack.sourceMapping(contractName)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if (isTargetRequired(outputSelection, file, name, "evm.deployedBytecode"))
|
||||||
evmData["deployedBytecode"] = collectEVMObject(
|
evmData["deployedBytecode"] = collectEVMObject(
|
||||||
m_compilerStack.runtimeObject(contractName),
|
m_compilerStack.runtimeObject(contractName),
|
||||||
m_compilerStack.runtimeSourceMapping(contractName)
|
m_compilerStack.runtimeSourceMapping(contractName)
|
||||||
|
Loading…
Reference in New Issue
Block a user