Currently, `git rev-parse` covers a wide range of functionality not directly related to parsing revisions, as its name says. Over time, many features like parsing datestrings, options, paths, and others were added to it because there wasn't a more appropriated command to place them. Create a new Git subcommand called `repo-info`. `git repo-info` will bring the functionality of retrieving repository-related information currently returned by `rev-parse`, displaying them in machine-readable formats (JSON or a null-terminated format). Also add entries for this new command in: - the build files (Makefile, meson.build, Documentation/meson.build) - builtin.h - git.c - .gitignore - command-list.txt - Documentation Helped-by: Phillip Wood <phillip.wood@xxxxxxxxxxxxx> Helped-by: Junio C Hamano <gitster@xxxxxxxxx> Mentored-by: Karthik Nayak <karthik.188@xxxxxxxxx> Mentored-by: Patrick Steinhardt <ps@xxxxxx> Signed-off-by: Lucas Seiki Oshiro <lucasseikioshiro@xxxxxxxxx> --- .gitignore | 1 + Documentation/git-repo-info.adoc | 45 ++++++++++++++++++++++++++++++++ Documentation/meson.build | 1 + Makefile | 1 + builtin.h | 1 + builtin/repo-info.c | 21 +++++++++++++++ command-list.txt | 1 + git.c | 1 + meson.build | 1 + 9 files changed, 73 insertions(+) create mode 100644 Documentation/git-repo-info.adoc create mode 100644 builtin/repo-info.c diff --git a/.gitignore b/.gitignore index 04c444404e..b2f3fb0047 100644 --- a/.gitignore +++ b/.gitignore @@ -139,6 +139,7 @@ /git-repack /git-replace /git-replay +/git-repo-info /git-request-pull /git-rerere /git-reset diff --git a/Documentation/git-repo-info.adoc b/Documentation/git-repo-info.adoc new file mode 100644 index 0000000000..d5f34fc46e --- /dev/null +++ b/Documentation/git-repo-info.adoc @@ -0,0 +1,45 @@ +git-repo-info(1) +================ + +NAME +---- +git-repo-info - Retrieve information about a repository + +SYNOPSIS +-------- +[synopsis] +git repo-info + +DESCRIPTION +----------- +Retrieve information about the current repository in a machine-readable format. + +`git repo-info` will be the primary tool to query repository-specific +information, which currently can also be done by calling `git rev-parse` (see +linkgit:git-rev-parse[1]). `git repo-info` doesn't query information unrelated +to the current repository or that is already retrieved by a specialized command, +for example, `git config` (see linkgit:git-config[1]) or `git var` (see +linkgit:git-var[1]). + +THIS COMMAND IS EXPERIMENTAL. THE BEHAVIOR MAY CHANGE. + +OPTIONS +------- + +`<key>`:: +Key of the value that will be retrieved. It should be in the format +`<category>.<field>`. See the "CATEGORIES AND FIELDS" section below. + +CATEGORIES AND FIELDS +--------------------- + +The set of data that `git repo-info` can return is divided into +categories. Each category is composed by one or more fields. + +SEE ALSO +-------- +linkgit:git-rev-parse[1] + +GIT +--- +Part of the linkgit:git[1] suite diff --git a/Documentation/meson.build b/Documentation/meson.build index 2fe1a1369d..1369523741 100644 --- a/Documentation/meson.build +++ b/Documentation/meson.build @@ -116,6 +116,7 @@ manpages = { 'git-repack.adoc' : 1, 'git-replace.adoc' : 1, 'git-replay.adoc' : 1, + 'git-repo-info.adoc' : 1, 'git-request-pull.adoc' : 1, 'git-rerere.adoc' : 1, 'git-reset.adoc' : 1, diff --git a/Makefile b/Makefile index 70d1543b6b..50e3a3cbcc 100644 --- a/Makefile +++ b/Makefile @@ -1308,6 +1308,7 @@ BUILTIN_OBJS += builtin/remote.o BUILTIN_OBJS += builtin/repack.o BUILTIN_OBJS += builtin/replace.o BUILTIN_OBJS += builtin/replay.o +BUILTIN_OBJS += builtin/repo-info.o BUILTIN_OBJS += builtin/rerere.o BUILTIN_OBJS += builtin/reset.o BUILTIN_OBJS += builtin/rev-list.o diff --git a/builtin.h b/builtin.h index bff13e3069..cc6bc95962 100644 --- a/builtin.h +++ b/builtin.h @@ -216,6 +216,7 @@ int cmd_remote_ext(int argc, const char **argv, const char *prefix, struct repos int cmd_remote_fd(int argc, const char **argv, const char *prefix, struct repository *repo); int cmd_repack(int argc, const char **argv, const char *prefix, struct repository *repo); int cmd_replay(int argc, const char **argv, const char *prefix, struct repository *repo); +int cmd_repo_info(int argc, const char **argv, const char *prefix, struct repository *repo); int cmd_rerere(int argc, const char **argv, const char *prefix, struct repository *repo); int cmd_reset(int argc, const char **argv, const char *prefix, struct repository *repo); int cmd_restore(int argc, const char **argv, const char *prefix, struct repository *repo); diff --git a/builtin/repo-info.c b/builtin/repo-info.c new file mode 100644 index 0000000000..0180c89908 --- /dev/null +++ b/builtin/repo-info.c @@ -0,0 +1,21 @@ +#include "builtin.h" +#include "parse-options.h" + +int cmd_repo_info(int argc, + const char **argv, + const char *prefix, + struct repository *repo UNUSED) +{ + const char *const repo_info_usage[] = { + "git repo-info", + NULL + }; + struct option options[] = { + OPT_END() + }; + + argc = parse_options(argc, argv, prefix, options, repo_info_usage, + 0); + + return 0; +} diff --git a/command-list.txt b/command-list.txt index b7ade3ab9f..197ac21706 100644 --- a/command-list.txt +++ b/command-list.txt @@ -164,6 +164,7 @@ git-remote ancillarymanipulators complete git-repack ancillarymanipulators complete git-replace ancillarymanipulators complete git-replay plumbingmanipulators +git-repo-info plumbinginterrogators git-request-pull foreignscminterface complete git-rerere ancillaryinterrogators git-reset mainporcelain history diff --git a/git.c b/git.c index 07a5fe39fb..27a2b3569b 100644 --- a/git.c +++ b/git.c @@ -611,6 +611,7 @@ static struct cmd_struct commands[] = { { "repack", cmd_repack, RUN_SETUP }, { "replace", cmd_replace, RUN_SETUP }, { "replay", cmd_replay, RUN_SETUP }, + { "repo-info", cmd_repo_info, RUN_SETUP }, { "rerere", cmd_rerere, RUN_SETUP }, { "reset", cmd_reset, RUN_SETUP }, { "restore", cmd_restore, RUN_SETUP | NEED_WORK_TREE }, diff --git a/meson.build b/meson.build index 7fea4a34d6..06f2f647ba 100644 --- a/meson.build +++ b/meson.build @@ -645,6 +645,7 @@ builtin_sources = [ 'builtin/repack.c', 'builtin/replace.c', 'builtin/replay.c', + 'builtin/repo-info.c', 'builtin/rerere.c', 'builtin/reset.c', 'builtin/rev-list.c', -- 2.39.5 (Apple Git-154)