diff --git a/libsolidity/interface/CompilerStack.cpp b/libsolidity/interface/CompilerStack.cpp index 70788db92..a936b055d 100644 --- a/libsolidity/interface/CompilerStack.cpp +++ b/libsolidity/interface/CompilerStack.cpp @@ -411,7 +411,7 @@ void CompilerStack::importASTs(map const& _sources) m_sources[path] = std::move(source); } m_stackState = ParsedAndImported; - m_importedSources = true; + m_compilationSourceType = CompilationSourceType::SolidityAST; storeContractDefinitions(); } @@ -1483,7 +1483,17 @@ string CompilerStack::createMetadata(Contract const& _contract, bool _forIR) con { Json::Value meta{Json::objectValue}; meta["version"] = 1; - meta["language"] = m_importedSources ? "SolidityAST" : "Solidity"; + string sourceType; + switch (m_compilationSourceType) + { + case CompilationSourceType::Solidity: + sourceType = "Solidity"; + break; + case CompilationSourceType::SolidityAST: + sourceType = "SolidityAST"; + break; + } + meta["language"] = sourceType; meta["compiler"]["version"] = VersionStringStrict; /// All the source files (including self), which should be included in the metadata. diff --git a/libsolidity/interface/CompilerStack.h b/libsolidity/interface/CompilerStack.h index 2f9524659..2ca7ba091 100644 --- a/libsolidity/interface/CompilerStack.h +++ b/libsolidity/interface/CompilerStack.h @@ -117,6 +117,13 @@ public: None }; + enum class CompilationSourceType { + /// Regular compilation from Solidity source files. + Solidity, + /// Compilation from an imported Solidity AST. + SolidityAST + }; + /// Creates a new compiler stack. /// @param _readFile callback used to read files for import statements. Must return /// and must not emit exceptions. @@ -514,7 +521,7 @@ private: langutil::DebugInfoSelection m_debugInfoSelection = langutil::DebugInfoSelection::Default(); bool m_parserErrorRecovery = false; State m_stackState = Empty; - bool m_importedSources = false; + CompilationSourceType m_compilationSourceType = CompilationSourceType::Solidity; /// Whether or not there has been an error during processing. /// If this is true, the stack will refuse to generate code. bool m_hasError = false;