Merge branch 'ef/maint-fast-export' into maint
* ef/maint-fast-export: builtin-fast-export.c: handle nested tags builtin-fast-export.c: fix crash on tagged trees builtin-fast-export.c: turn error into warning test-suite: adding a test for fast-export with tag variantsmaint
						commit
						4f26c39806
					
				|  | @ -362,7 +362,10 @@ static void get_tags_and_duplicates(struct object_array *pending, | |||
| 			break; | ||||
| 		case OBJ_TAG: | ||||
| 			tag = (struct tag *)e->item; | ||||
|  | ||||
| 			/* handle nested tags */ | ||||
| 			while (tag && tag->object.type == OBJ_TAG) { | ||||
| 				parse_object(tag->object.sha1); | ||||
| 				string_list_append(full_name, extra_refs)->util = tag; | ||||
| 				tag = (struct tag *)tag->tagged; | ||||
| 			} | ||||
|  | @ -375,11 +378,17 @@ static void get_tags_and_duplicates(struct object_array *pending, | |||
| 			case OBJ_BLOB: | ||||
| 				handle_object(tag->object.sha1); | ||||
| 				continue; | ||||
| 			default: /* OBJ_TAG (nested tags) is already handled */ | ||||
| 				warning("Tag points to object of unexpected type %s, skipping.", | ||||
| 					typename(tag->object.type)); | ||||
| 				continue; | ||||
| 			} | ||||
| 			break; | ||||
| 		default: | ||||
| 			die ("Unexpected object of type %s", | ||||
| 			     typename(e->item->type)); | ||||
| 			warning("%s: Unexpected object of type %s, skipping.", | ||||
| 				e->name, | ||||
| 				typename(e->item->type)); | ||||
| 			continue; | ||||
| 		} | ||||
| 		if (commit->util) | ||||
| 			/* more than one name for the same object */ | ||||
|  |  | |||
|  | @ -259,4 +259,19 @@ test_expect_success 'cope with tagger-less tags' ' | |||
|  | ||||
| ' | ||||
|  | ||||
| test_expect_success 'set-up a few more tags for tag export tests' ' | ||||
| 	git checkout -f master && | ||||
| 	HEAD_TREE=`git show -s --pretty=raw HEAD | grep tree | sed "s/tree //"` && | ||||
| 	git tag    tree_tag        -m "tagging a tree" $HEAD_TREE && | ||||
| 	git tag -a tree_tag-obj    -m "tagging a tree" $HEAD_TREE && | ||||
| 	git tag    tag-obj_tag     -m "tagging a tag" tree_tag-obj && | ||||
| 	git tag -a tag-obj_tag-obj -m "tagging a tag" tree_tag-obj | ||||
| ' | ||||
|  | ||||
| # NEEDSWORK: not just check return status, but validate the output | ||||
| test_expect_success 'tree_tag'        'git fast-export tree_tag' | ||||
| test_expect_success 'tree_tag-obj'    'git fast-export tree_tag-obj' | ||||
| test_expect_success 'tag-obj_tag'     'git fast-export tag-obj_tag' | ||||
| test_expect_success 'tag-obj_tag-obj' 'git fast-export tag-obj_tag-obj' | ||||
|  | ||||
| test_done | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Junio C Hamano
						Junio C Hamano