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
bf9e8cc8
Commit
bf9e8cc8
authored
Jul 20, 2012
by
nulltoken
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
branch: make git_branch_move() reference based
parent
abee7bd3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
41 additions
and
49 deletions
+41
-49
include/git2/branch.h
+4
-9
src/branch.c
+16
-12
tests-clar/refs/branches/move.c
+21
-28
No files found.
include/git2/branch.h
View file @
bf9e8cc8
...
@@ -96,24 +96,19 @@ GIT_EXTERN(int) git_branch_foreach(
...
@@ -96,24 +96,19 @@ GIT_EXTERN(int) git_branch_foreach(
);
);
/**
/**
* Move/rename an existing branch reference.
* Move/rename an existing
local
branch reference.
*
*
* @param repo Repository where lives the branch.
* @param branch Current underlying reference of the branch.
*
* @param old_branch_name Current name of the branch to be moved;
* this name is validated for consistency.
*
*
* @param new_branch_name Target name of the branch once the move
* @param new_branch_name Target name of the branch once the move
* is performed; this name is validated for consistency.
* is performed; this name is validated for consistency.
*
*
* @param force Overwrite existing branch.
* @param force Overwrite existing branch.
*
*
* @return 0 on success, GIT_ENOTFOUND if the branch
* @return 0 on success, or an error code.
* doesn't exist or an error code.
*/
*/
GIT_EXTERN
(
int
)
git_branch_move
(
GIT_EXTERN
(
int
)
git_branch_move
(
git_repository
*
repo
,
git_reference
*
branch
,
const
char
*
old_branch_name
,
const
char
*
new_branch_name
,
const
char
*
new_branch_name
,
int
force
);
int
force
);
...
...
src/branch.c
View file @
bf9e8cc8
...
@@ -180,27 +180,31 @@ int git_branch_foreach(
...
@@ -180,27 +180,31 @@ int git_branch_foreach(
return
git_reference_foreach
(
repo
,
GIT_REF_LISTALL
,
&
branch_foreach_cb
,
(
void
*
)
&
filter
);
return
git_reference_foreach
(
repo
,
GIT_REF_LISTALL
,
&
branch_foreach_cb
,
(
void
*
)
&
filter
);
}
}
int
git_branch_move
(
git_repository
*
repo
,
const
char
*
old_branch_name
,
const
char
*
new_branch_name
,
int
force
)
static
int
not_a_local_branch
(
git_reference
*
ref
)
{
{
git
_reference
*
reference
=
NULL
;
git
err_set
(
GITERR_INVALID
,
"Reference '%s' is not a local branch."
,
git_reference_name
(
ref
))
;
git_buf
old_reference_name
=
GIT_BUF_INIT
,
new_reference_name
=
GIT_BUF_INIT
;
return
-
1
;
int
error
=
0
;
}
if
((
error
=
git_buf_joinpath
(
&
old_reference_name
,
GIT_REFS_HEADS_DIR
,
old_branch_name
))
<
0
)
int
git_branch_move
(
goto
cleanup
;
git_reference
*
branch
,
const
char
*
new_branch_name
,
int
force
)
{
git_buf
new_reference_name
=
GIT_BUF_INIT
;
int
error
;
/* We need to be able to return GIT_ENOTFOUND */
assert
(
branch
&&
new_branch_name
);
if
((
error
=
git_reference_lookup
(
&
reference
,
repo
,
git_buf_cstr
(
&
old_reference_name
)))
<
0
)
goto
cleanup
;
if
(
!
git_reference_is_branch
(
branch
))
return
not_a_local_branch
(
branch
);
if
((
error
=
git_buf_joinpath
(
&
new_reference_name
,
GIT_REFS_HEADS_DIR
,
new_branch_name
))
<
0
)
if
((
error
=
git_buf_joinpath
(
&
new_reference_name
,
GIT_REFS_HEADS_DIR
,
new_branch_name
))
<
0
)
goto
cleanup
;
goto
cleanup
;
error
=
git_reference_rename
(
reference
,
git_buf_cstr
(
&
new_reference_name
),
force
);
error
=
git_reference_rename
(
branch
,
git_buf_cstr
(
&
new_reference_name
),
force
);
cleanup:
cleanup:
git_reference_free
(
reference
);
git_buf_free
(
&
old_reference_name
);
git_buf_free
(
&
new_reference_name
);
git_buf_free
(
&
new_reference_name
);
return
error
;
return
error
;
...
...
tests-clar/refs/branches/move.c
View file @
bf9e8cc8
#include "clar_libgit2.h"
#include "clar_libgit2.h"
#include "refs.h"
static
git_repository
*
repo
;
static
git_repository
*
repo
;
static
git_reference
*
ref
;
void
test_refs_branches_move__initialize
(
void
)
void
test_refs_branches_move__initialize
(
void
)
{
{
cl_fixture_sandbox
(
"testrepo.git"
);
repo
=
cl_git_sandbox_init
(
"testrepo.git"
);
cl_git_pass
(
git_repository_open
(
&
repo
,
"testrepo.git"
));
cl_git_pass
(
git_reference_lookup
(
&
ref
,
repo
,
"refs/heads/br2"
));
}
}
void
test_refs_branches_move__cleanup
(
void
)
void
test_refs_branches_move__cleanup
(
void
)
{
{
git_repository_free
(
repo
);
git_reference_free
(
ref
);
cl_git_sandbox_cleanup
();
cl_fixture_cleanup
(
"testrepo.git"
);
}
}
#define NEW_BRANCH_NAME "new-branch-on-the-block"
#define NEW_BRANCH_NAME "new-branch-on-the-block"
void
test_refs_branches_move__can_move_a_local_branch
(
void
)
void
test_refs_branches_move__can_move_a_local_branch
(
void
)
{
{
cl_git_pass
(
git_branch_move
(
repo
,
"br2"
,
NEW_BRANCH_NAME
,
0
));
cl_git_pass
(
git_branch_move
(
ref
,
NEW_BRANCH_NAME
,
0
));
cl_assert_equal_s
(
GIT_REFS_HEADS_DIR
NEW_BRANCH_NAME
,
git_reference_name
(
ref
));
}
}
void
test_refs_branches_move__can_move_a_local_branch_to_a_different_namespace
(
void
)
void
test_refs_branches_move__can_move_a_local_branch_to_a_different_namespace
(
void
)
{
{
/* Downward */
/* Downward */
cl_git_pass
(
git_branch_move
(
re
po
,
"br2"
,
"somewhere/"
NEW_BRANCH_NAME
,
0
));
cl_git_pass
(
git_branch_move
(
re
f
,
"somewhere/"
NEW_BRANCH_NAME
,
0
));
/* Upward */
/* Upward */
cl_git_pass
(
git_branch_move
(
re
po
,
"somewhere/"
NEW_BRANCH_NAME
,
"br2"
,
0
));
cl_git_pass
(
git_branch_move
(
re
f
,
"br2"
,
0
));
}
}
void
test_refs_branches_move__can_move_a_local_branch_to_a_partially_colliding_namespace
(
void
)
void
test_refs_branches_move__can_move_a_local_branch_to_a_partially_colliding_namespace
(
void
)
{
{
/* Downward */
/* Downward */
cl_git_pass
(
git_branch_move
(
re
po
,
"br2"
,
"br2/"
NEW_BRANCH_NAME
,
0
));
cl_git_pass
(
git_branch_move
(
re
f
,
"br2/"
NEW_BRANCH_NAME
,
0
));
/* Upward */
/* Upward */
cl_git_pass
(
git_branch_move
(
re
po
,
"br2/"
NEW_BRANCH_NAME
,
"br2"
,
0
));
cl_git_pass
(
git_branch_move
(
re
f
,
"br2"
,
0
));
}
}
void
test_refs_branches_move__can_not_move_a_branch_if_its_destination_name_collide_with_an_existing_one
(
void
)
void
test_refs_branches_move__can_not_move_a_branch_if_its_destination_name_collide_with_an_existing_one
(
void
)
{
{
cl_git_fail
(
git_branch_move
(
re
po
,
"br2"
,
"master"
,
0
));
cl_git_fail
(
git_branch_move
(
re
f
,
"master"
,
0
));
}
}
void
test_refs_branches_move__can_not_move_a_non_
existing_
branch
(
void
)
void
test_refs_branches_move__can_not_move_a_non_branch
(
void
)
{
{
cl_git_fail
(
git_branch_move
(
repo
,
"i-am-no-branch"
,
NEW_BRANCH_NAME
,
0
));
git_reference
*
tag
;
}
void
test_refs_branches_move__can_force_move_over_an_existing_branch
(
void
)
cl_git_pass
(
git_reference_lookup
(
&
tag
,
repo
,
"refs/tags/e90810b"
));
{
cl_git_fail
(
git_branch_move
(
tag
,
NEW_BRANCH_NAME
,
0
));
cl_git_pass
(
git_branch_move
(
repo
,
"br2"
,
"master"
,
1
));
}
void
test_refs_branches_move__can_not_move_a_branch_through_its_canonical_name
(
void
)
git_reference_free
(
tag
);
{
cl_git_fail
(
git_branch_move
(
repo
,
"refs/heads/br2"
,
NEW_BRANCH_NAME
,
1
));
}
}
void
test_refs_branches_move__
moving_a_non_exisiting_branch_returns_ENOTFOUND
(
void
)
void
test_refs_branches_move__
can_force_move_over_an_existing_branch
(
void
)
{
{
int
error
;
cl_git_pass
(
git_branch_move
(
ref
,
"master"
,
1
));
error
=
git_branch_move
(
repo
,
"where/am/I"
,
NEW_BRANCH_NAME
,
0
);
cl_git_fail
(
error
);
cl_assert_equal_i
(
GIT_ENOTFOUND
,
error
);
}
}
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