package coq-lsp
Language Server Protocol native server for Coq
Install
Dune Dependency
Authors
Maintainers
Sources
coq-lsp-0.1.8.8.19.tbz
sha256=1e63289d620e533615812267e96e44c1b5cd2dbdaf26cc9dc8ba00051c2b08c0
sha512=9f5e25c6974d293e7c073e65f85936ef18180692dd031c7b709d24d3eefb1955e955c6208cf02c2ac70fa12966d96bc1d43b29f55c425274802289dcf66d5eb2
doc/src/coq-lsp.coq/loader.ml.html
Source file loader.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92
(************************************************************************) (* * The Coq Proof Assistant / The Coq Development Team *) (* v * INRIA, CNRS and contributors - Copyright 1999-2018 *) (* <O___,, * (see CREDITS file for the list of authors) *) (* \VV/ **************************************************************) (* // * This file is distributed under the terms of the *) (* * GNU Lesser General Public License Version 2.1 *) (* * (see LICENSE file for the text of the license) *) (************************************************************************) (************************************************************************) (* Coq serialization API/Plugin *) (* Copyright 2016-2019 MINES ParisTech *) (* Copyright 2019-2022 Inria *) (* Written by Emilio J. Gallego Arias *) (************************************************************************) [@@@ocamlformat "disable"] let list_last l = List.(nth l (length l - 1)) let not_available_warn fl_pkg info = Feedback.msg_warning Pp.(str "Serlib plugin: " ++ str fl_pkg ++ str " is not available" ++ str info ++ str "." ++ fnl () ++ str "Incremental checking for commands in this plugin will be impacted.") let check_package_exists fl_pkg = try let _ = Findlib.package_directory fl_pkg in Some fl_pkg with | Findlib.No_such_package (_, info) -> not_available_warn fl_pkg info; None (* Should improve *) let map_serlib fl_pkg = let supported = match fl_pkg with (* Supported by serlib *) (* directory *) | "coq-core.plugins.cc" (* cc *) | "coq-core.plugins.extraction" (* extraction *) | "coq-core.plugins.firstorder" (* firstorder *) | "coq-core.plugins.funind" (* funind *) | "coq-core.plugins.ltac" (* ltac *) | "coq-core.plugins.ltac2" (* ltac2 *) | "coq-core.plugins.micromega" (* micromega *) | "coq-core.plugins.ring" (* ring *) | "coq-core.plugins.ssreflect" (* ssreflect *) | "coq-core.plugins.ssrmatching" (* ssrmatching *) | "coq-core.plugins.number_string_notation" (* syntax *) | "coq-core.plugins.tauto" (* tauto *) | "coq-core.plugins.zify" (* zify *) -> true | _ -> not_available_warn fl_pkg ": serlib support is missing"; false in if supported then let plugin_name = String.split_on_char '.' fl_pkg |> list_last in let serlib_name = "coq-serapi.serlib." ^ plugin_name in check_package_exists serlib_name else None (* We used to be liberal here in the case a SerAPI plugin was not available. This proved to be a bad choice as Coq got confused when plugin loading failed. Par-contre, we now need to make the list in `map_serlib` open, so plugins can register whether they support serialization. I'm afraid that'll have to happen via the finlib database as we cannot load anticipatedly a plugin that may not exist. *) let safe_loader loader fl_pkg = try loader [fl_pkg] with exn -> let iexn = Exninfo.capture exn in let exn_msg = CErrors.iprint iexn in Feedback.msg_warning Pp.(str "Loading findlib plugin: " ++ str fl_pkg ++ str "failed" ++ fnl () ++ exn_msg); Exninfo.iraise iexn let plugin_handler user_loader = let loader = Option.default (Fl_dynload.load_packages ~debug:false) user_loader in let safe_loader = safe_loader loader in fun fl_pkg -> let _, fl_pkg = Mltop.PluginSpec.repr fl_pkg in match map_serlib fl_pkg with | Some serlib_pkg -> safe_loader serlib_pkg | None -> safe_loader fl_pkg
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>