package coq-lsp

  1. Overview
  2. Docs
Language Server Protocol native server for Coq

Install

Dune Dependency

Authors

Maintainers

Sources

coq-lsp-0.2.3.9.0.tbz
sha256=8776582dddfe768623870cf540ff6ba1e96a44a36e85db18ab93d238d640f92a
sha512=2837889bf99bfe715bd0e752782211a76a14aac71ed37a4fb784f4f0abe338352c9c6d8caa37daf79c036997add1cb306c523f793625b38709f3b5e245380223

doc/src/coq-lsp.coq/interp.ml.html

Source file interp.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
(************************************************************************)
(*         *   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 Language Server Protocol                                         *)
(* Copyright 2019 MINES ParisTech -- Dual License LGPL 2.1 / GPL3+      *)
(* Copyright 2019-2022 Inria      -- Dual License LGPL 2.1 / GPL3+      *)
(* Written by: Emilio J. Gallego Arias                                  *)
(************************************************************************)

let coq_interp ~intern ~st cmd =
  let st = State.to_coq st in
  let cmd = Ast.to_coq cmd in
  Vernacinterp.interp ~intern ~st cmd |> State.of_coq

let interp ~token ~intern ~st cmd =
  Protect.eval ~token cmd ~f:(coq_interp ~intern ~st)

module Require = struct
  (* We could improve this Coq upstream by making the API a bit more
     orthogonal *)
  let interp ~intern ~st _files
      { Ast.Require.from; export; mods; loc = _; attrs; control } =
    let () = Vernacstate.unfreeze_full_state (State.to_coq st) in
    let fn () = Vernacentries.vernac_require ~intern from export mods in
    (* Check generic attributes *)
    let fn () =
      Synterp.with_generic_atts ~check:true attrs (fun ~atts ->
          (* Fail if attributes are not empty *)
          Attributes.unsupported_attributes atts;
          fn ())
    in
    (* Execute control commands *)
    let () = Utils.with_control ~fn ~control ~st in
    Vernacstate.freeze_full_state () |> State.of_coq

  let interp ~token ~intern ~st files cmd =
    Protect.eval ~token ~f:(interp ~intern ~st files) cmd
end
OCaml

Innovation. Community. Security.