Browse Source

Solc cmdline option for ast outputting either to stdout or a file

cl-refactor
Lefteris Karapetsas 10 years ago
parent
commit
2cc2fe735e
  1. 1
      solc/CMakeLists.txt
  2. 74
      solc/main.cpp

1
solc/CMakeLists.txt

@ -8,6 +8,7 @@ set(EXECUTABLE solc)
add_executable(${EXECUTABLE} ${SRC_LIST}) add_executable(${EXECUTABLE} ${SRC_LIST})
target_link_libraries(${EXECUTABLE} boost_filesystem)
target_link_libraries(${EXECUTABLE} boost_program_options) target_link_libraries(${EXECUTABLE} boost_program_options)
target_link_libraries(${EXECUTABLE} solidity) target_link_libraries(${EXECUTABLE} solidity)

74
solc/main.cpp

@ -22,8 +22,10 @@
#include <string> #include <string>
#include <iostream> #include <iostream>
#include <fstream>
#include <boost/program_options.hpp> #include <boost/program_options.hpp>
#include <boost/filesystem.hpp>
#include "BuildInfo.h" #include "BuildInfo.h"
#include <libdevcore/Common.h> #include <libdevcore/Common.h>
@ -51,6 +53,28 @@ void version()
exit(0); exit(0);
} }
enum class AstOutput
{
STDOUT,
FILE,
BOTH
};
std::istream& operator>>(std::istream& _in, AstOutput& io_output)
{
std::string token;
_in >> token;
if (token == "stdout")
io_output = AstOutput::STDOUT;
else if (token == "file")
io_output = AstOutput::FILE;
else if (token == "both")
io_output = AstOutput::BOTH;
else
throw boost::program_options::invalid_option_value(token);
return _in;
}
int main(int argc, char** argv) int main(int argc, char** argv)
{ {
// Declare the supported options. // Declare the supported options.
@ -59,14 +83,27 @@ int main(int argc, char** argv)
("help", "Show help message and exit") ("help", "Show help message and exit")
("version", "Show version and exit") ("version", "Show version and exit")
("optimize", po::value<bool>()->default_value(false), "Optimize bytecode for size") ("optimize", po::value<bool>()->default_value(false), "Optimize bytecode for size")
("input-file", po::value<vector<string>>(), "input file"); ("input-file", po::value<vector<string>>(), "input file")
("ast", po::value<AstOutput>(),
"Request to output the AST of the contract. Legal values:\n"
"\tstdout: Print it to standar output\n"
"\tfile: Print it to a file with same name\n");
// All positional options should be interpreted as input files // All positional options should be interpreted as input files
po::positional_options_description p; po::positional_options_description p;
p.add("input-file", -1); p.add("input-file", -1);
// parse the compiler arguments
po::variables_map vm; po::variables_map vm;
po::store(po::command_line_parser(argc, argv).options(desc).positional(p).allow_unregistered().run(), vm); try
{
po::store(po::command_line_parser(argc, argv).options(desc).positional(p).allow_unregistered().run(), vm);
}
catch (po::error const& exception)
{
cout << exception.what() << endl;
return -1;
}
po::notify(vm); po::notify(vm);
if (vm.count("help")) { if (vm.count("help")) {
@ -135,13 +172,36 @@ int main(int argc, char** argv)
return -1; return -1;
} }
cout << "Syntax trees:" << endl << endl;
for (auto const& sourceCode: sourceCodes) // do we need AST output?
if (vm.count("ast"))
{ {
cout << endl << "======= " << sourceCode.first << " =======" << endl; auto choice = vm["ast"].as<AstOutput>();
ASTPrinter printer(compiler.getAST(sourceCode.first), sourceCode.second); if (choice != AstOutput::FILE)
printer.print(cout); {
cout << "Syntax trees:" << endl << endl;
for (auto const& sourceCode: sourceCodes)
{
cout << endl << "======= " << sourceCode.first << " =======" << endl;
ASTPrinter printer(compiler.getAST(sourceCode.first), sourceCode.second);
printer.print(cout);
}
}
if (choice != AstOutput::STDOUT)
{
for (auto const& sourceCode: sourceCodes)
{
boost::filesystem::path p(sourceCode.first);
ofstream outFile(p.stem().string() + ".ast");
ASTPrinter printer(compiler.getAST(sourceCode.first), sourceCode.second);
printer.print(outFile);
outFile.close();
}
}
} }
vector<string> contracts = compiler.getContractNames(); vector<string> contracts = compiler.getContractNames();
cout << endl << "Contracts:" << endl; cout << endl << "Contracts:" << endl;
for (string const& contract: contracts) for (string const& contract: contracts)

Loading…
Cancel
Save