fix(library/module): sign error is circular module dependency is detected

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2014-07-20 19:21:54 -07:00
parent 29b6d1081c
commit cff6bf8c6d

View file

@ -181,6 +181,7 @@ struct import_modules_fn {
}; };
typedef std::shared_ptr<module_info> module_info_ptr; typedef std::shared_ptr<module_info> module_info_ptr;
name_map<module_info_ptr> m_module_info; name_map<module_info_ptr> m_module_info;
name_set m_visited;
import_modules_fn(environment const & env, unsigned num_threads, bool keep_proofs, io_state const & ios): import_modules_fn(environment const & env, unsigned num_threads, bool keep_proofs, io_state const & ios):
m_senv(env), m_num_threads(num_threads), m_keep_proofs(keep_proofs), m_ios(ios), m_senv(env), m_num_threads(num_threads), m_keep_proofs(keep_proofs), m_ios(ios),
@ -202,6 +203,9 @@ struct import_modules_fn {
if (it) if (it)
return *it; return *it;
std::string fname = find_file(mname, {".olean"}); std::string fname = find_file(mname, {".olean"});
if (m_visited.contains(fname))
throw exception(sstream() << "circular dependency detected at '" << fname << "'");
m_visited.insert(fname);
std::ifstream in(fname, std::ifstream::binary); std::ifstream in(fname, std::ifstream::binary);
if (!in.good()) if (!in.good())
throw exception(sstream() << "failed to open file '" << fname << "'"); throw exception(sstream() << "failed to open file '" << fname << "'");
@ -235,12 +239,11 @@ struct import_modules_fn {
r->m_module_idx = g_null_module_idx; r->m_module_idx = g_null_module_idx;
m_import_counter++; m_import_counter++;
std::swap(r->m_obj_code, code); std::swap(r->m_obj_code, code);
m_module_info.insert(mname, r);
for (auto i : imports) { for (auto i : imports) {
auto d = load_module_file(i); auto d = load_module_file(i);
d->m_dependents.push_back(r); d->m_dependents.push_back(r);
} }
m_module_info.insert(mname, r);
r->m_module_idx = m_next_module_idx++; r->m_module_idx = m_next_module_idx++;
if (imports.empty()) if (imports.empty())