summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 1c107dc)
raw | patch | inline | side by side (parent: 1c107dc)
author | Linus Torvalds <torvalds@ppc970.osdl.org> | |
Sun, 19 Jun 2005 17:40:10 +0000 (10:40 -0700) | ||
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | |
Sun, 19 Jun 2005 17:40:10 +0000 (10:40 -0700) |
But warn about them. If somebody really ends up later wanting to
explicitly add a note that something has the same parent twice (who
knows, there are strange people around), we can add a flag to say that
it's expected and ok.
This was brought on by a commit in the kernel tree, where a repeated
merge caused a duplicate parent.
Parent duplicates aren't "wrong" per se, they're just in practice not
something you are ever interested in.
explicitly add a note that something has the same parent twice (who
knows, there are strange people around), we can add a flag to say that
it's expected and ok.
This was brought on by a commit in the kernel tree, where a repeated
merge caused a duplicate parent.
Parent duplicates aren't "wrong" per se, they're just in practice not
something you are ever interested in.
commit-tree.c | patch | blob | history |
diff --git a/commit-tree.c b/commit-tree.c
index 1d125b8412f0eff6576e8c91343bbf8d9726247d..0d504e7e4be10083da6e677bbcb95bc186fc6277 100644 (file)
--- a/commit-tree.c
+++ b/commit-tree.c
* how multi-way merges are represented.
*/
#define MAXPARENT (16)
+static unsigned char parent_sha1[MAXPARENT][20];
static char *commit_tree_usage = "git-commit-tree <sha1> [-p <sha1>]* < changelog";
+static int new_parent(int idx)
+{
+ int i;
+ unsigned char *sha1 = parent_sha1[idx];
+ for (i = 0; i < idx; i++) {
+ if (!memcmp(parent_sha1[i], sha1, 20)) {
+ error("duplicate parent %s ignored", sha1_to_hex(sha1));
+ return 0;
+ }
+ }
+ return 1;
+}
+
int main(int argc, char **argv)
{
int i, len;
int parents = 0;
unsigned char tree_sha1[20];
- unsigned char parent_sha1[MAXPARENT][20];
unsigned char commit_sha1[20];
char *gecos, *realgecos, *commitgecos;
char *email, *commitemail, realemail[1000];
if (!b || strcmp(a, "-p") || get_sha1(b, parent_sha1[parents]))
usage(commit_tree_usage);
check_valid(parent_sha1[parents], "commit");
- parents++;
+ if (new_parent(parents))
+ parents++;
}
if (!parents)
fprintf(stderr, "Committing initial tree %s\n", argv[1]);