Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
git2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
git2
Commits
b23c206e
Commit
b23c206e
authored
Feb 15, 2015
by
Carlos Martín Nieto
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2903 from ethomson/rebase
Fixups for rebase
parents
57f45e7f
ffbd51ed
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
108 additions
and
20 deletions
+108
-20
include/git2/rebase.h
+2
-1
src/rebase.c
+56
-19
tests/rebase/iterator.c
+1
-0
tests/rebase/setup.c
+49
-0
No files found.
include/git2/rebase.h
View file @
b23c206e
...
@@ -133,7 +133,8 @@ GIT_EXTERN(int) git_rebase_init_options(
...
@@ -133,7 +133,8 @@ GIT_EXTERN(int) git_rebase_init_options(
*
*
* @param out Pointer to store the rebase object
* @param out Pointer to store the rebase object
* @param repo The repository to perform the rebase
* @param repo The repository to perform the rebase
* @param branch The terminal commit to rebase
* @param branch The terminal commit to rebase, or NULL to rebase the
* current branch
* @param upstream The commit to begin rebasing from, or NULL to rebase all
* @param upstream The commit to begin rebasing from, or NULL to rebase all
* reachable commits
* reachable commits
* @param onto The branch to rebase onto, or NULL to rebase onto the given
* @param onto The branch to rebase onto, or NULL to rebase onto the given
...
...
src/rebase.c
View file @
b23c206e
...
@@ -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
;
...
@@ -589,11 +608,21 @@ static int rebase_init(
...
@@ -589,11 +608,21 @@ static int rebase_init(
const
git_annotated_commit
*
onto
,
const
git_annotated_commit
*
onto
,
const
git_rebase_options
*
opts
)
const
git_rebase_options
*
opts
)
{
{
git_reference
*
head_ref
=
NULL
;
git_annotated_commit
*
head_branch
=
NULL
;
git_buf
state_path
=
GIT_BUF_INIT
;
git_buf
state_path
=
GIT_BUF_INIT
;
int
error
;
int
error
;
if
((
error
=
git_buf_joinpath
(
&
state_path
,
repo
->
path_repository
,
REBASE_MERGE_DIR
))
<
0
)
if
((
error
=
git_buf_joinpath
(
&
state_path
,
repo
->
path_repository
,
REBASE_MERGE_DIR
))
<
0
)
return
error
;
goto
done
;
if
(
!
branch
)
{
if
((
error
=
git_repository_head
(
&
head_ref
,
repo
))
<
0
||
(
error
=
git_annotated_commit_from_ref
(
&
head_branch
,
repo
,
head_ref
))
<
0
)
goto
done
;
branch
=
head_branch
;
}
rebase
->
repo
=
repo
;
rebase
->
repo
=
repo
;
rebase
->
type
=
GIT_REBASE_TYPE_MERGE
;
rebase
->
type
=
GIT_REBASE_TYPE_MERGE
;
...
@@ -611,6 +640,10 @@ static int rebase_init(
...
@@ -611,6 +640,10 @@ static int rebase_init(
git_buf_free
(
&
state_path
);
git_buf_free
(
&
state_path
);
done
:
git_reference_free
(
head_ref
);
git_annotated_commit_free
(
head_branch
);
return
error
;
return
error
;
}
}
...
@@ -625,12 +658,12 @@ int git_rebase_init(
...
@@ -625,12 +658,12 @@ int git_rebase_init(
{
{
git_rebase
*
rebase
=
NULL
;
git_rebase
*
rebase
=
NULL
;
git_rebase_options
opts
;
git_rebase_options
opts
;
git_reference
*
head_ref
=
NULL
;
git_buf
reflog
=
GIT_BUF_INIT
;
git_buf
reflog
=
GIT_BUF_INIT
;
git_commit
*
onto_commit
=
NULL
;
git_checkout_options
checkout_opts
=
GIT_CHECKOUT_OPTIONS_INIT
;
git_checkout_options
checkout_opts
=
GIT_CHECKOUT_OPTIONS_INIT
;
int
error
;
int
error
;
assert
(
repo
&&
branch
&&
(
upstream
||
onto
));
assert
(
repo
&&
(
upstream
||
onto
));
*
out
=
NULL
;
*
out
=
NULL
;
...
@@ -639,24 +672,28 @@ int git_rebase_init(
...
@@ -639,24 +672,28 @@ int git_rebase_init(
if
(
!
onto
)
if
(
!
onto
)
onto
=
upstream
;
onto
=
upstream
;
checkout_opts
.
checkout_strategy
=
GIT_CHECKOUT_
FORC
E
;
checkout_opts
.
checkout_strategy
=
GIT_CHECKOUT_
SAF
E
;
if
((
error
=
rebase_normalize_opts
(
repo
,
&
opts
,
given_opts
))
<
0
||
if
((
error
=
rebase_normalize_opts
(
repo
,
&
opts
,
given_opts
))
<
0
||
(
error
=
git_repository__ensure_not_bare
(
repo
,
"rebase"
))
<
0
||
(
error
=
git_repository__ensure_not_bare
(
repo
,
"rebase"
))
<
0
||
(
error
=
rebase_ensure_not_in_progress
(
repo
))
<
0
||
(
error
=
rebase_ensure_not_in_progress
(
repo
))
<
0
||
(
error
=
rebase_ensure_not_dirty
(
repo
))
<
0
)
(
error
=
rebase_ensure_not_dirty
(
repo
))
<
0
||
(
error
=
git_commit_lookup
(
&
onto_commit
,
repo
,
git_annotated_commit_id
(
onto
)))
<
0
)
return
error
;
return
error
;
rebase
=
git__calloc
(
1
,
sizeof
(
git_rebase
));
rebase
=
git__calloc
(
1
,
sizeof
(
git_rebase
));
GITERR_CHECK_ALLOC
(
rebase
);
GITERR_CHECK_ALLOC
(
rebase
);
if
((
error
=
rebase_init
(
rebase
,
repo
,
branch
,
upstream
,
onto
,
&
opts
))
<
0
||
if
((
error
=
rebase_init
(
rebase
,
repo
,
branch
,
upstream
,
onto
,
&
opts
))
<
0
||
(
error
=
rebase_setupfiles
(
rebase
))
<
0
||
(
error
=
rebase_setupfiles
(
rebase
))
<
0
||
(
error
=
git_buf_printf
(
&
reflog
,
(
error
=
git_buf_printf
(
&
reflog
,
"rebase: checkout %s"
,
rebase_onto_name
(
onto
)))
<
0
||
"rebase: checkout %s"
,
rebase_onto_name
(
onto
)))
<
0
||
(
error
=
git_reference_create
(
&
head_ref
,
repo
,
GIT_HEAD_FILE
,
(
error
=
git_checkout_tree
(
git_annotated_commit_id
(
onto
),
1
,
signature
,
reflog
.
ptr
))
<
0
||
repo
,
(
git_object
*
)
onto_commit
,
&
checkout_opts
))
<
0
||
(
error
=
git_checkout_head
(
repo
,
&
checkout_opts
))
<
0
)
(
error
=
git_repository_set_head_detached
(
repo
,
git_annotated_commit_id
(
onto
),
signature
,
reflog
.
ptr
))
<
0
)
goto
done
;
goto
done
;
*
out
=
rebase
;
*
out
=
rebase
;
...
@@ -667,7 +704,7 @@ done:
...
@@ -667,7 +704,7 @@ done:
git_rebase_free
(
rebase
);
git_rebase_free
(
rebase
);
}
}
git_
reference_free
(
head_ref
);
git_
commit_free
(
onto_commit
);
git_buf_free
(
&
reflog
);
git_buf_free
(
&
reflog
);
rebase_opts_free
(
&
opts
);
rebase_opts_free
(
&
opts
);
...
...
tests/rebase/iterator.c
View file @
b23c206e
...
@@ -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
);
}
}
}
}
...
...
tests/rebase/setup.c
View file @
b23c206e
...
@@ -293,6 +293,55 @@ void test_rebase_setup__orphan_branch(void)
...
@@ -293,6 +293,55 @@ void test_rebase_setup__orphan_branch(void)
git_rebase_free
(
rebase
);
git_rebase_free
(
rebase
);
}
}
/* git checkout beef && git rebase --merge master */
void
test_rebase_setup__merge_null_branch_uses_HEAD
(
void
)
{
git_rebase
*
rebase
;
git_reference
*
upstream_ref
;
git_annotated_commit
*
upstream_head
;
git_reference
*
head
;
git_commit
*
head_commit
;
git_oid
head_id
;
git_checkout_options
checkout_opts
=
GIT_CHECKOUT_OPTIONS_INIT
;
checkout_opts
.
checkout_strategy
=
GIT_CHECKOUT_FORCE
;
cl_assert_equal_i
(
GIT_REPOSITORY_STATE_NONE
,
git_repository_state
(
repo
));
cl_git_pass
(
git_repository_set_head
(
repo
,
"refs/heads/beef"
,
NULL
,
NULL
));
cl_git_pass
(
git_checkout_head
(
repo
,
&
checkout_opts
));
cl_git_pass
(
git_reference_lookup
(
&
upstream_ref
,
repo
,
"refs/heads/master"
));
cl_git_pass
(
git_annotated_commit_from_ref
(
&
upstream_head
,
repo
,
upstream_ref
));
cl_git_pass
(
git_rebase_init
(
&
rebase
,
repo
,
NULL
,
upstream_head
,
NULL
,
signature
,
NULL
));
cl_assert_equal_i
(
GIT_REPOSITORY_STATE_REBASE_MERGE
,
git_repository_state
(
repo
));
git_oid_fromstr
(
&
head_id
,
"efad0b11c47cb2f0220cbd6f5b0f93bb99064b00"
);
cl_git_pass
(
git_repository_head
(
&
head
,
repo
));
cl_git_pass
(
git_reference_peel
((
git_object
**
)
&
head_commit
,
head
,
GIT_OBJ_COMMIT
));
cl_assert_equal_oid
(
&
head_id
,
git_commit_id
(
head_commit
));
cl_assert_equal_file
(
"b146bd7608eac53d9bf9e1a6963543588b555c64
\n
"
,
41
,
"rebase/.git/ORIG_HEAD"
);
cl_assert_equal_file
(
"da9c51a23d02d931a486f45ad18cda05cf5d2b94
\n
"
,
41
,
"rebase/.git/rebase-merge/cmt.1"
);
cl_assert_equal_file
(
"8d1f13f93c4995760ac07d129246ac1ff64c0be9
\n
"
,
41
,
"rebase/.git/rebase-merge/cmt.2"
);
cl_assert_equal_file
(
"3069cc907e6294623e5917ef6de663928c1febfb
\n
"
,
41
,
"rebase/.git/rebase-merge/cmt.3"
);
cl_assert_equal_file
(
"588e5d2f04d49707fe4aab865e1deacaf7ef6787
\n
"
,
41
,
"rebase/.git/rebase-merge/cmt.4"
);
cl_assert_equal_file
(
"b146bd7608eac53d9bf9e1a6963543588b555c64
\n
"
,
41
,
"rebase/.git/rebase-merge/cmt.5"
);
cl_assert_equal_file
(
"5
\n
"
,
2
,
"rebase/.git/rebase-merge/end"
);
cl_assert_equal_file
(
"efad0b11c47cb2f0220cbd6f5b0f93bb99064b00
\n
"
,
41
,
"rebase/.git/rebase-merge/onto"
);
cl_assert_equal_file
(
"master
\n
"
,
7
,
"rebase/.git/rebase-merge/onto_name"
);
cl_assert_equal_file
(
"b146bd7608eac53d9bf9e1a6963543588b555c64
\n
"
,
41
,
"rebase/.git/rebase-merge/orig-head"
);
git_commit_free
(
head_commit
);
git_reference_free
(
head
);
git_annotated_commit_free
(
upstream_head
);
git_reference_free
(
upstream_ref
);
git_rebase_free
(
rebase
);
}
static
int
rebase_is_blocked
(
void
)
static
int
rebase_is_blocked
(
void
)
{
{
git_rebase
*
rebase
=
NULL
;
git_rebase
*
rebase
=
NULL
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment