public inbox for git@vger.kernel.org
 help / color / mirror / Atom feed
From: "Yoann Valeri via GitGitGadget" <gitgitgadget@gmail.com>
To: git@vger.kernel.org
Cc: Patrick Steinhardt <ps@pks.im>,
	Junio C Hamano <gitster@pobox.com>,
	Yoann Valeri <yoann.valeri@cea.fr>,
	Yoann Valeri <yoann.valeri@cea.fr>
Subject: [PATCH v3 0/3] branch: add prefixes to new branch names
Date: Fri, 06 Mar 2026 13:14:29 +0000	[thread overview]
Message-ID: <pull.2202.v3.git.git.1772802872.gitgitgadget@gmail.com> (raw)
In-Reply-To: <pull.2202.v2.git.git.1772207333.gitgitgadget@gmail.com>

This PR adds a way to add prefixes to a new branch being created. The goal
is mostly to ease the developer process of creating new branches by adding
shortcuts that can be set either with a command-line option or with
configuration parameter. This is useful especially when you have to do
similar backports on multiple branches, removing a bit of the need for
finding names or typing the names over and over again.

Changes since v1:

 * Added a '--no-prefix' option to git branch

Changes since v2:

 * Changed the PR structure, with 3 patches:
   * first patch adds the '--name-prefix' option
   * second adds the 'branch.namePrefix' configuration parameter
   * third adds the '--no-name-prefix' option
 * Those patches only target 'git branch' now

VALERI Yoann (3):
  branch: add '--name-prefix' option
  branch: add 'branch.namePrefix' config param
  branch: add '--no-name-prefix' option

 Documentation/config/branch.adoc |  5 +++++
 Documentation/git-branch.adoc    | 11 ++++++++++-
 branch.c                         | 21 ++++++++++++++++++++
 branch.h                         | 12 +++++++++++
 builtin/branch.c                 | 25 +++++++++++++++--------
 t/t3200-branch.sh                | 34 ++++++++++++++++++++++++++++++++
 6 files changed, 99 insertions(+), 9 deletions(-)


base-commit: 2cc71917514657b93014134350864f4849edfc83
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-git-2202%2Fvaleriyoann%2Fbranch-with-prefix-v3
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-git-2202/valeriyoann/branch-with-prefix-v3
Pull-Request: https://github.com/git/git/pull/2202

