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
f152f8ac
Commit
f152f8ac
authored
Aug 26, 2014
by
Edward Thomson
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
rebase: preload all operations
parent
b6b636a7
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
165 additions
and
125 deletions
+165
-125
include/git2/rebase.h
+2
-2
src/rebase.c
+151
-111
tests/rebase/merge.c
+12
-12
No files found.
include/git2/rebase.h
View file @
f152f8ac
...
...
@@ -156,13 +156,13 @@ GIT_EXTERN(int) git_rebase_open(git_rebase **out, git_repository *repo);
* working directory will be updated with the changes. If there are conflicts,
* you will need to address those before committing the changes.
*
* @param out
T
he rebase operation that is to be performed next
* @param out
Pointer to store t
he rebase operation that is to be performed next
* @param repo The rebase in progress
* @param checkout_opts Options to specify how the patch should be checked out
* @return Zero on success; -1 on failure.
*/
GIT_EXTERN
(
int
)
git_rebase_next
(
git_rebase_operation
*
operation
,
git_rebase_operation
*
*
operation
,
git_rebase
*
rebase
,
git_checkout_options
*
checkout_opts
);
...
...
src/rebase.c
View file @
f152f8ac
...
...
@@ -51,14 +51,6 @@ typedef enum {
GIT_REBASE_TYPE_INTERACTIVE
=
3
,
}
git_rebase_type_t
;
struct
git_rebase_merge
{
int32_t
msgnum
;
int32_t
end
;
char
*
onto_name
;
git_commit
*
current
;
};
struct
git_rebase
{
git_repository
*
repo
;
...
...
@@ -66,18 +58,17 @@ struct git_rebase {
char
*
state_path
;
int
head_detached
:
1
,
quiet
:
1
;
quiet
:
1
,
started
:
1
;
char
*
orig_head_name
;
git_oid
orig_head_id
;
git_oid
onto_id
;
char
*
onto_name
;
git_array_t
(
git_rebase_operation
)
operations
;
union
{
struct
git_rebase_merge
merge
;
};
size_t
current
;
};
#define GIT_REBASE_STATE_INIT {0}
...
...
@@ -118,79 +109,115 @@ done:
return
0
;
}
static
int
rebase_open_merge
(
git_rebase
*
rebas
e
)
GIT_INLINE
(
int
)
rebase_readfile
(
git_buf
*
out
,
git_buf
*
state_path
,
const
char
*
filenam
e
)
{
git_buf
path
=
GIT_BUF_INIT
,
msgnum
=
GIT_BUF_INIT
,
end
=
GIT_BUF_INIT
,
onto_name
=
GIT_BUF_INIT
,
current
=
GIT_BUF_INIT
;
git_oid
current_id
;
int
state_path_len
,
error
;
size_t
state_path_len
=
state_path
->
size
;
int
error
;
if
((
error
=
git_buf_puts
(
&
path
,
rebase
->
state_path
))
<
0
)
git_buf_clear
(
out
);
if
((
error
=
git_buf_joinpath
(
state_path
,
state_path
->
ptr
,
filename
))
<
0
||
(
error
=
git_futils_readbuffer
(
out
,
state_path
->
ptr
))
<
0
)
goto
done
;
state_path_len
=
git_buf_len
(
&
path
);
git_buf_rtrim
(
out
);
/* Read 'end' */
if
((
error
=
git_buf_joinpath
(
&
path
,
path
.
ptr
,
END_FILE
))
<
0
||
(
error
=
git_futils_readbuffer
(
&
end
,
path
.
ptr
))
<
0
)
goto
done
;
done
:
git_buf_truncate
(
state_path
,
state_path_len
);
return
error
;
}
git_buf_rtrim
(
&
end
);
GIT_INLINE
(
int
)
rebase_readint
(
size_t
*
out
,
git_buf
*
asc_out
,
git_buf
*
state_path
,
const
char
*
filename
)
{
int32_t
num
;
char
*
eol
;
int
error
=
0
;
if
((
error
=
git__strtol32
(
&
rebase
->
merge
.
end
,
end
.
ptr
,
NULL
,
10
))
<
0
)
goto
done
;
if
((
error
=
rebase_readfile
(
asc_out
,
state_path
,
filename
))
<
0
)
return
error
;
/* Read 'onto_name' */
git_buf_truncate
(
&
path
,
state_path_len
);
if
(
git__strtol32
(
&
num
,
asc_out
->
ptr
,
&
eol
,
10
)
<
0
||
num
<
0
||
*
eol
)
{
giterr_set
(
GITERR_REBASE
,
"The file '%s' contains an invalid numeric value"
,
filename
);
return
-
1
;
}
if
((
error
=
git_buf_joinpath
(
&
path
,
path
.
ptr
,
ONTO_NAME_FILE
))
<
0
||
(
error
=
git_futils_readbuffer
(
&
onto_name
,
path
.
ptr
))
<
0
)
goto
done
;
*
out
=
(
size_t
)
num
;
git_buf_rtrim
(
&
onto_name
);
return
0
;
}
rebase
->
merge
.
onto_name
=
git_buf_detach
(
&
onto_name
);
GIT_INLINE
(
int
)
rebase_readoid
(
git_oid
*
out
,
git_buf
*
str_out
,
git_buf
*
state_path
,
const
char
*
filename
)
{
int
error
;
/* Read 'msgnum' if it exists, otherwise let msgnum = 0 */
git_buf_truncate
(
&
path
,
state_path_len
)
;
if
((
error
=
rebase_readfile
(
str_out
,
state_path
,
filename
))
<
0
)
return
error
;
if
((
error
=
git_buf_joinpath
(
&
path
,
path
.
ptr
,
MSGNUM_FILE
))
<
0
)
goto
done
;
if
(
str_out
->
size
!=
GIT_OID_HEXSZ
||
git_oid_fromstr
(
out
,
str_out
->
ptr
)
<
0
)
{
giterr_set
(
GITERR_REBASE
,
"The file '%s' contains an invalid object ID"
,
filename
);
return
-
1
;
}
if
(
git_path_exists
(
path
.
ptr
))
{
if
((
error
=
git_futils_readbuffer
(
&
msgnum
,
path
.
ptr
))
<
0
)
goto
done
;
return
0
;
}
git_buf_rtrim
(
&
msgnum
);
static
int
rebase_open_merge
(
git_rebase
*
rebase
)
{
git_buf
state_path
=
GIT_BUF_INIT
,
buf
=
GIT_BUF_INIT
,
cmt
=
GIT_BUF_INIT
;
git_oid
current_id
=
{
0
};
git_rebase_operation
*
operation
;
size_t
i
,
msgnum
=
0
,
end
;
int
error
;
if
((
error
=
git__strtol32
(
&
rebase
->
merge
.
msgnum
,
msgnum
.
ptr
,
NULL
,
10
))
<
0
)
goto
done
;
}
if
((
error
=
git_buf_puts
(
&
state_path
,
rebase
->
state_path
))
<
0
)
goto
done
;
/* Read 'msgnum' if it exists (otherwise, let msgnum = 0) */
if
((
error
=
rebase_readint
(
&
msgnum
,
&
buf
,
&
state_path
,
MSGNUM_FILE
))
<
0
&&
error
!=
GIT_ENOTFOUND
)
goto
done
;
/* Read 'current' if it exists, otherwise let current = null */
git_buf_truncate
(
&
path
,
state_path_len
);
if
(
msgnum
)
{
rebase
->
started
=
1
;
rebase
->
current
=
msgnum
-
1
;
}
if
((
error
=
git_buf_joinpath
(
&
path
,
path
.
ptr
,
CURRENT_FILE
))
<
0
)
/* Read 'end' */
if
((
error
=
rebase_readint
(
&
end
,
&
buf
,
&
state_path
,
END_FILE
))
<
0
)
goto
done
;
if
(
git_path_exists
(
path
.
ptr
))
{
if
((
error
=
git_futils_readbuffer
(
&
current
,
path
.
ptr
))
<
0
)
goto
done
;
/* Read 'current' if it exists */
if
((
error
=
rebase_readoid
(
&
current_id
,
&
buf
,
&
state_path
,
CURRENT_FILE
))
<
0
&&
error
!=
GIT_ENOTFOUND
)
goto
done
;
/* Read cmt.* */
git_array_init_to_size
(
rebase
->
operations
,
end
);
GITERR_CHECK_ARRAY
(
rebase
->
operations
);
git_buf_rtrim
(
&
current
);
for
(
i
=
0
;
i
<
end
;
i
++
)
{
operation
=
git_array_alloc
(
rebase
->
operations
);
GITERR_CHECK_ALLOC
(
operation
);
if
((
error
=
git_oid_fromstr
(
&
current_id
,
current
.
ptr
))
<
0
||
(
error
=
git_commit_lookup
(
&
rebase
->
merge
.
current
,
rebase
->
repo
,
&
current_id
))
<
0
)
git_buf_clear
(
&
cmt
);
if
((
error
=
git_buf_printf
(
&
cmt
,
"cmt.%"
PRIuZ
,
(
i
+
1
)))
<
0
||
(
error
=
rebase_readoid
(
&
operation
->
id
,
&
buf
,
&
state_path
,
cmt
.
ptr
))
<
0
)
goto
done
;
}
/* Read 'onto_name' */
if
((
error
=
rebase_readfile
(
&
buf
,
&
state_path
,
ONTO_NAME_FILE
))
<
0
)
goto
done
;
rebase
->
onto_name
=
git_buf_detach
(
&
buf
);
done
:
git_buf_free
(
&
path
);
git_buf_free
(
&
msgnum
);
git_buf_free
(
&
end
);
git_buf_free
(
&
onto_name
);
git_buf_free
(
&
current
);
git_buf_free
(
&
cmt
);
git_buf_free
(
&
state_path
);
git_buf_free
(
&
buf
);
return
error
;
}
...
...
@@ -341,7 +368,7 @@ static int rebase_setupfiles_merge(git_rebase *rebase)
int
error
=
0
;
if
((
error
=
rebase_setupfile
(
rebase
,
END_FILE
,
-
1
,
"%d
\n
"
,
git_array_size
(
rebase
->
operations
)))
<
0
||
(
error
=
rebase_setupfile
(
rebase
,
ONTO_NAME_FILE
,
-
1
,
"%s
\n
"
,
rebase
->
merge
.
onto_name
))
<
0
)
(
error
=
rebase_setupfile
(
rebase
,
ONTO_NAME_FILE
,
-
1
,
"%s
\n
"
,
rebase
->
onto_name
))
<
0
)
goto
done
;
for
(
i
=
0
;
i
<
git_array_size
(
rebase
->
operations
);
i
++
)
{
...
...
@@ -542,10 +569,8 @@ static int rebase_init_merge(
if
(
rebase_init_operations
(
rebase
,
repo
,
branch
,
upstream
,
onto
)
<
0
)
return
-
1
;
rebase
->
merge
.
end
=
git_array_size
(
rebase
->
operations
);
rebase
->
merge
.
onto_name
=
git__strdup
(
rebase_onto_name
(
onto
));
GITERR_CHECK_ALLOC
(
rebase
->
merge
.
onto_name
);
rebase
->
onto_name
=
git__strdup
(
rebase_onto_name
(
onto
));
GITERR_CHECK_ALLOC
(
rebase
->
onto_name
);
return
0
;
}
...
...
@@ -647,6 +672,7 @@ static int normalize_checkout_opts(
git_checkout_options
*
checkout_opts
,
const
git_checkout_options
*
given_checkout_opts
)
{
git_commit
*
current_commit
=
NULL
;
int
error
=
0
;
if
(
given_checkout_opts
!=
NULL
)
...
...
@@ -663,64 +689,83 @@ static int normalize_checkout_opts(
if
(
rebase
->
type
==
GIT_REBASE_TYPE_MERGE
)
{
if
(
!
checkout_opts
->
our_label
)
checkout_opts
->
our_label
=
rebase
->
merge
.
onto_name
;
checkout_opts
->
our_label
=
rebase
->
onto_name
;
if
(
!
checkout_opts
->
their_label
)
checkout_opts
->
their_label
=
git_commit_summary
(
rebase
->
merge
.
current
);
if
(
!
checkout_opts
->
their_label
)
{
git_rebase_operation
*
operation
=
git_array_get
(
rebase
->
operations
,
rebase
->
current
);
if
((
error
=
git_commit_lookup
(
&
current_commit
,
rebase
->
repo
,
&
operation
->
id
))
<
0
)
goto
done
;
checkout_opts
->
their_label
=
git__strdup
(
git_commit_summary
(
current_commit
));
GITERR_CHECK_ALLOC
(
checkout_opts
->
their_label
);
}
}
else
{
abort
();
}
done
:
git_commit_free
(
current_commit
);
return
error
;
}
GIT_INLINE
(
int
)
rebase_movenext
(
git_rebase
*
rebase
)
{
size_t
next
=
rebase
->
started
?
rebase
->
current
+
1
:
0
;
if
(
next
==
git_array_size
(
rebase
->
operations
))
return
GIT_ITEROVER
;
rebase
->
started
=
1
;
rebase
->
current
=
next
;
return
0
;
}
static
int
rebase_next_merge
(
git_rebase_operation
*
out
,
git_rebase_operation
*
*
out
,
git_rebase
*
rebase
,
git_checkout_options
*
given_checkout_opts
)
{
git_buf
path
=
GIT_BUF_INIT
,
current
=
GIT_BUF_INIT
;
git_buf
path
=
GIT_BUF_INIT
;
git_checkout_options
checkout_opts
=
{
0
};
git_oid
current_id
;
git_commit
*
parent_commit
=
NULL
;
git_commit
*
current_commit
=
NULL
,
*
parent_commit
=
NULL
;
git_tree
*
current_tree
=
NULL
,
*
head_tree
=
NULL
,
*
parent_tree
=
NULL
;
git_index
*
index
=
NULL
;
git_rebase_operation
*
operation
;
char
current_idstr
[
GIT_OID_HEXSZ
];
unsigned
int
parent_count
;
int
error
;
if
(
rebase
->
merge
.
msgnum
==
rebase
->
merge
.
end
)
return
GIT_ITEROVER
;
rebase
->
merge
.
msgnum
++
;
*
out
=
NULL
;
if
((
error
=
git_buf_joinpath
(
&
path
,
rebase
->
state_path
,
"cmt."
))
<
0
||
(
error
=
git_buf_printf
(
&
path
,
"%d"
,
rebase
->
merge
.
msgnum
))
<
0
||
(
error
=
git_futils_readbuffer
(
&
current
,
path
.
ptr
))
<
0
)
if
((
error
=
rebase_movenext
(
rebase
))
<
0
)
goto
done
;
git_buf_rtrim
(
&
current
);
if
(
rebase
->
merge
.
current
)
git_commit_free
(
rebase
->
merge
.
current
);
operation
=
git_array_get
(
rebase
->
operations
,
rebase
->
current
);
if
((
error
=
git_oid_fromstr
(
&
current_id
,
current
.
ptr
))
<
0
||
(
error
=
git_commit_lookup
(
&
rebase
->
merge
.
current
,
rebase
->
repo
,
&
current_id
))
<
0
||
(
error
=
git_commit_tree
(
&
current_tree
,
rebase
->
merge
.
current
))
<
0
||
if
((
error
=
git_commit_lookup
(
&
current_commit
,
rebase
->
repo
,
&
operation
->
id
))
<
0
||
(
error
=
git_commit_tree
(
&
current_tree
,
current_commit
))
<
0
||
(
error
=
git_repository_head_tree
(
&
head_tree
,
rebase
->
repo
))
<
0
)
goto
done
;
if
((
parent_count
=
git_commit_parentcount
(
rebase
->
merge
.
curren
t
))
>
1
)
{
if
((
parent_count
=
git_commit_parentcount
(
current_commi
t
))
>
1
)
{
giterr_set
(
GITERR_REBASE
,
"Cannot rebase a merge commit"
);
error
=
-
1
;
goto
done
;
}
else
if
(
parent_count
)
{
if
((
error
=
git_commit_parent
(
&
parent_commit
,
rebase
->
merge
.
curren
t
,
0
))
<
0
||
if
((
error
=
git_commit_parent
(
&
parent_commit
,
current_commi
t
,
0
))
<
0
||
(
error
=
git_commit_tree
(
&
parent_tree
,
parent_commit
))
<
0
)
goto
done
;
}
if
((
error
=
rebase_setupfile
(
rebase
,
MSGNUM_FILE
,
-
1
,
"%d
\n
"
,
rebase
->
merge
.
msgnum
))
<
0
||
(
error
=
rebase_setupfile
(
rebase
,
CURRENT_FILE
,
-
1
,
"%s
\n
"
,
current
.
ptr
))
<
0
)
git_oid_fmt
(
current_idstr
,
&
operation
->
id
);
if
((
error
=
rebase_setupfile
(
rebase
,
MSGNUM_FILE
,
-
1
,
"%d
\n
"
,
rebase
->
current
+
1
))
<
0
||
(
error
=
rebase_setupfile
(
rebase
,
CURRENT_FILE
,
-
1
,
"%.*s
\n
"
,
GIT_OID_HEXSZ
,
current_idstr
))
<
0
)
goto
done
;
if
((
error
=
normalize_checkout_opts
(
rebase
,
&
checkout_opts
,
given_checkout_opts
))
<
0
||
...
...
@@ -729,8 +774,7 @@ static int rebase_next_merge(
(
error
=
git_checkout_index
(
rebase
->
repo
,
index
,
&
checkout_opts
))
<
0
)
goto
done
;
out
->
type
=
GIT_REBASE_OPERATION_PICK
;
memcpy
(
&
out
->
id
,
&
current_id
,
sizeof
(
git_oid
));
*
out
=
operation
;
done
:
git_index_free
(
index
);
...
...
@@ -738,14 +782,14 @@ done:
git_tree_free
(
head_tree
);
git_tree_free
(
parent_tree
);
git_commit_free
(
parent_commit
);
git_commit_free
(
current_commit
);
git_buf_free
(
&
path
);
git_buf_free
(
&
current
);
return
error
;
}
int
git_rebase_next
(
git_rebase_operation
*
out
,
git_rebase_operation
*
*
out
,
git_rebase
*
rebase
,
git_checkout_options
*
checkout_opts
)
{
...
...
@@ -753,8 +797,6 @@ int git_rebase_next(
assert
(
out
&&
rebase
);
memset
(
out
,
0
,
sizeof
(
git_rebase_operation
));
switch
(
rebase
->
type
)
{
case
GIT_REBASE_TYPE_MERGE
:
error
=
rebase_next_merge
(
out
,
rebase
,
checkout_opts
);
...
...
@@ -776,7 +818,8 @@ static int rebase_commit_merge(
{
git_index
*
index
=
NULL
;
git_reference
*
head
=
NULL
;
git_commit
*
head_commit
=
NULL
,
*
commit
=
NULL
;
git_commit
*
current_commit
=
NULL
,
*
head_commit
=
NULL
,
*
commit
=
NULL
;
git_rebase_operation
*
operation
;
git_tree
*
head_tree
=
NULL
,
*
tree
=
NULL
;
git_diff
*
diff
=
NULL
;
git_oid
tree_id
;
...
...
@@ -784,11 +827,8 @@ static int rebase_commit_merge(
char
old_idstr
[
GIT_OID_HEXSZ
],
new_idstr
[
GIT_OID_HEXSZ
];
int
error
;
if
(
!
rebase
->
merge
.
msgnum
||
!
rebase
->
merge
.
current
)
{
giterr_set
(
GITERR_REBASE
,
"No rebase-merge state files exist"
);
error
=
-
1
;
goto
done
;
}
operation
=
git_array_get
(
rebase
->
operations
,
rebase
->
current
);
assert
(
operation
);
if
((
error
=
git_repository_index
(
&
index
,
rebase
->
repo
))
<
0
)
goto
done
;
...
...
@@ -799,7 +839,8 @@ static int rebase_commit_merge(
goto
done
;
}
if
((
error
=
git_repository_head
(
&
head
,
rebase
->
repo
))
<
0
||
if
((
error
=
git_commit_lookup
(
&
current_commit
,
rebase
->
repo
,
&
operation
->
id
))
<
0
||
(
error
=
git_repository_head
(
&
head
,
rebase
->
repo
))
<
0
||
(
error
=
git_reference_peel
((
git_object
**
)
&
head_commit
,
head
,
GIT_OBJ_COMMIT
))
<
0
||
(
error
=
git_commit_tree
(
&
head_tree
,
head_commit
))
<
0
||
(
error
=
git_diff_tree_to_index
(
&
diff
,
rebase
->
repo
,
head_tree
,
index
,
NULL
))
<
0
)
...
...
@@ -816,11 +857,11 @@ static int rebase_commit_merge(
goto
done
;
if
(
!
author
)
author
=
git_commit_author
(
rebase
->
merge
.
curren
t
);
author
=
git_commit_author
(
current_commi
t
);
if
(
!
message
)
{
message_encoding
=
git_commit_message_encoding
(
rebase
->
merge
.
curren
t
);
message
=
git_commit_message
(
rebase
->
merge
.
curren
t
);
message_encoding
=
git_commit_message_encoding
(
current_commi
t
);
message
=
git_commit_message
(
current_commi
t
);
}
if
((
error
=
git_commit_create
(
commit_id
,
rebase
->
repo
,
NULL
,
author
,
...
...
@@ -831,7 +872,7 @@ static int rebase_commit_merge(
rebase
->
repo
,
NULL
,
"HEAD"
,
commit_id
,
committer
,
"rebase"
))
<
0
)
goto
done
;
git_oid_fmt
(
old_idstr
,
git_commit_id
(
rebase
->
merge
.
curren
t
));
git_oid_fmt
(
old_idstr
,
git_commit_id
(
current_commi
t
));
git_oid_fmt
(
new_idstr
,
commit_id
);
error
=
rebase_setupfile
(
rebase
,
REWRITTEN_FILE
,
O_CREAT
|
O_WRONLY
|
O_APPEND
,
...
...
@@ -844,6 +885,7 @@ done:
git_tree_free
(
tree
);
git_tree_free
(
head_tree
);
git_commit_free
(
head_commit
);
git_commit_free
(
current_commit
);
git_reference_free
(
head
);
git_index_free
(
index
);
...
...
@@ -1050,11 +1092,9 @@ void git_rebase_free(git_rebase *rebase)
if
(
rebase
==
NULL
)
return
;
if
(
rebase
->
type
==
GIT_REBASE_TYPE_MERGE
)
{
git__free
(
rebase
->
merge
.
onto_name
);
git_commit_free
(
rebase
->
merge
.
current
);
}
git__free
(
rebase
->
onto_name
);
git__free
(
rebase
->
orig_head_name
);
git__free
(
rebase
->
state_path
);
git_array_clear
(
rebase
->
operations
);
git__free
(
rebase
);
}
tests/rebase/merge.c
View file @
f152f8ac
...
...
@@ -27,7 +27,7 @@ void test_rebase_merge__next(void)
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_merge_head
*
branch_head
,
*
upstream_head
;
git_rebase_operation
rebase_operation
;
git_rebase_operation
*
rebase_operation
;
git_checkout_options
checkout_opts
=
GIT_CHECKOUT_OPTIONS_INIT
;
git_status_list
*
status_list
;
const
git_status_entry
*
status_entry
;
...
...
@@ -47,8 +47,8 @@ void test_rebase_merge__next(void)
git_oid_fromstr
(
&
pick_id
,
"da9c51a23d02d931a486f45ad18cda05cf5d2b94"
);
cl_assert_equal_i
(
GIT_REBASE_OPERATION_PICK
,
rebase_operation
.
type
);
cl_assert_equal_oid
(
&
pick_id
,
&
rebase_operation
.
id
);
cl_assert_equal_i
(
GIT_REBASE_OPERATION_PICK
,
rebase_operation
->
type
);
cl_assert_equal_oid
(
&
pick_id
,
&
rebase_operation
->
id
);
cl_assert_equal_file
(
"da9c51a23d02d931a486f45ad18cda05cf5d2b94
\n
"
,
41
,
"rebase/.git/rebase-merge/current"
);
cl_assert_equal_file
(
"1
\n
"
,
2
,
"rebase/.git/rebase-merge/msgnum"
);
...
...
@@ -74,7 +74,7 @@ void test_rebase_merge__next_with_conflicts(void)
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_merge_head
*
branch_head
,
*
upstream_head
;
git_rebase_operation
rebase_operation
;
git_rebase_operation
*
rebase_operation
;
git_checkout_options
checkout_opts
=
GIT_CHECKOUT_OPTIONS_INIT
;
git_status_list
*
status_list
;
const
git_status_entry
*
status_entry
;
...
...
@@ -114,8 +114,8 @@ void test_rebase_merge__next_with_conflicts(void)
git_oid_fromstr
(
&
pick_id
,
"33f915f9e4dbd9f4b24430e48731a59b45b15500"
);
cl_assert_equal_i
(
GIT_REBASE_OPERATION_PICK
,
rebase_operation
.
type
);
cl_assert_equal_oid
(
&
pick_id
,
&
rebase_operation
.
id
);
cl_assert_equal_i
(
GIT_REBASE_OPERATION_PICK
,
rebase_operation
->
type
);
cl_assert_equal_oid
(
&
pick_id
,
&
rebase_operation
->
id
);
cl_assert_equal_file
(
"33f915f9e4dbd9f4b24430e48731a59b45b15500
\n
"
,
41
,
"rebase/.git/rebase-merge/current"
);
cl_assert_equal_file
(
"1
\n
"
,
2
,
"rebase/.git/rebase-merge/msgnum"
);
...
...
@@ -140,7 +140,7 @@ void test_rebase_merge__next_stops_with_iterover(void)
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_merge_head
*
branch_head
,
*
upstream_head
;
git_rebase_operation
rebase_operation
;
git_rebase_operation
*
rebase_operation
;
git_checkout_options
checkout_opts
=
GIT_CHECKOUT_OPTIONS_INIT
;
git_oid
commit_id
;
int
error
;
...
...
@@ -193,7 +193,7 @@ void test_rebase_merge__commit(void)
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_merge_head
*
branch_head
,
*
upstream_head
;
git_rebase_operation
rebase_operation
;
git_rebase_operation
*
rebase_operation
;
git_checkout_options
checkout_opts
=
GIT_CHECKOUT_OPTIONS_INIT
;
git_oid
commit_id
,
tree_id
,
parent_id
;
git_signature
*
author
;
...
...
@@ -255,7 +255,7 @@ void test_rebase_merge__commit_updates_rewritten(void)
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_merge_head
*
branch_head
,
*
upstream_head
;
git_rebase_operation
rebase_operation
;
git_rebase_operation
*
rebase_operation
;
git_checkout_options
checkout_opts
=
GIT_CHECKOUT_OPTIONS_INIT
;
git_oid
commit_id
;
...
...
@@ -294,7 +294,7 @@ void test_rebase_merge__commit_drops_already_applied(void)
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_merge_head
*
branch_head
,
*
upstream_head
;
git_rebase_operation
rebase_operation
;
git_rebase_operation
*
rebase_operation
;
git_checkout_options
checkout_opts
=
GIT_CHECKOUT_OPTIONS_INIT
;
git_oid
commit_id
;
int
error
;
...
...
@@ -335,7 +335,7 @@ void test_rebase_merge__finish(void)
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
,
*
head_ref
;
git_merge_head
*
branch_head
,
*
upstream_head
;
git_rebase_operation
rebase_operation
;
git_rebase_operation
*
rebase_operation
;
git_checkout_options
checkout_opts
=
GIT_CHECKOUT_OPTIONS_INIT
;
git_oid
commit_id
;
git_reflog
*
reflog
;
...
...
@@ -398,7 +398,7 @@ static void test_copy_note(
git_reference
*
branch_ref
,
*
upstream_ref
;
git_merge_head
*
branch_head
,
*
upstream_head
;
git_commit
*
branch_commit
;
git_rebase_operation
rebase_operation
;
git_rebase_operation
*
rebase_operation
;
git_checkout_options
checkout_opts
=
GIT_CHECKOUT_OPTIONS_INIT
;
git_oid
note_id
,
commit_id
;
git_note
*
note
=
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