package coq-lsp

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

Install

Dune Dependency

Authors

Maintainers

Sources

coq-lsp-0.2.0.8.18.tbz
sha256=ba40f92f4c751793265d20f1c217638146e4714e0196a0d2b00c9ed58774abf6
sha512=0b7c1d98e22017e44d90461ee61081043401387251488ee7113668d24f6a463dca4ce690e30355248a949817c6b8f8a0944489c4d9b66bd239d903a089a1f11f

doc/src/coq-lsp.serlib/serlib_base.ml.html

Source file serlib_base.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
(************************************************************************)
(*  v      *   The Coq Proof Assistant  /  The Coq Development Team     *)
(* <O___,, *   INRIA - CNRS - LIX - LRI - PPS - Copyright 1999-2016     *)
(*   \VV/  **************************************************************)
(*    //   *      This file is distributed under the terms of the       *)
(*         *       GNU Lesser General Public License Version 2.1        *)
(************************************************************************)

(************************************************************************)
(* Coq serialization API/Plugin                                         *)
(* Copyright 2016-2018 MINES ParisTech                                  *)
(************************************************************************)
(* Status: Very Experimental                                            *)
(************************************************************************)

exception Ser_error of string

let _ = CErrors.register_handler (function
    | Ser_error msg ->
      Some Pp.(seq [str "Serlib Error: "; str msg])
    | _ ->
      None)

let opaque_of_sexp ~typ _obj =
  raise (Ser_error ("["^typ^": ABSTRACT / cannot deserialize]"))

let exn_on_opaque = ref true

let sexp_of_opaque ~typ _exp =
  let msg = "["^typ^": ABSTRACT]" in
  if !exn_on_opaque then
    raise (Ser_error msg)
  else
    Sexplib.Sexp.Atom ("["^typ^": ABSTRACT]")

let opaque_of_yojson ~typ _obj =
  raise (Ser_error ("["^typ^": ABSTRACT / cannot deserialize]"))

let opaque_to_yojson ~typ _obj =
  let msg = "["^typ^": ABSTRACT]" in
  if !exn_on_opaque then
    raise (Ser_error msg)
  else
    `String ("["^typ^": ABSTRACT]")

let hash_opaque ~typ:_ x = Hashtbl.hash x
let hash_fold_opaque ~typ st x = Ppx_hash_lib.Std.Hash.Builtin.hash_fold_int st (hash_opaque ~typ x)
let compare_opaque ~typ:_ x y = Stdlib.compare x y

OCaml

Innovation. Community. Security.