diff options
Diffstat (limited to 'list-objects.c')
| -rw-r--r-- | list-objects.c | 33 | 
1 files changed, 17 insertions, 16 deletions
| diff --git a/list-objects.c b/list-objects.c index 433394a107..8953548c07 100644 --- a/list-objects.c +++ b/list-objects.c @@ -10,7 +10,7 @@  static void process_blob(struct rev_info *revs,  			 struct blob *blob, -			 struct object_array *p, +			 show_object_fn show,  			 struct name_path *path,  			 const char *name)  { @@ -23,7 +23,7 @@ static void process_blob(struct rev_info *revs,  	if (obj->flags & (UNINTERESTING | SEEN))  		return;  	obj->flags |= SEEN; -	add_object(obj, p, path, name); +	show(obj, path, name);  }  /* @@ -50,7 +50,7 @@ static void process_blob(struct rev_info *revs,   */  static void process_gitlink(struct rev_info *revs,  			    const unsigned char *sha1, -			    struct object_array *p, +			    show_object_fn show,  			    struct name_path *path,  			    const char *name)  { @@ -59,7 +59,7 @@ static void process_gitlink(struct rev_info *revs,  static void process_tree(struct rev_info *revs,  			 struct tree *tree, -			 struct object_array *p, +			 show_object_fn show,  			 struct name_path *path,  			 const char *name)  { @@ -77,7 +77,7 @@ static void process_tree(struct rev_info *revs,  	if (parse_tree(tree) < 0)  		die("bad tree object %s", sha1_to_hex(obj->sha1));  	obj->flags |= SEEN; -	add_object(obj, p, path, name); +	show(obj, path, name);  	me.up = path;  	me.elem = name;  	me.elem_len = strlen(name); @@ -88,14 +88,14 @@ static void process_tree(struct rev_info *revs,  		if (S_ISDIR(entry.mode))  			process_tree(revs,  				     lookup_tree(entry.sha1), -				     p, &me, entry.path); +				     show, &me, entry.path);  		else if (S_ISGITLINK(entry.mode))  			process_gitlink(revs, entry.sha1, -					p, &me, entry.path); +					show, &me, entry.path);  		else  			process_blob(revs,  				     lookup_blob(entry.sha1), -				     p, &me, entry.path); +				     show, &me, entry.path);  	}  	free(tree->buffer);  	tree->buffer = NULL; @@ -134,6 +134,11 @@ void mark_edges_uninteresting(struct commit_list *list,  	}  } +static void add_pending_tree(struct rev_info *revs, struct tree *tree) +{ +	add_pending_object(revs, &tree->object, ""); +} +  void traverse_commit_list(struct rev_info *revs,  			  show_commit_fn show_commit,  			  show_object_fn show_object, @@ -141,10 +146,9 @@ void traverse_commit_list(struct rev_info *revs,  {  	int i;  	struct commit *commit; -	struct object_array objects = { 0, 0, NULL };  	while ((commit = get_revision(revs)) != NULL) { -		process_tree(revs, commit->tree, &objects, NULL, ""); +		add_pending_tree(revs, commit->tree);  		show_commit(commit, data);  	}  	for (i = 0; i < revs->pending.nr; i++) { @@ -155,25 +159,22 @@ void traverse_commit_list(struct rev_info *revs,  			continue;  		if (obj->type == OBJ_TAG) {  			obj->flags |= SEEN; -			add_object_array(obj, name, &objects); +			show_object(obj, NULL, name);  			continue;  		}  		if (obj->type == OBJ_TREE) { -			process_tree(revs, (struct tree *)obj, &objects, +			process_tree(revs, (struct tree *)obj, show_object,  				     NULL, name);  			continue;  		}  		if (obj->type == OBJ_BLOB) { -			process_blob(revs, (struct blob *)obj, &objects, +			process_blob(revs, (struct blob *)obj, show_object,  				     NULL, name);  			continue;  		}  		die("unknown pending object %s (%s)",  		    sha1_to_hex(obj->sha1), name);  	} -	for (i = 0; i < objects.nr; i++) -		show_object(&objects.objects[i], data); -	free(objects.objects);  	if (revs->pending.nr) {  		free(revs->pending.objects);  		revs->pending.nr = 0; | 
