feat(shell/lean): do not terminate if an error is detected when loading the cache

see issue #448
This commit is contained in:
Leonardo de Moura 2015-02-27 07:54:59 -08:00
parent 5b736a2268
commit 2b65f02f6f

View file

@ -28,6 +28,7 @@ Author: Leonardo de Moura
#include "library/standard_kernel.h" #include "library/standard_kernel.h"
#include "library/hott_kernel.h" #include "library/hott_kernel.h"
#include "library/module.h" #include "library/module.h"
#include "library/flycheck.h"
#include "library/io_state_stream.h" #include "library/io_state_stream.h"
#include "library/definition_cache.h" #include "library/definition_cache.h"
#include "library/declaration_index.h" #include "library/declaration_index.h"
@ -487,9 +488,17 @@ int main(int argc, char ** argv) {
if (!in.bad() && !in.fail()) if (!in.bad() && !in.fail())
cache.load(in); cache.load(in);
} catch (lean::throwable & ex) { } catch (lean::throwable & ex) {
lean::display_error(diagnostic(env, ios), nullptr, ex); cache_ptr = nullptr;
std::cerr << "Failed to load cache file '" << cache_name << "'\n"; auto out = regular(env, ios);
return 1; // I'm using flycheck_error instead off flycheck_warning because
// the :error-patterns at lean-flycheck.el do not work after
// I add a rule for FLYCHECK_WARNING.
// Same for display_error_pos vs display_warning_pos.
lean::flycheck_error warn(out);
if (optind < argc)
display_error_pos(out, argv[optind], 1, 0);
out << "failed to load cache file '" << cache_name << "', "
<< ex.what() << ". cache is going to be ignored\n";
} }
} }
declaration_index index; declaration_index index;