From: Johannes Schindelin <Johannes.Schindelin@gmx.de>
To: Paolo Bonzini <paolo.bonzini@gmail.com>
Cc: Junio C Hamano <junkio@cox.net>, Alex Riesen <raa.lkml@gmail.com>,
Julian Phillips <julian@quantumfyre.co.uk>,
Andy Parkins <andyparkins@gmail.com>,
git@vger.kernel.org
Subject: Re: [PATCH] defaults for where to merge from (take 3, inline)
Date: Thu, 1 Mar 2007 23:01:14 +0100 (CET) [thread overview]
Message-ID: <Pine.LNX.4.63.0703012240210.22628@wbgn013.biozentrum.uni-wuerzburg.de> (raw)
In-Reply-To: <45E70041.1030705@lu.unisi.ch>
Hi,
please don't take my comments as insults or even strict rules. It is
purely for your consideration. (I say this because I haven't seen you so
often on this list, so you might not know that discussions about patches
are sometimes, erm, lively...)
On Thu, 1 Mar 2007, Paolo Bonzini wrote:
> > (2) by reviewing the changes to the .config writer. That
> > traditionally has been one of the more fragile parts of the
> > system, and I am reluctant to look at it.
>
> Just FYI, this was broken into a separate patch.
>
> > I would just feel better to see a patch like this, which is a
> > significant improvement to the system, to be properly signed-off
> > by the submitter.
>
> I hope this is better, I tried to follow the steps in
> SubmittingPatches properly. The code is actually the same
> as take 3.
According to SubmittingPatches, this is a cover letter.
You often want to add additional explanation about the patch,
other than the commit message itself. Place such "cover letter"
material between the three dash lines and the diffstat.
So, please put it after the three dashes and the diffstat next time.
> * git-branch: register where to merge from, when branching off a remote branch.
This is the oneline description, which should have been the Subject of the
mail, preferably prefixed by "[PATCH]" to make it obvious that it is not
yet another reply in a medium-sized thread, but actually a code
contribution. SubmittingPatches is not clear about this: you can write
_anything_ in brackets, and it will be stripped from the commit message
automatically. In your case, I would have preferred "[PATCH, 3rd
version]".
> A rather standard (in 1.5) procedure for branching off a remote archive is:
Since this will go into the commit message, which is usually shown in the
output of "git log", indented, it would be nice to break lines early.
Again, I think that SubmittingPatches is not totally clear about this: I
try to maintain a maximum width of 76 characters (which seems to be the
default with pine -- my mail program -- anyway).
> The behavior is controlled by core.trackremotebranches,
I'd make it obvious here that it is on by default -- even if you state
that earlier, too.
[I leave comments on documentation to others, since I cannot write them
myself.]
> diff --git a/builtin-branch.c b/builtin-branch.c
> index d0179b0..20de049 100644
> --- a/builtin-branch.c
> +++ b/builtin-branch.c
> @@ -12,7 +12,7 @@
> #include "builtin.h"
>
> static const char builtin_branch_usage[] =
> - "git-branch [-r] (-d | -D) <branchname> | [-l] [-f] <branchname> [<start-point>] | (-m | -M) [<oldbranch>] <newbranch> | [--color | --no-color] [-r | -a] [-v [--abbrev=<length>]]";
> + "git-branch [-r] (-d | -D) <branchname> | [--track | --no-track] [-l] [-f] <branchname> [<start-point>] | (-m | -M) [<oldbranch>] <newbranch> | [--color | --no-color] [-r | -a] [-v [--abbrev=<length>]]";
>
> #define REF_UNKNOWN_TYPE 0x00
> #define REF_LOCAL_BRANCH 0x01
> @@ -308,15 +307,36 @@ static void print_ref_list(int kinds, int detached, int verbose, int abbrev)
> free_ref_list(&ref_list);
> }
>
> +static void register_branch_pull (const char *name, const char *remote_name)
It is not yet remote_name, right? it is branch_name. You extract the
remote_name by finding the first slash.
> +{
> + char *slash = strchr(remote_name, '/');
> +
> + char *config_key = xmalloc(strlen(name) + 15);
> + char *merge_value = xmalloc(strlen(remote_name) + 10);
> +
> + char *remote_value = xstrdup(remote_name);
I'd use "char key[1024], value[1024]" instead, erroring out if one of the
buffers are too small. It's not like you have to be memory efficient, and
it is easier to read.
> + remote_value[slash - remote_name] = 0;
You should check if slash == NULL and error out before using it.
> + sprintf(config_key, "branch.%s.remote", name);
This would be a snprintf(key, sizeof(key), "branch.%s.remote", name); and
snprintf(value, sizeof(value), "%.*s", slash - branch_name, branch_name);
> + git_config_set(config_key, remote_value);
> +
> + sprintf(merge_value, "refs/heads/%s", slash + 1);
> + sprintf(config_key, "branch.%s.merge", name);
> + git_config_set(config_key, merge_value);
> +
> + free (config_key);
> + free (remote_value);
> + free (merge_value);
> +}
> +
> static void create_branch(const char *name, const char *start_name,
> unsigned char *start_sha1,
> - int force, int reflog)
> + int force, int reflog, int track)
> {
> struct ref_lock *lock;
> struct commit *commit;
> unsigned char sha1[20];
> - char ref[PATH_MAX], msg[PATH_MAX + 20];
> - int forcing = 0;
> + char *real_ref = NULL, ref[PATH_MAX], msg[PATH_MAX + 20];
> + int forcing = 0, remote = 0;
>
> snprintf(ref, sizeof ref, "refs/heads/%s", name);
> if (check_ref_format(ref))
> @@ -333,7 +353,9 @@ static void create_branch(const char *name, const char *start_name,
> if (start_sha1)
> /* detached HEAD */
> hashcpy(sha1, start_sha1);
> - else if (get_sha1(start_name, sha1))
> + else if (dwim_ref(start_name, strlen (start_name), sha1, &real_ref))
> + remote = !prefixcmp(real_ref, "refs/remotes/");
> + else
> die("Not a valid object name: '%s'.", start_name);
Yes, that is how I imagined it. The rest of your patch looks perfect to
me.
Ciao,
Dscho
next prev parent reply other threads:[~2007-03-01 22:01 UTC|newest]
Thread overview: 48+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-02-28 14:53 defaults for where to merge from Paolo Bonzini
2007-02-28 15:13 ` Johannes Schindelin
2007-02-28 15:22 ` Andy Parkins
2007-02-28 15:30 ` Paolo Bonzini
2007-02-28 15:43 ` Andy Parkins
2007-02-28 15:30 ` Julian Phillips
2007-02-28 15:46 ` Johannes Schindelin
2007-02-28 17:11 ` Paolo Bonzini
2007-02-28 18:06 ` Johannes Schindelin
2007-03-01 7:52 ` [PATCH] defaults for where to merge from (take 2) Paolo Bonzini
2007-02-28 18:45 ` defaults for where to merge from Alex Riesen
2007-02-28 19:56 ` Paolo Bonzini
2007-03-01 0:07 ` Alex Riesen
2007-03-01 1:25 ` Johannes Schindelin
2007-03-01 7:55 ` Alex Riesen
2007-03-01 8:02 ` Paolo Bonzini
2007-03-01 8:10 ` Alex Riesen
2007-03-01 8:18 ` Junio C Hamano
2007-03-02 15:53 ` J. Bruce Fields
2007-03-01 8:29 ` Paolo Bonzini
2007-03-01 8:33 ` Alex Riesen
2007-03-01 8:45 ` Paolo Bonzini
2007-03-01 8:59 ` Alex Riesen
2007-03-01 9:37 ` [PATCH] defaults for where to merge from (take 3) Paolo Bonzini
2007-03-01 10:12 ` Alex Riesen
2007-03-01 10:17 ` Paolo Bonzini
2007-03-01 10:27 ` Junio C Hamano
2007-03-01 10:42 ` Alex Riesen
2007-03-02 4:49 ` Junio C Hamano
2007-03-02 9:05 ` Alex Riesen
2007-03-02 9:57 ` Junio C Hamano
2007-03-01 10:47 ` Alex Riesen
2007-03-01 16:33 ` [PATCH] defaults for where to merge from (take 3, inline) Paolo Bonzini
2007-03-01 22:01 ` Johannes Schindelin [this message]
2007-03-02 8:10 ` Paolo Bonzini
2007-03-02 8:50 ` [PATCH, 4th version] git-branch: register where to merge from, when branching off a remote branch Paolo Bonzini
2007-03-02 9:52 ` Junio C Hamano
2007-03-02 9:55 ` Junio C Hamano
2007-03-02 10:32 ` Jeff King
2007-03-02 11:15 ` Paolo Bonzini
2007-03-02 11:21 ` Jeff King
2007-03-02 11:14 ` Paolo Bonzini
2007-03-02 15:54 ` Johannes Schindelin
2007-03-02 16:33 ` Paolo Bonzini
2007-03-02 19:06 ` Johannes Schindelin
2007-03-02 11:19 ` [PATCH] defaults for where to merge from (take 3, inline) Johannes Schindelin
2007-03-02 14:10 ` Jakub Narebski
2007-02-28 17:31 ` defaults for where to merge from Peter Baumann
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=Pine.LNX.4.63.0703012240210.22628@wbgn013.biozentrum.uni-wuerzburg.de \
--to=johannes.schindelin@gmx.de \
--cc=andyparkins@gmail.com \
--cc=git@vger.kernel.org \
--cc=julian@quantumfyre.co.uk \
--cc=junkio@cox.net \
--cc=paolo.bonzini@gmail.com \
--cc=raa.lkml@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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.