Commit 92e87dd7 by Edward Thomson

rebase: provide NULL `exec` on non-EXEC operations

Users may want to try to pay attention to the `exec` field on all
rebase operations.
parent 57f45e7f
...@@ -168,10 +168,31 @@ GIT_INLINE(int) rebase_readoid( ...@@ -168,10 +168,31 @@ GIT_INLINE(int) rebase_readoid(
return 0; return 0;
} }
static git_rebase_operation *rebase_operation_alloc(
git_rebase *rebase,
git_rebase_operation_t type,
git_oid *id,
const char *exec)
{
git_rebase_operation *operation;
assert((type == GIT_REBASE_OPERATION_EXEC) == !id);
assert((type == GIT_REBASE_OPERATION_EXEC) == !!exec);
if ((operation = git_array_alloc(rebase->operations)) == NULL)
return NULL;
operation->type = type;
git_oid_cpy((git_oid *)&operation->id, id);
operation->exec = exec;
return operation;
}
static int rebase_open_merge(git_rebase *rebase) static int rebase_open_merge(git_rebase *rebase)
{ {
git_buf state_path = GIT_BUF_INIT, buf = GIT_BUF_INIT, cmt = GIT_BUF_INIT; git_buf state_path = GIT_BUF_INIT, buf = GIT_BUF_INIT, cmt = GIT_BUF_INIT;
git_oid current_id = {{0}}; git_oid id;
git_rebase_operation *operation; git_rebase_operation *operation;
size_t i, msgnum = 0, end; size_t i, msgnum = 0, end;
int error; int error;
...@@ -194,7 +215,7 @@ static int rebase_open_merge(git_rebase *rebase) ...@@ -194,7 +215,7 @@ static int rebase_open_merge(git_rebase *rebase)
goto done; goto done;
/* Read 'current' if it exists */ /* Read 'current' if it exists */
if ((error = rebase_readoid(&current_id, &buf, &state_path, CURRENT_FILE)) < 0 && if ((error = rebase_readoid(&id, &buf, &state_path, CURRENT_FILE)) < 0 &&
error != GIT_ENOTFOUND) error != GIT_ENOTFOUND)
goto done; goto done;
...@@ -203,14 +224,14 @@ static int rebase_open_merge(git_rebase *rebase) ...@@ -203,14 +224,14 @@ static int rebase_open_merge(git_rebase *rebase)
GITERR_CHECK_ARRAY(rebase->operations); GITERR_CHECK_ARRAY(rebase->operations);
for (i = 0; i < end; i++) { for (i = 0; i < end; i++) {
operation = git_array_alloc(rebase->operations);
GITERR_CHECK_ALLOC(operation);
git_buf_clear(&cmt); git_buf_clear(&cmt);
if ((error = git_buf_printf(&cmt, "cmt.%" PRIuZ, (i+1))) < 0 || if ((error = git_buf_printf(&cmt, "cmt.%" PRIuZ, (i+1))) < 0 ||
(error = rebase_readoid((git_oid *)&operation->id, &buf, &state_path, cmt.ptr)) < 0) (error = rebase_readoid(&id, &buf, &state_path, cmt.ptr)) < 0)
goto done; goto done;
operation = rebase_operation_alloc(rebase, GIT_REBASE_OPERATION_PICK, &id, NULL);
GITERR_CHECK_ALLOC(operation);
} }
/* Read 'onto_name' */ /* Read 'onto_name' */
...@@ -553,9 +574,7 @@ static int rebase_init_operations( ...@@ -553,9 +574,7 @@ static int rebase_init_operations(
if (merge) if (merge)
continue; continue;
operation = git_array_alloc(rebase->operations); operation = rebase_operation_alloc(rebase, GIT_REBASE_OPERATION_PICK, &id, NULL);
operation->type = GIT_REBASE_OPERATION_PICK;
git_oid_cpy((git_oid *)&operation->id, &id);
} }
error = 0; error = 0;
......
...@@ -42,6 +42,7 @@ static void test_operations(git_rebase *rebase, size_t expected_current) ...@@ -42,6 +42,7 @@ static void test_operations(git_rebase *rebase, size_t expected_current)
operation = git_rebase_operation_byindex(rebase, i); operation = git_rebase_operation_byindex(rebase, i);
cl_assert_equal_i(GIT_REBASE_OPERATION_PICK, operation->type); cl_assert_equal_i(GIT_REBASE_OPERATION_PICK, operation->type);
cl_assert_equal_oid(&expected_oid[i], &operation->id); cl_assert_equal_oid(&expected_oid[i], &operation->id);
cl_assert_equal_p(NULL, operation->exec);
} }
} }
......
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