package coq-lsp
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.coq/args.ml.html
Source file args.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 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
(************************************************************************) (* Flèche => document manager: Document *) (* Copyright 2019 MINES ParisTech -- Dual License LGPL 2.1 / GPL3+ *) (* Copyright 2019-2024 Inria -- Dual License LGPL 2.1 / GPL3+ *) (* Written by: Emilio J. Gallego Arias & coq-lsp contributors *) (************************************************************************) open Cmdliner (****************************************************************************) (* Common Coq command-line arguments *) let coqlib = let doc = "Load Coq.Init.Prelude from $(docv); theories and user-contrib should live \ there." in Arg.( value & opt string Coq_config.coqlib & info [ "coqlib" ] ~docv:"COQLIB" ~doc) let coqcorelib = let doc = "Path to Coq plugin directories." in Arg.( value & opt string (Filename.concat Coq_config.coqlib "../coq-core/") & info [ "coqcorelib" ] ~docv:"COQCORELIB" ~doc) let ocamlpath = let doc = "Path to OCaml's lib" in Arg.( value & opt (some string) None & info [ "ocamlpath" ] ~docv:"OCAMLPATH" ~doc) let coq_lp_conv ~implicit (unix_path, lp) = { Loadpath.coq_path = Libnames.dirpath_of_string lp ; unix_path ; has_ml = true ; implicit ; recursive = true } let rload_paths : Loadpath.vo_path list Term.t = let doc = "Bind a logical loadpath LP to a directory DIR and implicitly open its \ namespace." in Term.( const List.(map (coq_lp_conv ~implicit:true)) $ Arg.( value & opt_all (pair dir string) [] & info [ "R"; "rec-load-path" ] ~docv:"DIR,LP" ~doc)) let qload_paths : Loadpath.vo_path list Term.t = let doc = "Bind a logical loadpath LP to a directory DIR" in Term.( const List.(map (coq_lp_conv ~implicit:false)) $ Arg.( value & opt_all (pair dir string) [] & info [ "Q"; "load-path" ] ~docv:"DIR,LP" ~doc)) let debug : bool Term.t = let doc = "Enable debug mode" in Arg.(value & flag & info [ "debug" ] ~doc) let bt = let doc = "Enable backtraces" in Cmdliner.Arg.(value & flag & info [ "bt" ] ~doc) let ml_include_path : string list Term.t = let doc = "Include DIR in default loadpath, for locating ML files" in Arg.( value & opt_all dir [] & info [ "I"; "ml-include-path" ] ~docv:"DIR" ~doc) let ri_from : (string option * string) list Term.t = let doc = "FROM Require Import LIBRARY before creating the document, à la From Coq \ Require Import Prelude" in Term.( const (List.map (fun (x, y) -> (Some x, y))) $ Arg.( value & opt_all (pair string string) [] & info [ "rifrom"; "require-import-from" ] ~docv:"FROM,LIBRARY" ~doc)) let int_backend = let docv = "BACKEND" in let backends = [ ("Coq", Limits.Coq); ("Mp", Limits.Mp) ] in let backends_str = "either 'Mp', for memprof-limits token-based interruption,\n\ \ or 'Coq', for Coq's polling mode (unreliable). The 'Mp' backend is only \ supported in OCaml 4.x series." in let doc = Printf.sprintf "Select Interruption Backend, if absent, the best available for your \ OCaml version will be selected. %s is %s" docv backends_str in let absent = "'Mp' for OCaml 4.x, 'Coq' for OCaml 5.x" in Arg.( value & opt (some (enum backends)) None & info [ "int_backend" ] ~docv ~doc ~absent) let roots : string list Term.t = let doc = "Workspace(s) root(s)" in Arg.(value & opt_all string [] & info [ "root" ] ~docv:"ROOTS" ~doc) let coq_diags_level : int Term.t = let doc = "Controls whether Coq Info and Notice message appear in diagnostics.\n\ \ 0 = None; 1 = Notices, 2 = Notices and Info" in Arg.(value & opt int 0 & info [ "diags_level" ] ~docv:"DIAGS_LEVEL" ~doc)
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>