Commit 35221441 by Sascha Cunz

Checkout: Don't assert if treeish is NULL

In git_checkout_tree, the first check tests if either repo or treeish is
NULL and says that eithor of them has to have a valid value. But there
is no code to handle the treeish == NULL case.

So, do something meaningful in that case: use HEAD instead.
parent 10749f6c
...@@ -280,7 +280,7 @@ GIT_EXTERN(int) git_checkout_index( ...@@ -280,7 +280,7 @@ GIT_EXTERN(int) git_checkout_index(
* *
* @param repo repository to check out (must be non-bare) * @param repo repository to check out (must be non-bare)
* @param treeish a commit, tag or tree which content will be used to update * @param treeish a commit, tag or tree which content will be used to update
* the working directory * the working directory (or NULL to use HEAD)
* @param opts specifies checkout options (may be NULL) * @param opts specifies checkout options (may be NULL)
* @return 0 on success, GIT_ERROR otherwise (use giterr_last for information * @return 0 on success, GIT_ERROR otherwise (use giterr_last for information
* about the error) * about the error)
......
...@@ -2073,11 +2073,22 @@ int git_checkout_tree( ...@@ -2073,11 +2073,22 @@ int git_checkout_tree(
if (!repo) if (!repo)
repo = git_object_owner(treeish); repo = git_object_owner(treeish);
if (treeish) {
if (git_object_peel((git_object **)&tree, treeish, GIT_OBJ_TREE) < 0) { if (git_object_peel((git_object **)&tree, treeish, GIT_OBJ_TREE) < 0) {
giterr_set( giterr_set(
GITERR_CHECKOUT, "Provided object cannot be peeled to a tree"); GITERR_CHECKOUT, "Provided object cannot be peeled to a tree");
return -1; return -1;
} }
}
else {
if ((error = checkout_lookup_head_tree(&tree, repo)) < 0) {
if (error != GIT_EUNBORNBRANCH)
giterr_set(
GITERR_CHECKOUT,
"HEAD could not be peeled to a tree and no treeish given");
return error;
}
}
if (!(error = git_iterator_for_tree(&tree_i, tree, 0, NULL, NULL))) if (!(error = git_iterator_for_tree(&tree_i, tree, 0, NULL, NULL)))
error = git_checkout_iterator(tree_i, opts); error = git_checkout_iterator(tree_i, opts);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment