diff options
| author | Junio C Hamano <gitster@pobox.com> | 2009-12-27 23:01:32 -0800 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2009-12-27 23:01:32 -0800 | 
| commit | c2ff10c98e22ae64d553273e6d67bb123a1c916f (patch) | |
| tree | 7ac3dec7bc0eeb688b538932b4d30f64d245d252 /builtin-commit.c | |
| parent | 67834b924044101a5d25f047746cfce7301bff1c (diff) | |
| parent | 3c5884536563518ce6cd4dc782b0ebb670bf3b6d (diff) | |
| download | git-c2ff10c98e22ae64d553273e6d67bb123a1c916f.tar.gz | |
Merge branch 'jk/1.7.0-status'
* jk/1.7.0-status:
  status/commit: do not suggest "reset HEAD <path>" while merging
  commit/status: "git add <path>" is not necessarily how to resolve
  commit/status: check $GIT_DIR/MERGE_HEAD only once
  t7508-status: test all modes with color
  t7508-status: status --porcelain ignores relative paths setting
  status: reduce duplicated setup code
  status: disable color for porcelain format
  status -s: obey color.status
  builtin-commit: refactor short-status code into wt-status.c
  t7508-status.sh: Add tests for status -s
  status -s: respect the status.relativePaths option
  docs: note that status configuration affects only long format
  commit: support alternate status formats
  status: add --porcelain output format
  status: refactor format option parsing
  status: refactor short-mode printing to its own function
  status: typo fix in usage
  git status: not "commit --dry-run" anymore
  git stat -s: short status output
  git stat: the beginning of "status that is not a dry-run of commit"
Conflicts:
	t/t4034-diff-words.sh
	wt-status.c
