From 2b65f02f6f8db8b5d586db0ad0242596a7f1bfd6 Mon Sep 17 00:00:00 2001 From: Leonardo de Moura Date: Fri, 27 Feb 2015 07:54:59 -0800 Subject: [PATCH] feat(shell/lean): do not terminate if an error is detected when loading the cache see issue #448 --- src/shell/lean.cpp | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/src/shell/lean.cpp b/src/shell/lean.cpp index aff055f03..a2ebe5a99 100644 --- a/src/shell/lean.cpp +++ b/src/shell/lean.cpp @@ -28,6 +28,7 @@ Author: Leonardo de Moura #include "library/standard_kernel.h" #include "library/hott_kernel.h" #include "library/module.h" +#include "library/flycheck.h" #include "library/io_state_stream.h" #include "library/definition_cache.h" #include "library/declaration_index.h" @@ -487,9 +488,17 @@ int main(int argc, char ** argv) { if (!in.bad() && !in.fail()) cache.load(in); } catch (lean::throwable & ex) { - lean::display_error(diagnostic(env, ios), nullptr, ex); - std::cerr << "Failed to load cache file '" << cache_name << "'\n"; - return 1; + cache_ptr = nullptr; + auto out = regular(env, ios); + // 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;