Range-diff vs v2:

 1:  49641fb34c ! 1:  6cbb950d8b branch: add 'branch.addCurrentBranchAsPrefix' config param
     @@ Metadata
      Author: VALERI Yoann <yoann.valeri@cea.fr>
      
       ## Commit message ##
     -    branch: add 'branch.addCurrentBranchAsPrefix' config param
     +    branch: add '--name-prefix' option
      
     -    This patch adds a new configuration parameter for the branch creation
     -    feature: 'branch.addCurrentBranchAsPrefix'. When set to true, if one
     -    creates a new branch with either `git branch`, `git checkout -[bB]` or
     -    `git switch -[cC]`, we will now retrieve the current branch's name, and
     -    use it as prefix for the name of the newly created branch, alongside a
     -    hyphen separating the two.
     -
     -    For instance, using this parameter, and attempting to create a branch
     -    'test' while on the 'main' branch will instead create a branch
     -    'main-test'.
     -
     -    This parameters is useful for projects handling many branches, with
     -    features often needing backport on different branches, so as to reduce
     -    the time taken to create branches without having to come up with clever
     -    names.
     +    This patch adds a '--name-prefix' option to add a prefix to a newly
     +    created branch. It can use a regular string or a token as prefix. The
     +    only token currently handled is '@{current}', which is substituted for
     +    the current branch's name.
      
          Signed-off-by: VALERI Yoann <yoann.valeri@cea.fr>
      
     - ## Documentation/config/branch.adoc ##
     -@@ Documentation/config/branch.adoc: This option defaults to `never`.
     - 	value of this variable will be used as the default.
     - 	See linkgit:git-for-each-ref[1] field names for valid values.
     - 
     -+`branch.addCurrentBranchAsPrefix`::
     -+	When a new branch is created with `git branch`, `git switch` or `git
     -+	checkout` use the name of the current branch as a prefix for the new
     -+	branch's name, alongside the one provided by the user, with a hyphen in the
     -+	middle. For instance, using this configuration variable, creating the branch
     -+	`test` while on `main` will create the branch `main-test`. False by default.
     -+
     - `branch.<name>.remote`::
     - 	When on branch _<name>_, it tells `git fetch` and `git push`
     - 	which remote to fetch from or push to.  The remote to push to
     + ## Documentation/git-branch.adoc ##
     +@@ Documentation/git-branch.adoc: git branch [--color[=<when>] | --no-color] [--show-current]
     + 	   [(-r|--remotes) | (-a|--all)]
     + 	   [--list] [<pattern>...]
     + git branch [--track[=(direct|inherit)] | --no-track] [-f]
     +-	   [--recurse-submodules] <branch-name> [<start-point>]
     ++	   [--recurse-submodules] [--name-prefix=<token>]
     ++           <branch-name> [<start-point>]
     + git branch (--set-upstream-to=<upstream>|-u <upstream>) [<branch-name>]
     + git branch --unset-upstream [<branch-name>]
     + git branch (-m|-M) [<old-branch>] <new-branch>
     +@@ Documentation/git-branch.adoc: Note that this will create the new branch, but it will not switch the
     + working tree to it; use `git switch <new-branch>` to switch to the
     + new branch.
     + 
     ++With a `--name-prefix` option, you can add a prefix to the branch to create.
     ++This can either a simple name, or a token. Currently, only '@{current}' is
     ++managed as token, and will use the current branch name as prefix.
     ++
     + When a local branch is started off a remote-tracking branch, Git sets up the
     + branch (specifically the `branch.<name>.remote` and `branch.<name>.merge`
     + configuration entries) so that `git pull` will appropriately merge from
     +@@ Documentation/git-branch.adoc: superproject's "origin/main", but tracks the submodule's "origin/main".
     + 	and the object it points at.  _<format>_ is the same as
     + 	that of linkgit:git-for-each-ref[1].
     + 
     ++`--name-prefix <token>`::
     ++	A string that will be used as prefix to the name of the new branch to
     ++        create. Can be '@{current}' to use the current branch's name.
     ++
     + _<branch-name>_::
     + 	The name of the branch to create or delete.
     + 	The new branch name must pass all checks defined by
      
       ## branch.c ##
      @@ branch.c: int read_branch_desc(struct strbuf *buf, const char *branch_name)
       	return 0;
       }
       
     -+void add_branch_prefix(const char *current_branch,
     -+					   const char *target_branch, struct strbuf *buf)
     ++void add_branch_prefix(const char *name_prefix,
     ++					   const char *current_branch, struct strbuf *buf)
      +{
      +	int value = 0;
      +
     -+	repo_config_get_bool(the_repository,
     -+						 "branch.addCurrentBranchAsPrefix", &value);
     ++	if (!name_prefix)
     ++		return;
      +
     -+	if (value)
     -+		strbuf_addf(buf, "%s-%s", current_branch, target_branch);
     -+	else
     -+		strbuf_addstr(buf, target_branch);
     ++	if (name_prefix[0] != '@') {
     ++		strbuf_addstr(buf, name_prefix);
     ++		return;
     ++	}
     ++
     ++	if (strcmp(name_prefix, "@{current}") == 0)
     ++		strbuf_addstr(buf, current_branch);
      +}
      +
       /*
     @@ branch.h: int install_branch_config(int flag, const char *local, const char *ori
       int read_branch_desc(struct strbuf *, const char *branch_name);
       
      +/*
     -+ * Fetch the configuration parameter 'branch.addCurrentBranchAsPrefix' and
     -+ * fill the buffer 'buf' with '<current_branch>-<target_branch>' if true,
     -+ * otherwise just '<current_branch>'.
     ++ * Store in 'buf' a prefix to the name of a branch to create by using the given
     ++ * string 'name_prefix'. It can either be a simple string to a shorthand
     ++ * starting with '@'.
     ++ *
     ++ * Currently, only '@{current}' is managed, and will use 'current_branch' as
     ++ * prefix.
      + */
     -+void add_branch_prefix(const char *current_branch,
     -+					   const char *target_branch, struct strbuf *buf);
     ++void add_branch_prefix(const char *name_prefix, const char *current_branch,
     ++					   struct strbuf *buf);
     ++
      +
       /*
        * Check if a branch is checked out in the main worktree or any linked
        * worktree and die (with a message describing its checkout location) if
      
       ## builtin/branch.c ##
     +@@ builtin/branch.c: int cmd_branch(int argc,
     + 	struct string_list sorting_options = STRING_LIST_INIT_DUP;
     + 	struct ref_format format = REF_FORMAT_INIT;
     + 	int ret;
     ++	const char *name_prefix = NULL;
     + 
     + 	struct option options[] = {
     + 		OPT_GROUP(N_("Generic options")),
     +@@ builtin/branch.c: int cmd_branch(int argc,
     + 		OPT_BOOL('i', "ignore-case", &icase, N_("sorting and filtering are case insensitive")),
     + 		OPT_BOOL(0, "recurse-submodules", &recurse_submodules_explicit, N_("recurse through submodules")),
     + 		OPT_STRING(  0 , "format", &format.format, N_("format"), N_("format to use for the output")),
     ++		OPT_STRING(0, "name-prefix", &name_prefix, N_("name"), N_("prefix for the branch to create")),
     + 		OPT_END(),
     + 	};
     + 
      @@ builtin/branch.c: int cmd_branch(int argc,
       	} else if (!noncreate_actions && argc > 0 && argc <= 2) {
       		const char *branch_name = argv[0];
     @@ builtin/branch.c: int cmd_branch(int argc,
       
      -		if (recurse_submodules) {
      -			create_branches_recursively(the_repository, branch_name,
     -+		add_branch_prefix(start_name, branch_name, &new_branch_name);
     ++		add_branch_prefix(name_prefix, start_name, &new_branch_name);
     ++		strbuf_addstr(&new_branch_name, branch_name);
      +
      +		if (recurse_submodules)
      +			create_branches_recursively(the_repository, new_branch_name.buf,
     @@ builtin/branch.c: int cmd_branch(int argc,
       		usage_with_options(builtin_branch_usage, options);
       
      
     - ## builtin/checkout.c ##
     -@@ builtin/checkout.c: static void orphaned_commit_warning(struct commit *old_commit, struct commit *ne
     - 	release_revisions(&revs);
     - }
     - 
     -+static void get_current_branch_info(struct branch_info *branch_info)
     -+{
     -+	struct object_id rev;
     -+	int flag;
     -+
     -+	branch_info->path = refs_resolve_refdup(get_main_ref_store(the_repository),
     -+											"HEAD", 0, &rev, &flag);
     -+
     -+	if (branch_info->path)
     -+		branch_info->commit = lookup_commit_reference_gently(the_repository,
     -+															 &rev, 1);
     -+
     -+	if (!(flag & REF_ISSYMREF))
     -+		FREE_AND_NULL(branch_info->path);
     -+
     -+	if (branch_info->path) {
     -+		const char *const prefix = "refs/heads/";
     -+		const char *p;
     -+
     -+		if (skip_prefix(branch_info->path, prefix, &p))
     -+			branch_info->name = xstrdup(p);
     -+	}
     -+}
     -+
     - static int switch_branches(const struct checkout_opts *opts,
     - 			   struct branch_info *new_branch_info)
     - {
     - 	int ret = 0;
     - 	struct branch_info old_branch_info = { 0 };
     --	struct object_id rev;
     --	int flag, writeout_error = 0;
     -+	int writeout_error = 0;
     - 	int do_merge = 1;
     - 
     - 	trace2_cmd_mode("branch");
     - 
     - 	memset(&old_branch_info, 0, sizeof(old_branch_info));
     --	old_branch_info.path = refs_resolve_refdup(get_main_ref_store(the_repository),
     --						   "HEAD", 0, &rev, &flag);
     --	if (old_branch_info.path)
     --		old_branch_info.commit = lookup_commit_reference_gently(the_repository, &rev, 1);
     --	if (!(flag & REF_ISSYMREF))
     --		FREE_AND_NULL(old_branch_info.path);
     --
     --	if (old_branch_info.path) {
     --		const char *const prefix = "refs/heads/";
     --		const char *p;
     --		if (skip_prefix(old_branch_info.path, prefix, &p))
     --			old_branch_info.name = xstrdup(p);
     --	}
     -+	get_current_branch_info(&old_branch_info);
     - 
     - 	if (opts->new_orphan_branch && opts->orphan_from_empty_tree) {
     - 		if (new_branch_info->name)
     -@@ builtin/checkout.c: static int checkout_main(int argc, const char **argv, const char *prefix,
     - 	int parseopt_flags = 0;
     - 	struct branch_info new_branch_info = { 0 };
     - 	int ret;
     -+	struct strbuf full_branch_name = { 0 };
     - 
     - 	opts->overwrite_ignore = 1;
     - 	opts->prefix = prefix;
     -@@ builtin/checkout.c: static int checkout_main(int argc, const char **argv, const char *prefix,
     - 	}
     - 
     - 	if (opts->new_branch) {
     -+		struct branch_info current_branch = { 0 };
     - 		struct strbuf buf = STRBUF_INIT;
     -+		strbuf_init(&full_branch_name, 0);
     -+
     -+		get_current_branch_info(&current_branch);
     -+		add_branch_prefix(current_branch.name, opts->new_branch,
     -+						  &full_branch_name);
     -+		branch_info_release(&current_branch);
     -+		opts->new_branch = full_branch_name.buf;
     - 
     - 		if (opts->new_branch_force)
     - 			opts->branch_exists = validate_branchname(opts->new_branch, &buf);
     -@@ builtin/checkout.c: static int checkout_main(int argc, const char **argv, const char *prefix,
     - 	clear_pathspec(&opts->pathspec);
     - 	free(opts->pathspec_from_file);
     - 	free(options);
     -+	if (full_branch_name.buf)
     -+		strbuf_release(&full_branch_name);
     - 
     - 	return ret;
     - }
     -
     - ## t/t2018-checkout-branch.sh ##
     -@@ t/t2018-checkout-branch.sh: test_expect_success 'checkout -b rejects an extra path argument' '
     - 	test_grep "Cannot update paths and switch to branch" err
     - '
     - 
     -+test_expect_success 'checkout -b with prefix is valid' '
     -+	git checkout -b main &&
     -+	git checkout -b checkoutb-with-prefix &&
     -+	git checkout main &&
     -+	test_config branch.addCurrentBranchAsPrefix false &&
     -+	test_must_fail git checkout -b checkoutb-with-prefix &&
     -+	test_config branch.addCurrentBranchAsPrefix true &&
     -+	git checkout -b checkoutb-with-prefix &&
     -+	git checkout -b checkoutb-with-prefix &&
     -+	test_ref_exists refs/heads/checkoutb-with-prefix &&
     -+	test_ref_exists refs/heads/main-checkoutb-with-prefix &&
     -+	test_ref_exists refs/heads/main-checkoutb-with-prefix-checkoutb-with-prefix
     -+'
     -+
     -+test_expect_success 'checkout -B with prefix is valid' '
     -+	git checkout main &&
     -+	git checkout -B checkoutB-with-prefix &&
     -+	git checkout main &&
     -+	test_config branch.addCurrentBranchAsPrefix false &&
     -+	git checkout -B checkoutB-with-prefix &&
     -+	test_config branch.addCurrentBranchAsPrefix true &&
     -+	git checkout -B checkoutB-with-prefix &&
     -+	test_ref_exists refs/heads/checkoutB-with-prefix &&
     -+	test_ref_exists refs/heads/checkoutB-with-prefix-checkoutB-with-prefix
     -+'
     -+
     - test_done
     -
     - ## t/t2060-switch.sh ##
     -@@ t/t2060-switch.sh: test_expect_success 'switch back when temporarily detached and checked out elsew
     - 	git -C wt2 switch --ignore-other-worktrees shared
     - '
     - 
     -+test_expect_success 'switch -c with prefix is valid' '
     -+	git switch main &&
     -+	git switch -c switchc-with-prefix &&
     -+	git checkout main &&
     -+	test_config branch.addCurrentBranchAsPrefix false &&
     -+	test_must_fail git switch -c switchc-with-prefix &&
     -+	test_config branch.addCurrentBranchAsPrefix true &&
     -+	git switch -c switchc-with-prefix &&
     -+	git switch -c switchc-with-prefix &&
     -+	test_ref_exists refs/heads/switchc-with-prefix &&
     -+	test_ref_exists refs/heads/main-switchc-with-prefix &&
     -+	test_ref_exists refs/heads/main-switchc-with-prefix-switchc-with-prefix
     -+'
     -+
     -+test_expect_success 'switch -C with prefix is valid' '
     -+	git switch main &&
     -+	git switch -C switchC-with-prefix &&
     -+	git checkout main &&
     -+	test_config branch.addCurrentBranchAsPrefix false &&
     -+	git switch -C switchC-with-prefix &&
     -+	test_config branch.addCurrentBranchAsPrefix true &&
     -+	git switch -C switchC-with-prefix &&
     -+	test_ref_exists refs/heads/switchC-with-prefix &&
     -+	test_ref_exists refs/heads/switchC-with-prefix-switchC-with-prefix
     -+'
     -+
     - test_done
     -
       ## t/t3200-branch.sh ##
      @@ t/t3200-branch.sh: test_expect_success 'errors if given a bad branch name' '
       	test_cmp expect actual
       '
       
     -+test_expect_success 'create branch with prefix' '
     ++test_expect_success 'create branch with --name-prefix' '
      +	git config branch.autosetupmerge false &&
      +	git branch branch-with-prefix &&
     -+	test_config branch.addCurrentBranchAsPrefix false &&
     -+	test_must_fail git branch branch-with-prefix &&
     -+	test_config branch.addCurrentBranchAsPrefix true &&
     -+	git branch branch-with-prefix &&
     -+	git checkout branch-with-prefix &&
     -+	git branch branch-with-prefix &&
     ++	git branch --name-prefix "blob" -- -with-prefix &&
     ++	test_must_fail git branch --name-prefix "blob" -- -with-prefix &&
     ++	git branch --name-prefix "@{current}" -- -with-prefix &&
     ++	git switch blob-with-prefix &&
     ++	git branch --name-prefix "@{current}" -- -with-prefix &&
     ++	test_must_fail git branch --name-prefix "@{current}" -- -with-prefix &&
      +	test_ref_exists refs/heads/branch-with-prefix &&
     -+	test_ref_exists refs/heads/main-branch-with-prefix &&
     -+	test_ref_exists refs/heads/branch-with-prefix-branch-with-prefix
     ++	test_ref_exists refs/heads/main-with-prefix &&
     ++	test_ref_exists refs/heads/blob-with-prefix &&
     ++	test_ref_exists refs/heads/blob-with-prefix-with-prefix &&
     ++	git checkout main &&
     ++	git branch -D branch-with-prefix main-with-prefix blob-with-prefix &&
     ++	git branch -D blob-with-prefix-with-prefix
      +'
      +
       test_done
 -:  ---------- > 2:  d51f71708c branch: add 'branch.namePrefix' config param
 2:  0fbdf031cb ! 3:  8f45374007 branch: add a no-prefix option
     @@ Metadata
      Author: VALERI Yoann <yoann.valeri@cea.fr>
      
       ## Commit message ##
     -    branch: add a no-prefix option
     +    branch: add '--no-name-prefix' option
      
     -    This patch adds a '--no-prefix' option to 'git branch' to selectively
     -    override the 'branch.addCurrentBranchAsPrefix' configuration parameter.
     +    This patch adds the '--no-name-prefix' option to prevent adding any
     +    prefix to the branch being created, whether through the '--name-prefix'
     +    option or the 'branch.namePrefix' configuration parameter.
          Signed-off-by: VALERI Yoann <yoann.valeri@cea.fr>
      
       ## builtin/branch.c ##
     @@ builtin/branch.c: int cmd_branch(int argc,
       	int delete = 0, rename = 0, copy = 0, list = 0,
      -	    unset_upstream = 0, show_current = 0, edit_description = 0;
      +	    unset_upstream = 0, show_current = 0, edit_description = 0,
     -+	    no_prefix = 0;
     ++		no_name_prefix = 0;
       	const char *new_upstream = NULL;
       	int noncreate_actions = 0;
       	/* possible options */
     @@ builtin/branch.c: int cmd_branch(int argc,
       		OPT_BOOL('i', "ignore-case", &icase, N_("sorting and filtering are case insensitive")),
       		OPT_BOOL(0, "recurse-submodules", &recurse_submodules_explicit, N_("recurse through submodules")),
       		OPT_STRING(  0 , "format", &format.format, N_("format"), N_("format to use for the output")),
     -+		OPT_BOOL(0, "no-prefix", &no_prefix, N_("do not add a prefix to the branch being created")),
     +-		OPT_STRING(0, "name-prefix", &name_prefix, N_("name"), N_("prefix for the branch to create")),
     ++		OPT_STRING_F(0, "name-prefix", &name_prefix, N_("name"), N_("prefix for the branch to create"), PARSE_OPT_NONEG),
     ++		OPT_BOOL(0, "no-name-prefix", &no_name_prefix, N_("do not use any prefix for the branch to create")),
       		OPT_END(),
       	};
       
     @@ builtin/branch.c: int cmd_branch(int argc,
       		if (track == BRANCH_TRACK_OVERRIDE)
       			die(_("the '--set-upstream' option is no longer supported. Please use '--track' or '--set-upstream-to' instead"));
       
     --		add_branch_prefix(start_name, branch_name, &new_branch_name);
     -+		if (!no_prefix)
     -+			add_branch_prefix(start_name, branch_name, &new_branch_name);
     -+		else
     -+			strbuf_addstr(&new_branch_name, branch_name);
     +-		add_branch_prefix(name_prefix, start_name, &new_branch_name);
     ++		if (!no_name_prefix)
     ++			add_branch_prefix(name_prefix, start_name, &new_branch_name);
     + 		strbuf_addstr(&new_branch_name, branch_name);
       
       		if (recurse_submodules)
     - 			create_branches_recursively(the_repository, new_branch_name.buf,
      
       ## t/t3200-branch.sh ##
     -@@ t/t3200-branch.sh: test_expect_success 'create branch with prefix' '
     - 	git branch branch-with-prefix &&
     - 	git checkout branch-with-prefix &&
     - 	git branch branch-with-prefix &&
     -+	git branch branch-with-no-prefix --no-prefix &&
     +@@ t/t3200-branch.sh: test_expect_success 'create branch with --name-prefix' '
     + 	git switch blob-with-prefix &&
     + 	git branch --name-prefix "@{current}" -- -with-prefix &&
     + 	test_must_fail git branch --name-prefix "@{current}" -- -with-prefix &&
     ++	git branch --name-prefix "blob" --no-name-prefix branch-with-no-prefix &&
       	test_ref_exists refs/heads/branch-with-prefix &&
     - 	test_ref_exists refs/heads/main-branch-with-prefix &&
     --	test_ref_exists refs/heads/branch-with-prefix-branch-with-prefix
     -+	test_ref_exists refs/heads/branch-with-prefix-branch-with-prefix &&
     -+	test_ref_exists refs/heads/branch-with-no-prefix
     + 	test_ref_exists refs/heads/main-with-prefix &&
     + 	test_ref_exists refs/heads/blob-with-prefix &&
     + 	test_ref_exists refs/heads/blob-with-prefix-with-prefix &&
     ++	test_ref_exists refs/heads/branch-with-no-prefix &&
     + 	git checkout main &&
     + 	git branch -D branch-with-prefix main-with-prefix blob-with-prefix &&
     +-	git branch -D blob-with-prefix-with-prefix
     ++	git branch -D blob-with-prefix-with-prefix branch-with-no-prefix
     + '
     + 
     + test_expect_success 'create branch with config prefix' '
     +@@ t/t3200-branch.sh: test_expect_success 'create branch with config prefix' '
     + 	test_config branch.namePrefix "@{current}" &&
     + 	git checkout main &&
     + 	git branch -- -with-prefix &&
     ++	git branch --no-name-prefix branch-with-no-prefix &&
     + 	test_ref_exists refs/heads/blob-with-prefix &&
     + 	test_ref_exists refs/heads/main-with-prefix &&
     +-	git branch -D blob-with-prefix main-with-prefix
     ++	test_ref_exists refs/heads/branch-with-no-prefix &&
     ++	git branch -D blob-with-prefix main-with-prefix branch-with-no-prefix
       '
       
       test_done

-- 
gitgitgadget

  parent reply	other threads:[~2026-03-06 13:14 UTC|newest]

Thread overview: 18+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-02-20  8:07 [PATCH] branch: add 'branch.addCurrentBranchAsPrefix' config param Yoann Valeri via GitGitGadget
2026-02-20 15:59 ` Junio C Hamano
2026-02-20 16:08 ` Junio C Hamano
2026-02-27 15:48 ` [PATCH v2 0/2] " Yoann Valeri via GitGitGadget
2026-02-27 15:48   ` [PATCH v2 1/2] " VALERI Yoann via GitGitGadget
2026-02-27 15:48   ` [PATCH v2 2/2] branch: add a no-prefix option VALERI Yoann via GitGitGadget
2026-02-27 17:07     ` Junio C Hamano
2026-03-06 13:14   ` Yoann Valeri via GitGitGadget [this message]
2026-03-06 13:14     ` [PATCH v3 1/3] branch: add '--name-prefix' option VALERI Yoann via GitGitGadget
2026-03-07  7:06       ` Eric Sunshine
2026-03-08  7:06       ` Junio C Hamano
2026-03-06 13:14     ` [PATCH v3 2/3] branch: add 'branch.namePrefix' config param VALERI Yoann via GitGitGadget
2026-03-07  7:07       ` Eric Sunshine
2026-03-06 13:14     ` [PATCH v3 3/3] branch: add '--no-name-prefix' option VALERI Yoann via GitGitGadget
2026-03-06 21:38       ` Junio C Hamano
2026-03-06 21:01     ` [PATCH v3 0/3] branch: add prefixes to new branch names Junio C Hamano
2026-03-07  7:05     ` Eric Sunshine
2026-03-08  6:48       ` Junio C Hamano

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=pull.2202.v3.git.git.1772802872.gitgitgadget@gmail.com \
    --to=gitgitgadget@gmail.com \
    --cc=git@vger.kernel.org \
    --cc=gitster@pobox.com \
    --cc=ps@pks.im \
    --cc=yoann.valeri@cea.fr \
    /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