|
|
|
/*
|
|
|
|
* GIT - The information manager from hell
|
|
|
|
*
|
|
|
|
* Copyright (C) Linus Torvalds, 2005
|
|
|
|
*/
|
|
|
|
#include "builtin.h"
|
|
|
|
#include "cache.h"
|
|
|
|
#include "tree.h"
|
|
|
|
#include "cache-tree.h"
|
|
|
|
|
|
|
|
static const char write_tree_usage[] =
|
|
|
|
"git write-tree [--missing-ok] [--prefix=<prefix>/]";
|
|
|
|
|
|
|
|
int cmd_write_tree(int argc, const char **argv, const char *unused_prefix)
|
|
|
|
{
|
|
|
|
int flags = 0, ret;
|
|
|
|
const char *prefix = NULL;
|
|
|
|
unsigned char sha1[20];
|
|
|
|
const char *me = "git-write-tree";
|
|
|
|
|
|
|
|
git_config(git_default_config, NULL);
|
|
|
|
while (1 < argc) {
|
|
|
|
const char *arg = argv[1];
|
|
|
|
if (!strcmp(arg, "--missing-ok"))
|
|
|
|
flags |= WRITE_TREE_MISSING_OK;
|
Mechanical conversion to use prefixcmp()
This mechanically converts strncmp() to use prefixcmp(), but only when
the parameters match specific patterns, so that they can be verified
easily. Leftover from this will be fixed in a separate step, including
idiotic conversions like
if (!strncmp("foo", arg, 3))
=>
if (!(-prefixcmp(arg, "foo")))
This was done by using this script in px.perl
#!/usr/bin/perl -i.bak -p
if (/strncmp\(([^,]+), "([^\\"]*)", (\d+)\)/ && (length($2) == $3)) {
s|strncmp\(([^,]+), "([^\\"]*)", (\d+)\)|prefixcmp($1, "$2")|;
}
if (/strncmp\("([^\\"]*)", ([^,]+), (\d+)\)/ && (length($1) == $3)) {
s|strncmp\("([^\\"]*)", ([^,]+), (\d+)\)|(-prefixcmp($2, "$1"))|;
}
and running:
$ git grep -l strncmp -- '*.c' | xargs perl px.perl
Signed-off-by: Junio C Hamano <junkio@cox.net>
18 years ago
|
|
|
else if (!prefixcmp(arg, "--prefix="))
|
|
|
|
prefix = arg + 9;
|
|
|
|
else if (!prefixcmp(arg, "--ignore-cache-tree"))
|
|
|
|
/*
|
|
|
|
* This is only useful for debugging, so I
|
|
|
|
* do not bother documenting it.
|
|
|
|
*/
|
|
|
|
flags |= WRITE_TREE_IGNORE_CACHE_TREE;
|
|
|
|
else
|
|
|
|
usage(write_tree_usage);
|
|
|
|
argc--; argv++;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (argc > 2)
|
|
|
|
die("too many options");
|
|
|
|
|
|
|
|
ret = write_cache_as_tree(sha1, flags, prefix);
|
|
|
|
switch (ret) {
|
|
|
|
case 0:
|
|
|
|
printf("%s\n", sha1_to_hex(sha1));
|
|
|
|
break;
|
|
|
|
case WRITE_TREE_UNREADABLE_INDEX:
|
|
|
|
die("%s: error reading the index", me);
|
|
|
|
break;
|
|
|
|
case WRITE_TREE_UNMERGED_INDEX:
|
|
|
|
die("%s: error building trees", me);
|
|
|
|
break;
|
|
|
|
case WRITE_TREE_PREFIX_ERROR:
|
|
|
|
die("%s: prefix %s not found", me, prefix);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
}
|