diff options
Diffstat (limited to 'revision.c')
| -rw-r--r-- | revision.c | 68 | 
1 files changed, 59 insertions, 9 deletions
| diff --git a/revision.c b/revision.c index a8a3c3a4bd..3ba6d991f6 100644 --- a/revision.c +++ b/revision.c @@ -134,10 +134,20 @@ static void add_pending_object_with_mode(struct rev_info *revs, struct object *o  {  	if (revs->no_walk && (obj->flags & UNINTERESTING))  		revs->no_walk = 0; -	if (revs->reflog_info && obj->type == OBJ_COMMIT && -			add_reflog_for_walk(revs->reflog_info, -				(struct commit *)obj, name)) -		return; +	if (revs->reflog_info && obj->type == OBJ_COMMIT) { +		struct strbuf buf = STRBUF_INIT; +		int len = interpret_branch_name(name, &buf); +		int st; + +		if (0 < len && name[len] && buf.len) +			strbuf_addstr(&buf, name + len); +		st = add_reflog_for_walk(revs->reflog_info, +					 (struct commit *)obj, +					 buf.buf[0] ? buf.buf: name); +		strbuf_release(&buf); +		if (st) +			return; +	}  	add_object_array_with_mode(obj, name, &revs->pending, mode);  } @@ -268,7 +278,7 @@ static int tree_difference = REV_TREE_SAME;  static void file_add_remove(struct diff_options *options,  		    int addremove, unsigned mode,  		    const unsigned char *sha1, -		    const char *fullpath) +		    const char *fullpath, unsigned dirty_submodule)  {  	int diff = addremove == '+' ? REV_TREE_NEW : REV_TREE_OLD; @@ -281,7 +291,8 @@ static void file_change(struct diff_options *options,  		 unsigned old_mode, unsigned new_mode,  		 const unsigned char *old_sha1,  		 const unsigned char *new_sha1, -		 const char *fullpath) +		 const char *fullpath, +		 unsigned old_dirty_submodule, unsigned new_dirty_submodule)  {  	tree_difference = REV_TREE_DIFFERENT;  	DIFF_OPT_SET(options, HAS_CHANGES); @@ -699,12 +710,18 @@ static int handle_one_ref(const char *path, const unsigned char *sha1, int flag,  	return 0;  } +static void init_all_refs_cb(struct all_refs_cb *cb, struct rev_info *revs, +	unsigned flags) +{ +	cb->all_revs = revs; +	cb->all_flags = flags; +} +  static void handle_refs(struct rev_info *revs, unsigned flags,  		int (*for_each)(each_ref_fn, void *))  {  	struct all_refs_cb cb; -	cb.all_revs = revs; -	cb.all_flags = flags; +	init_all_refs_cb(&cb, revs, flags);  	for_each(handle_one_ref, &cb);  } @@ -791,7 +808,7 @@ void init_revisions(struct rev_info *revs, const char *prefix)  	revs->ignore_merges = 1;  	revs->simplify_history = 1;  	DIFF_OPT_SET(&revs->pruning, RECURSIVE); -	DIFF_OPT_SET(&revs->pruning, QUIET); +	DIFF_OPT_SET(&revs->pruning, QUICK);  	revs->pruning.add_remove = file_add_remove;  	revs->pruning.change = file_change;  	revs->lifo = 1; @@ -1161,13 +1178,22 @@ static int handle_revision_opt(struct rev_info *revs, int argc, const char **arg  		revs->verbose_header = 1;  	} else if (!strcmp(arg, "--pretty")) {  		revs->verbose_header = 1; +		revs->pretty_given = 1;  		get_commit_format(arg+8, revs);  	} else if (!prefixcmp(arg, "--pretty=") || !prefixcmp(arg, "--format=")) {  		revs->verbose_header = 1; +		revs->pretty_given = 1;  		get_commit_format(arg+9, revs); +	} else if (!strcmp(arg, "--show-notes")) { +		revs->show_notes = 1; +		revs->show_notes_given = 1; +	} else if (!strcmp(arg, "--no-notes")) { +		revs->show_notes = 0; +		revs->show_notes_given = 1;  	} else if (!strcmp(arg, "--oneline")) {  		revs->verbose_header = 1;  		get_commit_format("oneline", revs); +		revs->pretty_given = 1;  		revs->abbrev_commit = 1;  	} else if (!strcmp(arg, "--graph")) {  		revs->topo_order = 1; @@ -1352,6 +1378,30 @@ int setup_revisions(int argc, const char **argv, struct rev_info *revs, const ch  				handle_refs(revs, flags, for_each_remote_ref);  				continue;  			} +			if (!prefixcmp(arg, "--glob=")) { +				struct all_refs_cb cb; +				init_all_refs_cb(&cb, revs, flags); +				for_each_glob_ref(handle_one_ref, arg + 7, &cb); +				continue; +			} +			if (!prefixcmp(arg, "--branches=")) { +				struct all_refs_cb cb; +				init_all_refs_cb(&cb, revs, flags); +				for_each_glob_ref_in(handle_one_ref, arg + 11, "refs/heads/", &cb); +				continue; +			} +			if (!prefixcmp(arg, "--tags=")) { +				struct all_refs_cb cb; +				init_all_refs_cb(&cb, revs, flags); +				for_each_glob_ref_in(handle_one_ref, arg + 7, "refs/tags/", &cb); +				continue; +			} +			if (!prefixcmp(arg, "--remotes=")) { +				struct all_refs_cb cb; +				init_all_refs_cb(&cb, revs, flags); +				for_each_glob_ref_in(handle_one_ref, arg + 10, "refs/remotes/", &cb); +				continue; +			}  			if (!strcmp(arg, "--reflog")) {  				handle_reflog(revs, flags);  				continue; | 
