mirror of
				https://git.proxmox.com/git/libgit2
				synced 2025-11-04 10:33:00 +00:00 
			
		
		
		
	Merge pull request #2724 from libgit2/vmg/empty
odb: `git_odb_object` contents are never NULL
This commit is contained in:
		
						commit
						c89f1cf9d6
					
				@ -762,12 +762,12 @@ static int hardcoded_objects(git_rawobj *raw, const git_oid *id)
 | 
			
		||||
	if (!git_oid_cmp(id, &empty_blob)) {
 | 
			
		||||
		raw->type = GIT_OBJ_BLOB;
 | 
			
		||||
		raw->len = 0;
 | 
			
		||||
		raw->data = NULL;
 | 
			
		||||
		raw->data = git__calloc(1, sizeof(uint8_t));
 | 
			
		||||
		return 0;
 | 
			
		||||
	} else if (!git_oid_cmp(id, &empty_tree)) {
 | 
			
		||||
		raw->type = GIT_OBJ_TREE;
 | 
			
		||||
		raw->len = 0;
 | 
			
		||||
		raw->data = NULL;
 | 
			
		||||
		raw->data = git__calloc(1, sizeof(uint8_t));
 | 
			
		||||
		return 0;
 | 
			
		||||
	} else {
 | 
			
		||||
		return GIT_ENOTFOUND;
 | 
			
		||||
 | 
			
		||||
@ -21,6 +21,8 @@ void test_odb_emptyobjects__read(void)
 | 
			
		||||
	cl_git_pass(git_oid_fromstr(&id, "e69de29bb2d1d6434b8b29ae775ad8c2e48c5391"));
 | 
			
		||||
	cl_git_pass(git_blob_lookup(&blob, g_repo, &id));
 | 
			
		||||
	cl_assert_equal_i(GIT_OBJ_BLOB, git_object_type((git_object *) blob));
 | 
			
		||||
	cl_assert(git_blob_rawcontent(blob));
 | 
			
		||||
	cl_assert_equal_s("", git_blob_rawcontent(blob));
 | 
			
		||||
	cl_assert_equal_i(0, git_blob_rawsize(blob));
 | 
			
		||||
	git_blob_free(blob);
 | 
			
		||||
}
 | 
			
		||||
@ -37,3 +39,19 @@ void test_odb_emptyobjects__read_tree(void)
 | 
			
		||||
	cl_assert_equal_p(NULL, git_tree_entry_byname(tree, "foo"));
 | 
			
		||||
	git_tree_free(tree);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void test_odb_emptyobjects__read_tree_odb(void)
 | 
			
		||||
{
 | 
			
		||||
	git_oid id;
 | 
			
		||||
	git_odb *odb;
 | 
			
		||||
	git_odb_object *tree_odb;
 | 
			
		||||
 | 
			
		||||
	cl_git_pass(git_oid_fromstr(&id, "4b825dc642cb6eb9a060e54bf8d69288fbee4904"));
 | 
			
		||||
	cl_git_pass(git_repository_odb(&odb, g_repo));
 | 
			
		||||
	cl_git_pass(git_odb_read(&tree_odb, odb, &id));
 | 
			
		||||
	cl_assert(git_odb_object_data(tree_odb));
 | 
			
		||||
	cl_assert_equal_s("", git_odb_object_data(tree_odb));
 | 
			
		||||
	cl_assert_equal_i(0, git_odb_object_size(tree_odb));
 | 
			
		||||
	git_odb_object_free(tree_odb);
 | 
			
		||||
	git_odb_free(odb);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user