diff options
author | chriseth <chris@ethereum.org> | 2017-10-05 17:23:46 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-10-05 17:23:46 +0800 |
commit | 54cf15ac4f479a658d3c069b24df92d068ca1325 (patch) | |
tree | 7f58c16b745db3464a9f3bb1a5d50748c7c653fa /libsolidity/interface/StandardCompiler.cpp | |
parent | 995b5525a0bd29a96950fad168ce12e6dc167528 (diff) | |
parent | f86cd06b9755f4827467e86acd4a53603f3da84f (diff) | |
download | dexon-solidity-54cf15ac4f479a658d3c069b24df92d068ca1325.tar dexon-solidity-54cf15ac4f479a658d3c069b24df92d068ca1325.tar.gz dexon-solidity-54cf15ac4f479a658d3c069b24df92d068ca1325.tar.bz2 dexon-solidity-54cf15ac4f479a658d3c069b24df92d068ca1325.tar.lz dexon-solidity-54cf15ac4f479a658d3c069b24df92d068ca1325.tar.xz dexon-solidity-54cf15ac4f479a658d3c069b24df92d068ca1325.tar.zst dexon-solidity-54cf15ac4f479a658d3c069b24df92d068ca1325.zip |
Merge pull request #2901 from ethereum/compiler-names
Provide optional list of contract names to CompilerStack.compile
Diffstat (limited to 'libsolidity/interface/StandardCompiler.cpp')
-rw-r--r-- | libsolidity/interface/StandardCompiler.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/libsolidity/interface/StandardCompiler.cpp b/libsolidity/interface/StandardCompiler.cpp index b4fbbef9..430739ac 100644 --- a/libsolidity/interface/StandardCompiler.cpp +++ b/libsolidity/interface/StandardCompiler.cpp @@ -92,6 +92,22 @@ Json::Value formatErrorWithException( return formatError(_warning, _type, _component, message, formattedMessage, location); } +set<string> requestedContractNames(Json::Value const& _outputSelection) +{ + set<string> names; + for (auto const& sourceName: _outputSelection.getMemberNames()) + { + for (auto const& contractName: _outputSelection[sourceName].getMemberNames()) + { + /// Consider the "all sources" shortcuts as requesting everything. + if (contractName == "*" || contractName == "") + return set<string>(); + names.insert((sourceName == "*" ? "" : sourceName) + ":" + contractName); + } + } + return names; +} + /// Returns true iff @a _hash (hex with 0x prefix) is the Keccak256 hash of the binary data in @a _content. bool hashMatchesContent(string const& _hash, string const& _content) { @@ -265,6 +281,9 @@ Json::Value StandardCompiler::compileInternal(Json::Value const& _input) Json::Value metadataSettings = settings.get("metadata", Json::Value()); m_compilerStack.useMetadataLiteralSources(metadataSettings.get("useLiteralContent", Json::Value(false)).asBool()); + Json::Value outputSelection = settings.get("outputSelection", Json::Value()); + m_compilerStack.setRequestedContractNames(requestedContractNames(outputSelection)); + auto scannerFromSourceName = [&](string const& _sourceName) -> solidity::Scanner const& { return m_compilerStack.scanner(_sourceName); }; try |