2022-11-19 13:07:38 +00:00
|
|
|
#define USE_THE_INDEX_VARIABLE
|
Fix sparse warnings
Fix warnings from 'make check'.
- These files don't include 'builtin.h' causing sparse to complain that
cmd_* isn't declared:
builtin/clone.c:364, builtin/fetch-pack.c:797,
builtin/fmt-merge-msg.c:34, builtin/hash-object.c:78,
builtin/merge-index.c:69, builtin/merge-recursive.c:22
builtin/merge-tree.c:341, builtin/mktag.c:156, builtin/notes.c:426
builtin/notes.c:822, builtin/pack-redundant.c:596,
builtin/pack-refs.c:10, builtin/patch-id.c:60, builtin/patch-id.c:149,
builtin/remote.c:1512, builtin/remote-ext.c:240,
builtin/remote-fd.c:53, builtin/reset.c:236, builtin/send-pack.c:384,
builtin/unpack-file.c:25, builtin/var.c:75
- These files have symbols which should be marked static since they're
only file scope:
submodule.c:12, diff.c:631, replace_object.c:92, submodule.c:13,
submodule.c:14, trace.c:78, transport.c:195, transport-helper.c:79,
unpack-trees.c:19, url.c:3, url.c:18, url.c:104, url.c:117, url.c:123,
url.c:129, url.c:136, thread-utils.c:21, thread-utils.c:48
- These files redeclare symbols to be different types:
builtin/index-pack.c:210, parse-options.c:564, parse-options.c:571,
usage.c:49, usage.c:58, usage.c:63, usage.c:72
- These files use a literal integer 0 when they really should use a NULL
pointer:
daemon.c:663, fast-import.c:2942, imap-send.c:1072, notes-merge.c:362
While we're in the area, clean up some unused #includes in builtin files
(mostly exec_cmd.h).
Signed-off-by: Stephen Boyd <bebarino@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2011-03-22 07:51:05 +00:00
|
|
|
#include "builtin.h"
|
2023-02-24 00:09:27 +00:00
|
|
|
#include "hex.h"
|
2023-04-22 20:17:20 +00:00
|
|
|
#include "repository.h"
|
2007-03-12 23:00:21 +00:00
|
|
|
#include "run-command.h"
|
2005-04-18 02:52:54 +00:00
|
|
|
|
2006-08-15 17:23:48 +00:00
|
|
|
static const char *pgm;
|
2005-07-29 12:53:38 +00:00
|
|
|
static int one_shot, quiet;
|
2005-04-19 02:16:15 +00:00
|
|
|
static int err;
|
2005-04-18 02:52:54 +00:00
|
|
|
|
|
|
|
static int merge_entry(int pos, const char *path)
|
|
|
|
{
|
|
|
|
int found;
|
2009-06-08 20:34:29 +00:00
|
|
|
const char *arguments[] = { pgm, "", "", "", path, "", "", "", NULL };
|
2017-03-26 16:01:24 +00:00
|
|
|
char hexbuf[4][GIT_MAX_HEXSZ + 1];
|
2009-06-08 20:34:29 +00:00
|
|
|
char ownbuf[4][60];
|
2022-10-30 11:55:06 +00:00
|
|
|
struct child_process cmd = CHILD_PROCESS_INIT;
|
2007-06-07 07:04:01 +00:00
|
|
|
|
2022-11-19 13:07:34 +00:00
|
|
|
if (pos >= the_index.cache_nr)
|
2008-08-31 16:39:19 +00:00
|
|
|
die("git merge-index: %s not in the cache", path);
|
2005-04-18 02:52:54 +00:00
|
|
|
found = 0;
|
|
|
|
do {
|
2022-11-19 13:07:34 +00:00
|
|
|
const struct cache_entry *ce = the_index.cache[pos];
|
2005-04-18 02:52:54 +00:00
|
|
|
int stage = ce_stage(ce);
|
|
|
|
|
|
|
|
if (strcmp(ce->name, path))
|
|
|
|
break;
|
|
|
|
found++;
|
2017-01-28 22:03:03 +00:00
|
|
|
oid_to_hex_r(hexbuf[stage], &ce->oid);
|
2015-09-24 21:06:08 +00:00
|
|
|
xsnprintf(ownbuf[stage], sizeof(ownbuf[stage]), "%o", ce->ce_mode);
|
2005-04-18 21:17:58 +00:00
|
|
|
arguments[stage] = hexbuf[stage];
|
2005-04-24 03:50:10 +00:00
|
|
|
arguments[stage + 4] = ownbuf[stage];
|
2022-11-19 13:07:34 +00:00
|
|
|
} while (++pos < the_index.cache_nr);
|
2005-04-18 02:52:54 +00:00
|
|
|
if (!found)
|
2008-08-31 16:39:19 +00:00
|
|
|
die("git merge-index: %s not in the cache", path);
|
2009-06-08 20:34:29 +00:00
|
|
|
|
2022-10-30 11:55:06 +00:00
|
|
|
strvec_pushv(&cmd.args, arguments);
|
|
|
|
if (run_command(&cmd)) {
|
2009-06-08 20:34:29 +00:00
|
|
|
if (one_shot)
|
|
|
|
err++;
|
|
|
|
else {
|
|
|
|
if (!quiet)
|
|
|
|
die("merge program failed");
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
}
|
2005-04-18 02:52:54 +00:00
|
|
|
return found;
|
|
|
|
}
|
|
|
|
|
2012-12-06 23:08:01 +00:00
|
|
|
static void merge_one_path(const char *path)
|
2005-04-18 02:52:54 +00:00
|
|
|
{
|
2022-11-19 13:07:38 +00:00
|
|
|
int pos = index_name_pos(&the_index, path, strlen(path));
|
2005-04-18 02:52:54 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* If it already exists in the cache as stage0, it's
|
|
|
|
* already merged and there is nothing to do.
|
|
|
|
*/
|
|
|
|
if (pos < 0)
|
|
|
|
merge_entry(-pos-1, path);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void merge_all(void)
|
|
|
|
{
|
|
|
|
int i;
|
2021-04-01 01:49:50 +00:00
|
|
|
/* TODO: audit for interaction with sparse-index. */
|
|
|
|
ensure_full_index(&the_index);
|
2022-11-19 13:07:34 +00:00
|
|
|
for (i = 0; i < the_index.cache_nr; i++) {
|
|
|
|
const struct cache_entry *ce = the_index.cache[i];
|
2005-04-18 02:52:54 +00:00
|
|
|
if (!ce_stage(ce))
|
|
|
|
continue;
|
|
|
|
i += merge_entry(i, ce->name)-1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
builtins: mark unused prefix parameters
All builtins receive a "prefix" parameter, but it is only useful if they
need to adjust filenames given by the user on the command line. For
builtins that do not even call parse_options(), they often don't look at
the prefix at all, and -Wunused-parameter complains.
Let's annotate those to silence the compiler warning. I gave a quick
scan of each of these cases, and it seems like they don't have anything
they _should_ be using the prefix for (i.e., there is no hidden bug that
we are missing). The only questionable cases I saw were:
- in git-unpack-file, we create a tempfile which will always be at the
root of the repository, even if the command is run from a subdir.
Arguably this should be created in the subdir from which we're run
(as we report the path only as a relative name). However, nobody has
complained, and I'm hesitant to change something that is deep
plumbing going back to April 2005 (though I think within our
scripts, the sole caller in git-merge-one-file would be OK, as it
moves to the toplevel itself).
- in fetch-pack, local-filesystem remotes are taken as relative to the
project root, not the current directory. So:
git init server.git
[...put stuff in server.git...]
git init client.git
cd client.git
mkdir subdir
cd subdir
git fetch-pack ../../server.git ...
won't work, as we quietly move to the top of the repository before
interpreting the path (so "../server.git" would work). This is
weird, but again, nobody has complained and this is how it has
always worked. And this is how "git fetch" works, too. Plus it
raises questions about how a configured remote like:
git config remote.origin.url ../server.git
should behave. I can certainly come up with a reasonable set of
behavior, but it may not be worth stirring up complications in a
plumbing tool.
So I've left the behavior untouched in both of those cases. If anybody
really wants to revisit them, it's easy enough to drop the UNUSED
marker. This commit is just about removing them as obstacles to turning
on -Wunused-parameter all the time.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2023-03-28 20:56:55 +00:00
|
|
|
int cmd_merge_index(int argc, const char **argv, const char *prefix UNUSED)
|
2005-04-18 02:52:54 +00:00
|
|
|
{
|
|
|
|
int i, force_file = 0;
|
|
|
|
|
2006-06-20 01:25:21 +00:00
|
|
|
/* Without this we cannot rely on waitpid() to tell
|
|
|
|
* what happened to our children.
|
|
|
|
*/
|
|
|
|
signal(SIGCHLD, SIG_DFL);
|
|
|
|
|
2005-04-18 02:52:54 +00:00
|
|
|
if (argc < 3)
|
2015-01-13 07:44:47 +00:00
|
|
|
usage("git merge-index [-o] [-q] <merge-program> (-a | [--] [<filename>...])");
|
2005-04-18 02:52:54 +00:00
|
|
|
|
2022-11-19 13:07:38 +00:00
|
|
|
repo_read_index(the_repository);
|
2005-04-18 02:52:54 +00:00
|
|
|
|
2021-04-01 01:49:50 +00:00
|
|
|
/* TODO: audit for interaction with sparse-index. */
|
|
|
|
ensure_full_index(&the_index);
|
|
|
|
|
2005-05-11 02:44:59 +00:00
|
|
|
i = 1;
|
2005-07-29 12:53:38 +00:00
|
|
|
if (!strcmp(argv[i], "-o")) {
|
2005-05-11 02:44:59 +00:00
|
|
|
one_shot = 1;
|
|
|
|
i++;
|
|
|
|
}
|
2005-07-29 12:53:38 +00:00
|
|
|
if (!strcmp(argv[i], "-q")) {
|
|
|
|
quiet = 1;
|
|
|
|
i++;
|
|
|
|
}
|
2005-05-11 02:44:59 +00:00
|
|
|
pgm = argv[i++];
|
|
|
|
for (; i < argc; i++) {
|
2010-01-22 15:29:21 +00:00
|
|
|
const char *arg = argv[i];
|
2005-04-18 02:52:54 +00:00
|
|
|
if (!force_file && *arg == '-') {
|
|
|
|
if (!strcmp(arg, "--")) {
|
|
|
|
force_file = 1;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (!strcmp(arg, "-a")) {
|
|
|
|
merge_all();
|
|
|
|
continue;
|
|
|
|
}
|
2008-08-31 16:39:19 +00:00
|
|
|
die("git merge-index: unknown option %s", arg);
|
2005-04-18 02:52:54 +00:00
|
|
|
}
|
2012-12-06 23:08:01 +00:00
|
|
|
merge_one_path(arg);
|
2005-04-18 02:52:54 +00:00
|
|
|
}
|
2005-08-04 22:31:12 +00:00
|
|
|
if (err && !quiet)
|
2005-04-19 02:16:15 +00:00
|
|
|
die("merge program failed");
|
2005-07-29 12:53:38 +00:00
|
|
|
return err;
|
2005-04-18 02:52:54 +00:00
|
|
|
}
|