Diffstat (limited to 'builtin-commit.c')
| -rw-r--r-- | builtin-commit.c | 124 | 
1 files changed, 104 insertions, 20 deletions
| diff --git a/builtin-commit.c b/builtin-commit.c index f54772f74a..6822aa07ca 100644 --- a/builtin-commit.c +++ b/builtin-commit.c @@ -24,6 +24,7 @@  #include "string-list.h"  #include "rerere.h"  #include "unpack-trees.h" +#include "quote.h"  static const char * const builtin_commit_usage[] = {  	"git commit [options] [--] <filepattern>...", @@ -35,7 +36,7 @@ static const char * const builtin_status_usage[] = {  	NULL  }; -static unsigned char head_sha1[20], merge_head_sha1[20]; +static unsigned char head_sha1[20];  static char *use_message_buffer;  static const char commit_editmsg[] = "COMMIT_EDITMSG";  static struct lock_file index_lock; /* real index */ @@ -71,6 +72,13 @@ static int use_editor = 1, initial_commit, in_merge;  static const char *only_include_assumed;  static struct strbuf message; +static int null_termination; +static enum { +	STATUS_FORMAT_LONG, +	STATUS_FORMAT_SHORT, +	STATUS_FORMAT_PORCELAIN, +} status_format = STATUS_FORMAT_LONG; +  static int opt_parse_m(const struct option *opt, const char *arg, int unset)  {  	struct strbuf *buf = opt->value; @@ -105,6 +113,12 @@ static struct option builtin_commit_options[] = {  	OPT_BOOLEAN('o', "only", &only, "commit only specified files"),  	OPT_BOOLEAN('n', "no-verify", &no_verify, "bypass pre-commit hook"),  	OPT_BOOLEAN(0, "dry-run", &dry_run, "show what would be committed"), +	OPT_SET_INT(0, "short", &status_format, "show status concisely", +		    STATUS_FORMAT_SHORT), +	OPT_SET_INT(0, "porcelain", &status_format, +		    "show porcelain output format", STATUS_FORMAT_PORCELAIN), +	OPT_BOOLEAN('z', "null", &null_termination, +		    "terminate entries with NUL"),  	OPT_BOOLEAN(0, "amend", &amend, "amend previous commit"),  	{ OPTION_STRING, 'u', "untracked-files", &untracked_files_arg, "mode", "show untracked files, optional modes: all, normal, no. (Default: all)", PARSE_OPT_OPTARG, NULL, (intptr_t)"all" },  	OPT_BOOLEAN(0, "allow-empty", &allow_empty, "ok to record an empty change"), @@ -306,7 +320,7 @@ static char *prepare_index(int argc, const char **argv, const char *prefix, int  	 */  	commit_style = COMMIT_PARTIAL; -	if (file_exists(git_path("MERGE_HEAD"))) +	if (in_merge)  		die("cannot do a partial commit during a merge.");  	memset(&partial, 0, sizeof(partial)); @@ -347,6 +361,8 @@ static char *prepare_index(int argc, const char **argv, const char *prefix, int  static int run_status(FILE *fp, const char *index_file, const char *prefix, int nowarn,  		      struct wt_status *s)  { +	unsigned char sha1[20]; +  	if (s->relative_paths)  		s->prefix = prefix; @@ -358,8 +374,21 @@ static int run_status(FILE *fp, const char *index_file, const char *prefix, int  	s->index_file = index_file;  	s->fp = fp;  	s->nowarn = nowarn; +	s->is_initial = get_sha1(s->reference, sha1) ? 1 : 0; -	wt_status_print(s); +	wt_status_collect(s); + +	switch (status_format) { +	case STATUS_FORMAT_SHORT: +		wt_shortstatus_print(s, null_termination); +		break; +	case STATUS_FORMAT_PORCELAIN: +		wt_porcelain_print(s, null_termination); +		break; +	case STATUS_FORMAT_LONG: +		wt_status_print(s); +		break; +	}  	return s->commitable;  } @@ -735,6 +764,21 @@ static const char *find_author_by_nickname(const char *name)  	die("No existing author found with '%s'", name);  } + +static void handle_untracked_files_arg(struct wt_status *s) +{ +	if (!untracked_files_arg) +		; /* default already initialized */ +	else if (!strcmp(untracked_files_arg, "no")) +		s->show_untracked_files = SHOW_NO_UNTRACKED_FILES; +	else if (!strcmp(untracked_files_arg, "normal")) +		s->show_untracked_files = SHOW_NORMAL_UNTRACKED_FILES; +	else if (!strcmp(untracked_files_arg, "all")) +		s->show_untracked_files = SHOW_ALL_UNTRACKED_FILES; +	else +		die("Invalid untracked files mode '%s'", untracked_files_arg); +} +  static int parse_and_validate_options(int argc, const char *argv[],  				      const char * const usage[],  				      const char *prefix, @@ -761,9 +805,6 @@ static int parse_and_validate_options(int argc, const char *argv[],  	if (get_sha1("HEAD", head_sha1))  		initial_commit = 1; -	if (!get_sha1("MERGE_HEAD", merge_head_sha1)) -		in_merge = 1; -  	/* Sanity check options */  	if (amend && initial_commit)  		die("You have nothing to amend."); @@ -843,22 +884,18 @@ static int parse_and_validate_options(int argc, const char *argv[],  	else  		die("Invalid cleanup mode %s", cleanup_arg); -	if (!untracked_files_arg) -		; /* default already initialized */ -	else if (!strcmp(untracked_files_arg, "no")) -		s->show_untracked_files = SHOW_NO_UNTRACKED_FILES; -	else if (!strcmp(untracked_files_arg, "normal")) -		s->show_untracked_files = SHOW_NORMAL_UNTRACKED_FILES; -	else if (!strcmp(untracked_files_arg, "all")) -		s->show_untracked_files = SHOW_ALL_UNTRACKED_FILES; -	else -		die("Invalid untracked files mode '%s'", untracked_files_arg); +	handle_untracked_files_arg(s);  	if (all && argc > 0)  		die("Paths with -a does not make sense.");  	else if (interactive && argc > 0)  		die("Paths with --interactive does not make sense."); +	if (null_termination && status_format == STATUS_FORMAT_LONG) +		status_format = STATUS_FORMAT_PORCELAIN; +	if (status_format != STATUS_FORMAT_LONG) +		dry_run = 1; +  	return argc;  } @@ -940,17 +977,63 @@ static int git_status_config(const char *k, const char *v, void *cb)  int cmd_status(int argc, const char **argv, const char *prefix)  {  	struct wt_status s; +	unsigned char sha1[20]; +	static struct option builtin_status_options[] = { +		OPT__VERBOSE(&verbose), +		OPT_SET_INT('s', "short", &status_format, +			    "show status concisely", STATUS_FORMAT_SHORT), +		OPT_SET_INT(0, "porcelain", &status_format, +			    "show porcelain output format", +			    STATUS_FORMAT_PORCELAIN), +		OPT_BOOLEAN('z', "null", &null_termination, +			    "terminate entries with NUL"), +		{ OPTION_STRING, 'u', "untracked-files", &untracked_files_arg, +		  "mode", +		  "show untracked files, optional modes: all, normal, no. (Default: all)", +		  PARSE_OPT_OPTARG, NULL, (intptr_t)"all" }, +		OPT_END(), +	}; + +	if (null_termination && status_format == STATUS_FORMAT_LONG) +		status_format = STATUS_FORMAT_PORCELAIN;  	wt_status_prepare(&s);  	git_config(git_status_config, &s); +	in_merge = file_exists(git_path("MERGE_HEAD")); +	argc = parse_options(argc, argv, prefix, +			     builtin_status_options, +			     builtin_status_usage, 0); +	handle_untracked_files_arg(&s); + +	if (*argv) +		s.pathspec = get_pathspec(prefix, argv); + +	read_cache(); +	refresh_cache(REFRESH_QUIET|REFRESH_UNMERGED); +	s.is_initial = get_sha1(s.reference, sha1) ? 1 : 0; +	s.in_merge = in_merge; +	wt_status_collect(&s); + +	if (s.relative_paths) +		s.prefix = prefix;  	if (s.use_color == -1)  		s.use_color = git_use_color_default;  	if (diff_use_color_default == -1)  		diff_use_color_default = git_use_color_default; -	argc = parse_and_validate_options(argc, argv, builtin_status_usage, -					  prefix, &s); -	return dry_run_commit(argc, argv, prefix, &s); +	switch (status_format) { +	case STATUS_FORMAT_SHORT: +		wt_shortstatus_print(&s, null_termination); +		break; +	case STATUS_FORMAT_PORCELAIN: +		wt_porcelain_print(&s, null_termination); +		break; +	case STATUS_FORMAT_LONG: +		s.verbose = verbose; +		wt_status_print(&s); +		break; +	} +	return 0;  }  static void print_summary(const char *prefix, const unsigned char *sha1) @@ -1026,10 +1109,11 @@ int cmd_commit(int argc, const char **argv, const char *prefix)  	wt_status_prepare(&s);  	git_config(git_commit_config, &s); +	in_merge = file_exists(git_path("MERGE_HEAD")); +	s.in_merge = in_merge;  	if (s.use_color == -1)  		s.use_color = git_use_color_default; -  	argc = parse_and_validate_options(argc, argv, builtin_commit_usage,  					  prefix, &s);  	if (dry_run) { | 
