From: Stephen Boyd <bebarino@gmail.com>
To: "Michał Kiedrowicz" <michal.kiedrowicz@gmail.com>
Cc: git@vger.kernel.org
Subject: Re: [PATCH] init-db: migrate to parse-options
Date: Sun, 12 Jul 2009 00:17:23 -0700 [thread overview]
Message-ID: <4A598E03.10204@gmail.com> (raw)
In-Reply-To: <1247352793-25675-1-git-send-email-michal.kiedrowicz@gmail.com>
Michał Kiedrowicz wrote:
> Also add missing --bare to init-db synopsis.
>
> Signed-off-by: Michał Kiedrowicz <michal.kiedrowicz@gmail.com>
> ---
Heh, I had a very similar patch queued up.
> Documentation/git-init-db.txt | 2 +-
> builtin-init-db.c | 51 ++++++++++++++++++++++++-----------------
> 2 files changed, 31 insertions(+), 22 deletions(-)
>
> diff --git a/Documentation/git-init-db.txt b/Documentation/git-init-db.txt
> index 1fd0ff2..eba3cb4 100644
> --- a/Documentation/git-init-db.txt
> +++ b/Documentation/git-init-db.txt
> @@ -8,7 +8,7 @@ git-init-db - Creates an empty git repository
>
> SYNOPSIS
> --------
> -'git init-db' [-q | --quiet] [--template=<template_directory>] [--shared[=<permissions>]]
> +'git init-db' [-q | --quiet] [--bare] [--template=<template_directory>] [--shared[=<permissions>]]
>
>
> DESCRIPTION
> diff --git a/builtin-init-db.c b/builtin-init-db.c
> index 4a56006..9b1ce45 100644
> --- a/builtin-init-db.c
> +++ b/builtin-init-db.c
> @@ -6,6 +6,7 @@
> #include "cache.h"
> #include "builtin.h"
> #include "exec_cmd.h"
> +#include "parse-options.h"
>
> #ifndef DEFAULT_GIT_TEMPLATE_DIR
> #define DEFAULT_GIT_TEMPLATE_DIR "/usr/share/git-core/templates"
> @@ -370,8 +371,16 @@ static int guess_repository_type(const char *git_dir)
> return 1;
> }
>
> -static const char init_db_usage[] =
> -"git init [-q | --quiet] [--bare] [--template=<template-directory>] [--shared[=<permissions>]]";
> +static int shared_callback(const struct option *opt, const char *arg, int unset)
> +{
> + *((int *) opt->value) = (arg) ? git_config_perm("arg", arg) : PERM_GROUP;
> + return 0;
> +}
What occurs when "--no-shared" is used? I have this callback use an if,
else if, else to handle all possibilities.
> +
> +static const char *const init_db_usage[] = {
> + "git init [-q | --quiet] [--bare] [--template=<template-directory>] [--shared[=<permissions>]]",
> + NULL
> +};
>
> /*
> * If you want to, you can share the DB area with any number of branches.
> @@ -384,25 +393,25 @@ int cmd_init_db(int argc, const char **argv, const char *prefix)
> const char *git_dir;
> const char *template_dir = NULL;
> unsigned int flags = 0;
> - int i;
> -
> - for (i = 1; i < argc; i++, argv++) {
> - const char *arg = argv[1];
> - if (!prefixcmp(arg, "--template="))
> - template_dir = arg+11;
> - else if (!strcmp(arg, "--bare")) {
> - static char git_dir[PATH_MAX+1];
> - is_bare_repository_cfg = 1;
> - setenv(GIT_DIR_ENVIRONMENT, getcwd(git_dir,
> - sizeof(git_dir)), 0);
> - } else if (!strcmp(arg, "--shared"))
> - init_shared_repository = PERM_GROUP;
> - else if (!prefixcmp(arg, "--shared="))
> - init_shared_repository = git_config_perm("arg", arg+9);
> - else if (!strcmp(arg, "-q") || !strcmp(arg, "--quiet"))
> - flags |= INIT_DB_QUIET;
> - else
> - usage(init_db_usage);
> + const struct option init_db_options[] = {
> + OPT_STRING(0, "template", &template_dir, "template-directory",
> + "provide the directory from which templates will be used"),
> + OPT_SET_INT(0, "bare", &is_bare_repository_cfg,
> + "create a bare repository", 1),
> + { OPTION_CALLBACK, 0, "shared", &init_shared_repository,
> + "permissions",
> + "specify that the git repository is to be shared amongst several users",
> + PARSE_OPT_OPTARG, shared_callback, 0},
Or you can add PARSE_OPT_NONEG here and avoid the above comment.
> + OPT_BIT('q', "quiet", &flags, "be quiet", INIT_DB_QUIET),
> + OPT_END()
> + };
> +
> + parse_options(argc, argv, prefix, init_db_options, init_db_usage, 0);
> +
> + if(is_bare_repository_cfg == 1) {
> + static char git_dir[PATH_MAX+1];
> + setenv(GIT_DIR_ENVIRONMENT, getcwd(git_dir,
> + sizeof(git_dir)), 0);
> }
>
> if (init_shared_repository != -1)
next prev parent reply other threads:[~2009-07-12 7:18 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-07-11 22:53 [PATCH] init-db: migrate to parse-options Michał Kiedrowicz
2009-07-12 7:17 ` Stephen Boyd [this message]
2009-07-12 10:24 ` [PATCH v2] " Michał Kiedrowicz
2009-07-12 18:27 ` Junio C Hamano
2009-07-12 18:37 ` Michał Kiedrowicz
2009-07-12 21:34 ` Junio C Hamano
2009-07-12 23:37 ` Stephen Boyd
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4A598E03.10204@gmail.com \
--to=bebarino@gmail.com \
--cc=git@vger.kernel.org \
--cc=michal.kiedrowicz@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).