Skip to content

funwithcthulhu/doctor

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

37 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

doctor

CI opam license

doctor checks a local OCaml development environment. It reports missing tools, suspicious opam state, and editor setup issues; it does not modify switches, shell files, or editor settings.

It currently checks platform details, core tool versions, opam initialization state, active and available switches, whether the resolved ocaml appears to match the active switch, whether installed switch tools are visible on PATH, selected opam packages, environment settings known to disturb opam builds, Windows opam plugin dispatch state, and the VS Code OCaml Platform extension when code is available.

The read-only diagnostic contract is described in docs/diagnostic-contract.md.

When opam has an active switch but switch tools are missing from the current shell, doctor reports the active switch bin path and suggests reloading the opam environment. On Windows it prints PowerShell and cmd.exe commands; on Unix-like systems it uses eval $(opam env).

Installation

opam update
opam install doctor

To build from a checkout:

git clone https://github.com/funwithcthulhu/doctor
cd doctor
opam install . --deps-only --with-test
opam exec -- dune build

For local testing through opam, use a path pin:

opam pin add doctor . -y --kind=path

Usage

doctor check
doctor check --json
doctor version
doctor --help

The package also installs opam-doctor. When installed through opam, the same CLI is available as an opam plugin:

opam doctor check

doctor check prints a text report:

$ doctor check
OCaml Doctor

[OK] platform detected: macOS
[OK] opam found: 2.2.1
[OK] OCaml found: 5.2.0
[OK] dune found: 3.17.0
[OK] OCaml LSP found: 1.19.0 (ocamllsp)
[WARN] ocamlformat not installed
       Suggested fix: opam install ocamlformat
[OK] active switch: 5.2.0
[WARN] VS Code OCaml Platform extension not detected
       Suggested fix: Install extension ocamllabs.ocaml-platform in VS Code.

Summary: 6 OK, 2 WARN, 0 ERROR

Use --json when another program needs to read the report:

$ doctor check --json
{
  "summary": {
    "status": "warn",
    "exit_code": 1
  },
  "diagnostics": [
    {
      "name": "command.ocamlformat",
      "status": "warn",
      "message": "ocamlformat not installed",
      "details": ["Suggested fix: opam install ocamlformat"]
    }
  ]
}

Diagnostic name values are intended to be stable for scripts. The current names are listed in docs/diagnostic-contract.md.

doctor version prints:

doctor 0.4.0

Exit Codes

  • 0: no warnings or errors
  • 1: one or more warnings, no errors
  • 2: one or more errors
  • 3: unexpected internal failure

Development

opam install . --deps-only --with-test
opam exec -- dune build
opam exec -- dune runtest
opam exec -- dune exec doctor -- check

Tests fake process execution, so they do not depend on the host opam setup, VS Code, or a particular shell.

Maintainer release notes are in RELEASE.md.

About

Diagnostic CLI for OCaml development environments

Topics

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors