3
0
Fork 0
mirror of https://github.com/YosysHQ/yosys synced 2025-10-26 17:29:23 +00:00

[Backend] enable list of files planned in execution which will be deleted if exception thrown

This commit is contained in:
Muthu Annamalai 2023-05-25 16:05:16 +00:00
parent 57c9eb70fe
commit 5a5e25c4ea
2 changed files with 32 additions and 9 deletions

View file

@ -649,16 +649,36 @@ void Backend::execute(std::vector<std::string> args, RTLIL::Design *design)
{
std::ostream *f = NULL;
auto state = pre_execute();
execute(f, std::string(), args, design);
post_execute(state);
if (f != &std::cout)
delete f;
bool restore_log_cmd_error_throw = log_cmd_error_throw;
log_cmd_error_throw = true;
try {
execute(f, std::string(), args, design);
post_execute(state);
} catch(log_cmd_error_exception& _) {
if (f && (f != &std::cout)) {
delete f;
f = NULL;
for(auto& itr : filenames) {
if ( itr == "<stdout>" ) continue;
int code = std::remove(itr.c_str());
if ( code )
log("\t Failed to deleted file %s - with exitcode %d\n",itr.c_str(),code);
}
}
log_cmd_error_throw = restore_log_cmd_error_throw;
if ( log_cmd_error_throw )
throw log_cmd_error_exception();
}
log_cmd_error_throw = restore_log_cmd_error_throw;
if (f && (f != &std::cout)) {
delete f;
}
}
void Backend::extra_args(std::ostream *&f, std::string &filename, std::vector<std::string> args, size_t argidx, bool bin_output)
{
bool called_with_fp = f != NULL;
for (; argidx < args.size(); argidx++)
{
std::string arg = args[argidx];
@ -668,8 +688,9 @@ void Backend::extra_args(std::ostream *&f, std::string &filename, std::vector<st
if (f != NULL)
cmd_error(args, argidx, "Extra filename argument in direct file mode.");
if (arg == "-") {
if (arg == "-") {
filename = "<stdout>";
filenames.push_back(filename);
f = &std::cout;
continue;
}
@ -684,6 +705,7 @@ void Backend::extra_args(std::ostream *&f, std::string &filename, std::vector<st
log_cmd_error("Can't open output file `%s' for writing: %s\n", filename.c_str(), strerror(errno));
}
yosys_output_files.insert(filename);
filenames.push_back(filename);
f = gf;
#else
log_cmd_error("Yosys is compiled without zlib support, unable to write gzip output.\n");
@ -696,18 +718,18 @@ void Backend::extra_args(std::ostream *&f, std::string &filename, std::vector<st
delete ff;
log_cmd_error("Can't open output file `%s' for writing: %s\n", filename.c_str(), strerror(errno));
}
filenames.push_back(filename);
f = ff;
}
}
if (called_with_fp)
args.push_back(filename);
args[0] = pass_name;
// cmd_log_args(args);
if (f == NULL) {
filename = "<stdout>";
f = &std::cout;
filenames.push_back(filename);
}
}

View file

@ -112,6 +112,7 @@ struct Frontend : Pass
struct Backend : Pass
{
std::string backend_name;
std::vector<std::string> filenames;
Backend(std::string name, std::string short_help = "** document me **");
void run_register() override;
~Backend() override;