123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960(********************************************************************************)(* crs - A tool for managing inline review comments embedded in source code *)(* Copyright (C) 2024-2026 Mathieu Barbin <mathieu.barbin@gmail.com> *)(* *)(* This file is part of crs. *)(* *)(* crs is free software; you can redistribute it and/or modify it under the *)(* terms of the GNU Lesser General Public License as published by the Free *)(* Software Foundation either version 3 of the License, or any later version, *)(* with the LGPL-3.0 Linking Exception. *)(* *)(* crs is distributed in the hope that it will be useful, but WITHOUT ANY *)(* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS *)(* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License and *)(* the file `NOTICE.md` at the root of this repository for more details. *)(* *)(* You should have received a copy of the GNU Lesser General Public License *)(* and the LGPL-3.0 Linking Exception along with this library. If not, see *)(* <http://www.gnu.org/licenses/> and <https://spdx.org>, respectively. *)(********************************************************************************)letmain=Command.make~summary:"A util to get info about the enclosing repo."~readme:(fun()->"This debug command locates the root of the repository containing the current \
working directory.\n\n\
It then displays a json-expression containing several fields related to that \
repository and the current path.\n\n\
- $(b,repo_root) : The root of the enclosing repo (absolute path).\n\n\
- $(b,path_in_repo) : The path of the current directory related to the repo root \
(relative path).\n\n\
- $(b,vcs_kind) : The kind of version control for the enclosing repository \
(Git|Hg).\n\n\
This command is meant for debug and quick tests only. Its output is unstable and \
may change without semver updates. In particular it should not be relied on in \
scripts.")(letopenCommand.Stdinlet+()=Arg.return()inletcwd=Unix.getcwd()|>Absolute_path.vinlet{Enclosing_repo.vcs_kind;repo_root;vcs=_}=Common_helpers.find_enclosing_repo~from:cwdinletpath_in_repo=Common_helpers.relativize~repo_root~cwd~path:(Relative_path.empty:>Fpath.t)in(* Even though we say that this command shall not be used by scripts, it is
actually used internally by the emacs-mode provided by this repo. We
control both code and release them in sync, however breaking upgrades
shall be done with care. At the moment, the emacs code relies on the
presence of [json-string] fields [repo_root] and [path_in_repo]. *)print_endline(Json.to_string(`Assoc["repo_root",`String(repo_root|>Vcs.Repo_root.to_string);"path_in_repo",`String(path_in_repo|>Vcs.Path_in_repo.to_string);"vcs_kind",`String(vcs_kind|>Enclosing_repo.Vcs_kind.to_string)]));());;