diff options
| author | Erik Faye-Lund <kusmabite@gmail.com> | 2009-03-23 12:53:09 +0000 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2009-03-29 19:48:43 -0700 | 
| commit | 1982467d9229e3c92157f2a41363365dcb866e86 (patch) | |
| tree | 1793fed564f89f4c62411261c882bdc270486791 | |
| parent | c0582c53bcf4e83bba70e1ad23abbad31f96ebc8 (diff) | |
| download | git-1982467d9229e3c92157f2a41363365dcb866e86.tar.gz | |
builtin-fast-export.c: handle nested tags
When tags that points to tags are passed to fast-export, an error is given,
saying "Tag [TAGNAME] points nowhere?". This fix calls parse_object() on the
object before referencing it's tag, to ensure the tag-info is fully initialized.
In addition, it inserts a comment to point out where nested tags are handled.
This is consistent with the comment for signed tags.
Signed-off-by: Erik Faye-Lund <kusmabite@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
| -rw-r--r-- | builtin-fast-export.c | 5 | ||||
| -rwxr-xr-x | t/t9301-fast-export.sh | 4 | 
2 files changed, 6 insertions, 3 deletions
| diff --git a/builtin-fast-export.c b/builtin-fast-export.c index 1ec459f057..f171ee4a2b 100644 --- a/builtin-fast-export.c +++ b/builtin-fast-export.c @@ -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,7 +378,7 @@ static void get_tags_and_duplicates(struct object_array *pending,  			case OBJ_BLOB:  				handle_object(tag->object.sha1);  				continue; -			default: +			default: /* OBJ_TAG (nested tags) is already handled */  				warning("Tag points to object of unexpected type %s, skipping.",  					typename(tag->object.type));  				continue; diff --git a/t/t9301-fast-export.sh b/t/t9301-fast-export.sh index b1f75ceea4..4a87f36258 100755 --- a/t/t9301-fast-export.sh +++ b/t/t9301-fast-export.sh @@ -271,7 +271,7 @@ test_expect_success 'set-up a few more tags for tag export tests' '  # 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_failure 'tag-obj_tag'     'git fast-export tag-obj_tag' -test_expect_failure 'tag-obj_tag-obj' 'git fast-export tag-obj_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 | 
