solidity/libsolidity/interface/StandardCompiler.h

87 lines
2.9 KiB
C
Raw Normal View History

2017-02-09 21:56:49 +00:00
/*
This file is part of solidity.
solidity is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
solidity is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with solidity. If not, see <http://www.gnu.org/licenses/>.
*/
// SPDX-License-Identifier: GPL-3.0
2017-02-09 21:56:49 +00:00
/**
* @author Alex Beregszaszi
* @date 2016
* Standard JSON compiler interface.
*/
#pragma once
#include <libsolidity/interface/CompilerStack.h>
2020-04-01 03:04:29 +00:00
#include <optional>
#include <utility>
#include <variant>
2019-12-11 16:31:36 +00:00
namespace solidity::frontend
2017-02-09 21:56:49 +00:00
{
/**
* Standard JSON compiler interface, which expects a JSON input and returns a JSON output.
2017-02-09 21:56:49 +00:00
* See docs/using-the-compiler#compiler-input-and-output-json-description.
*/
class StandardCompiler: boost::noncopyable
{
public:
/// Creates a new StandardCompiler.
/// @param _readFile callback used to read files for import statements. Must return
/// and must not emit exceptions.
2020-04-01 03:04:29 +00:00
explicit StandardCompiler(ReadCallback::Callback _readFile = ReadCallback::Callback()):
m_readFile(std::move(_readFile))
2017-02-09 21:56:49 +00:00
{
}
/// Sets all input parameters according to @a _input which conforms to the standardized input
/// format, performs compilation and returns a standardized output.
Json::Value compile(Json::Value const& _input) noexcept;
2017-02-09 21:56:49 +00:00
/// Parses input as JSON and peforms the above processing steps, returning a serialized JSON
/// output. Parsing errors are returned as regular errors.
std::string compile(std::string const& _input) noexcept;
2017-02-09 21:56:49 +00:00
private:
struct InputsAndSettings
{
std::string language;
Json::Value errors;
bool parserErrorRecovery = false;
2020-07-08 20:08:50 +00:00
CompilerStack::State stopAfter = CompilerStack::State::CompilationSuccessful;
std::map<std::string, std::string> sources;
2019-12-11 16:31:36 +00:00
std::map<util::h256, std::string> smtLib2Responses;
langutil::EVMVersion evmVersion;
std::vector<CompilerStack::Remapping> remappings;
RevertStrings revertStrings = RevertStrings::Default;
OptimiserSettings optimiserSettings = OptimiserSettings::minimal();
2019-12-11 16:31:36 +00:00
std::map<std::string, util::h160> libraries;
bool metadataLiteralSources = false;
2019-09-06 17:11:07 +00:00
CompilerStack::MetadataHash metadataHash = CompilerStack::MetadataHash::IPFS;
Json::Value outputSelection;
};
/// Parses the input json (and potentially invokes the read callback) and either returns
/// it in condensed form or an error as a json object.
std::variant<InputsAndSettings, Json::Value> parseInput(Json::Value const& _input);
Json::Value compileSolidity(InputsAndSettings _inputsAndSettings);
Json::Value compileYul(InputsAndSettings _inputsAndSettings);
2017-03-17 12:08:12 +00:00
2017-07-13 19:06:04 +00:00
ReadCallback::Callback m_readFile;
2017-02-09 21:56:49 +00:00
};
}