/*
	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 .
*/
/**
 * @author Alex Beregszaszi
 * @date 2016
 * Standard JSON compiler interface.
 */
#pragma once
#include 
#include 
#include 
namespace dev
{
namespace solidity
{
/**
 * Standard JSON compiler interface, which expects a JSON input and returns a JSON output.
 * See docs/using-the-compiler#compiler-input-and-output-json-description.
 */
class StandardCompiler: boost::noncopyable
{
public:
	/// Creates a new StandardCompiler.
	/// @param _readFile callback to used to read files for import statements. Must return
	/// and must not emit exceptions.
	explicit StandardCompiler(ReadCallback::Callback const& _readFile = ReadCallback::Callback()):
		m_readFile(_readFile)
	{
	}
	/// 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;
	/// 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;
private:
	struct InputsAndSettings
	{
		Json::Value errors;
		std::map sources;
		std::map smtLib2Responses;
		langutil::EVMVersion evmVersion;
		std::vector remappings;
		OptimiserSettings optimiserSettings = OptimiserSettings::minimal();
		std::map libraries;
		bool metadataLiteralSources = false;
		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.
	boost::variant parseInput(Json::Value const& _input);
	Json::Value compileSolidity(InputsAndSettings _inputsAndSettings);
	ReadCallback::Callback m_readFile;
};
}
}