aboutsummaryrefslogtreecommitdiffstats
path: root/solc/CommandLineInterface.cpp
diff options
context:
space:
mode:
authorAlex Beregszaszi <alex@rtfs.hu>2018-03-29 08:53:56 +0800
committerGitHub <noreply@github.com>2018-03-29 08:53:56 +0800
commitc2ae33f8067c2ed2a70a86f9e29cce06e23af28a (patch)
treecb6a57d921d7dd45fd78ab4f5a51e71ee1ff0c28 /solc/CommandLineInterface.cpp
parent3bb54e8bd5ea75bd52d2eca43fd438f8e894a2de (diff)
parent8a18f22b878b86fff8e2f49a99397320180d4b22 (diff)
downloaddexon-solidity-c2ae33f8067c2ed2a70a86f9e29cce06e23af28a.tar
dexon-solidity-c2ae33f8067c2ed2a70a86f9e29cce06e23af28a.tar.gz
dexon-solidity-c2ae33f8067c2ed2a70a86f9e29cce06e23af28a.tar.bz2
dexon-solidity-c2ae33f8067c2ed2a70a86f9e29cce06e23af28a.tar.lz
dexon-solidity-c2ae33f8067c2ed2a70a86f9e29cce06e23af28a.tar.xz
dexon-solidity-c2ae33f8067c2ed2a70a86f9e29cce06e23af28a.tar.zst
dexon-solidity-c2ae33f8067c2ed2a70a86f9e29cce06e23af28a.zip
Merge pull request #3754 from AnthonyBroadCrawford/error-on-missing-file
Error on non existing or irregular files
Diffstat (limited to 'solc/CommandLineInterface.cpp')
-rw-r--r--solc/CommandLineInterface.cpp31
1 files changed, 26 insertions, 5 deletions
diff --git a/solc/CommandLineInterface.cpp b/solc/CommandLineInterface.cpp
index d3d234c3..8f81e799 100644
--- a/solc/CommandLineInterface.cpp
+++ b/solc/CommandLineInterface.cpp
@@ -116,6 +116,7 @@ static string const g_strStandardJSON = "standard-json";
static string const g_strStrictAssembly = "strict-assembly";
static string const g_strPrettyJson = "pretty-json";
static string const g_strVersion = "version";
+static string const g_strIgnoreMissingFiles = "ignore-missing";
static string const g_argAbi = g_strAbi;
static string const g_argPrettyJson = g_strPrettyJson;
@@ -152,6 +153,7 @@ static string const g_argStandardJSON = g_strStandardJSON;
static string const g_argStrictAssembly = g_strStrictAssembly;
static string const g_argVersion = g_strVersion;
static string const g_stdinFileName = g_stdinFileNameStr;
+static string const g_argIgnoreMissingFiles = g_strIgnoreMissingFiles;
/// Possible arguments to for --combined-json
static set<string> const g_combinedJsonArgs
@@ -398,8 +400,9 @@ void CommandLineInterface::handleGasEstimation(string const& _contract)
}
}
-void CommandLineInterface::readInputFilesAndConfigureRemappings()
+bool CommandLineInterface::readInputFilesAndConfigureRemappings()
{
+ bool ignoreMissing = m_args.count(g_argIgnoreMissingFiles);
bool addStdin = false;
if (!m_args.count(g_argInputFile))
addStdin = true;
@@ -416,13 +419,27 @@ void CommandLineInterface::readInputFilesAndConfigureRemappings()
auto infile = boost::filesystem::path(path);
if (!boost::filesystem::exists(infile))
{
- cerr << "Skipping non-existent input file \"" << infile << "\"" << endl;
+ if (!ignoreMissing)
+ {
+ cerr << "\"" << infile << "\" is not found" << endl;
+ return false;
+ }
+ else
+ cerr << "\"" << infile << "\" is not found. Skipping." << endl;
+
continue;
}
if (!boost::filesystem::is_regular_file(infile))
{
- cerr << "\"" << infile << "\" is not a valid file. Skipping" << endl;
+ if (!ignoreMissing)
+ {
+ cerr << "\"" << infile << "\" is not a valid file" << endl;
+ return false;
+ }
+ else
+ cerr << "\"" << infile << "\" is not a valid file. Skipping." << endl;
+
continue;
}
@@ -433,6 +450,8 @@ void CommandLineInterface::readInputFilesAndConfigureRemappings()
}
if (addStdin)
m_sourceCodes[g_stdinFileName] = dev::readStandardInput();
+
+ return true;
}
bool CommandLineInterface::parseLibraryOption(string const& _input)
@@ -599,7 +618,8 @@ Allowed options)",
g_argAllowPaths.c_str(),
po::value<string>()->value_name("path(s)"),
"Allow a given path for imports. A list of paths can be supplied by separating them with a comma."
- );
+ )
+ (g_argIgnoreMissingFiles.c_str(), "Ignore missing files.");
po::options_description outputComponents("Output Components");
outputComponents.add_options()
(g_argAst.c_str(), "AST of all source files.")
@@ -741,7 +761,8 @@ bool CommandLineInterface::processInput()
return true;
}
- readInputFilesAndConfigureRemappings();
+ if (!readInputFilesAndConfigureRemappings())
+ return false;
if (m_args.count(g_argLibraries))
for (string const& library: m_args[g_argLibraries].as<vector<string>>())