Staging
v0.5.1
https://github.com/git/git
Revision 5d213e46bb7b880238ff5ea3914e940a50ae9369 authored by Junio C Hamano on 11 August 2021, 18:54:03 UTC, committed by Junio C Hamano on 11 August 2021, 19:36:18 UTC
Signed-off-by: Junio C Hamano <gitster@pobox.com>
1 parent 4c90d89
Raw File
Tip revision: 5d213e46bb7b880238ff5ea3914e940a50ae9369 authored by Junio C Hamano on 11 August 2021, 18:54:03 UTC
Git 2.33-rc2
Tip revision: 5d213e4
rebase.c
#include "rebase.h"
#include "config.h"

/*
 * Parses textual value for pull.rebase, branch.<name>.rebase, etc.
 * Unrecognised value yields REBASE_INVALID, which traditionally is
 * treated the same way as REBASE_FALSE.
 *
 * The callers that care if (any) rebase is requested should say
 *   if (REBASE_TRUE <= rebase_parse_value(string))
 *
 * The callers that want to differenciate an unrecognised value and
 * false can do so by treating _INVALID and _FALSE differently.
 */
enum rebase_type rebase_parse_value(const char *value)
{
	int v = git_parse_maybe_bool(value);

	if (!v)
		return REBASE_FALSE;
	else if (v > 0)
		return REBASE_TRUE;
	else if (!strcmp(value, "preserve") || !strcmp(value, "p"))
		return REBASE_PRESERVE;
	else if (!strcmp(value, "merges") || !strcmp(value, "m"))
		return REBASE_MERGES;
	else if (!strcmp(value, "interactive") || !strcmp(value, "i"))
		return REBASE_INTERACTIVE;
	/*
	 * Please update _git_config() in git-completion.bash when you
	 * add new rebase modes.
	 */

	return REBASE_INVALID;
}
back to top