builtin/apply: make gitdiff_*() return -1 on error
To libify `git apply` functionality we have to signal errors to the caller instead of die()ing. To do that in a compatible manner with the rest of the error handling in "builtin/apply.c", gitdiff_*() functions should return -1 instead of calling die(). A previous patch made it possible for gitdiff_*() functions to return -1 in case of error. Let's take advantage of that to make gitdiff_verify_name() return -1 on error, and to have gitdiff_oldname() and gitdiff_newname() directly return what gitdiff_verify_name() returns. Helped-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> Signed-off-by: Christian Couder <chriscool@tuxfamily.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
70af7662d4
commit
dbf1b5fb6a
@ -827,54 +827,56 @@ static int gitdiff_hdrend(struct apply_state *state,
|
|||||||
#define DIFF_OLD_NAME 0
|
#define DIFF_OLD_NAME 0
|
||||||
#define DIFF_NEW_NAME 1
|
#define DIFF_NEW_NAME 1
|
||||||
|
|
||||||
static void gitdiff_verify_name(struct apply_state *state,
|
static int gitdiff_verify_name(struct apply_state *state,
|
||||||
const char *line,
|
const char *line,
|
||||||
int isnull,
|
int isnull,
|
||||||
char **name,
|
char **name,
|
||||||
int side)
|
int side)
|
||||||
{
|
{
|
||||||
if (!*name && !isnull) {
|
if (!*name && !isnull) {
|
||||||
*name = find_name(state, line, NULL, state->p_value, TERM_TAB);
|
*name = find_name(state, line, NULL, state->p_value, TERM_TAB);
|
||||||
return;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (*name) {
|
if (*name) {
|
||||||
int len = strlen(*name);
|
int len = strlen(*name);
|
||||||
char *another;
|
char *another;
|
||||||
if (isnull)
|
if (isnull)
|
||||||
die(_("git apply: bad git-diff - expected /dev/null, got %s on line %d"),
|
return error(_("git apply: bad git-diff - expected /dev/null, got %s on line %d"),
|
||||||
*name, state->linenr);
|
*name, state->linenr);
|
||||||
another = find_name(state, line, NULL, state->p_value, TERM_TAB);
|
another = find_name(state, line, NULL, state->p_value, TERM_TAB);
|
||||||
if (!another || memcmp(another, *name, len + 1))
|
if (!another || memcmp(another, *name, len + 1)) {
|
||||||
die((side == DIFF_NEW_NAME) ?
|
free(another);
|
||||||
|
return error((side == DIFF_NEW_NAME) ?
|
||||||
_("git apply: bad git-diff - inconsistent new filename on line %d") :
|
_("git apply: bad git-diff - inconsistent new filename on line %d") :
|
||||||
_("git apply: bad git-diff - inconsistent old filename on line %d"), state->linenr);
|
_("git apply: bad git-diff - inconsistent old filename on line %d"), state->linenr);
|
||||||
|
}
|
||||||
free(another);
|
free(another);
|
||||||
} else {
|
} else {
|
||||||
/* expect "/dev/null" */
|
/* expect "/dev/null" */
|
||||||
if (memcmp("/dev/null", line, 9) || line[9] != '\n')
|
if (memcmp("/dev/null", line, 9) || line[9] != '\n')
|
||||||
die(_("git apply: bad git-diff - expected /dev/null on line %d"), state->linenr);
|
return error(_("git apply: bad git-diff - expected /dev/null on line %d"), state->linenr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int gitdiff_oldname(struct apply_state *state,
|
static int gitdiff_oldname(struct apply_state *state,
|
||||||
const char *line,
|
const char *line,
|
||||||
struct patch *patch)
|
struct patch *patch)
|
||||||
{
|
{
|
||||||
gitdiff_verify_name(state, line,
|
return gitdiff_verify_name(state, line,
|
||||||
patch->is_new, &patch->old_name,
|
patch->is_new, &patch->old_name,
|
||||||
DIFF_OLD_NAME);
|
DIFF_OLD_NAME);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int gitdiff_newname(struct apply_state *state,
|
static int gitdiff_newname(struct apply_state *state,
|
||||||
const char *line,
|
const char *line,
|
||||||
struct patch *patch)
|
struct patch *patch)
|
||||||
{
|
{
|
||||||
gitdiff_verify_name(state, line,
|
return gitdiff_verify_name(state, line,
|
||||||
patch->is_delete, &patch->new_name,
|
patch->is_delete, &patch->new_name,
|
||||||
DIFF_NEW_NAME);
|
DIFF_NEW_NAME);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int gitdiff_oldmode(struct apply_state *state,
|
static int gitdiff_oldmode(struct apply_state *state,
|
||||||
|
Reference in New Issue
Block a user