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
bbb988a5
Commit
bbb988a5
authored
Sep 17, 2014
by
The rugged tests are fragile
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
path: Fix `git_path_walk_up` to work with non-rooted paths
parent
1312f87b
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
64 additions
and
28 deletions
+64
-28
src/attr.c
+2
-2
src/fileops.c
+4
-4
src/ignore.c
+2
-2
src/path.c
+17
-2
src/path.h
+1
-1
tests/core/path.c
+38
-15
tests/path/core.c
+0
-2
No files found.
src/attr.c
View file @
bbb988a5
...
...
@@ -377,7 +377,7 @@ static int push_attr_file(
return
error
;
}
static
int
push_one_attr
(
void
*
ref
,
git_buf
*
path
)
static
int
push_one_attr
(
void
*
ref
,
const
char
*
path
)
{
int
error
=
0
,
n_src
,
i
;
attr_walk_up_info
*
info
=
(
attr_walk_up_info
*
)
ref
;
...
...
@@ -388,7 +388,7 @@ static int push_one_attr(void *ref, git_buf *path)
for
(
i
=
0
;
!
error
&&
i
<
n_src
;
++
i
)
error
=
push_attr_file
(
info
->
repo
,
info
->
files
,
src
[
i
],
path
->
ptr
,
GIT_ATTR_FILE
);
info
->
repo
,
info
->
files
,
src
[
i
],
path
,
GIT_ATTR_FILE
);
return
error
;
}
...
...
src/fileops.c
View file @
bbb988a5
...
...
@@ -505,15 +505,15 @@ static int futils__rmdir_recurs_foreach(void *opaque, git_buf *path)
return
error
;
}
static
int
futils__rmdir_empty_parent
(
void
*
opaque
,
git_buf
*
path
)
static
int
futils__rmdir_empty_parent
(
void
*
opaque
,
const
char
*
path
)
{
futils__rmdir_data
*
data
=
opaque
;
int
error
=
0
;
if
(
git_buf_
len
(
path
)
<=
data
->
baselen
)
if
(
str
len
(
path
)
<=
data
->
baselen
)
error
=
GIT_ITEROVER
;
else
if
(
p_rmdir
(
git_buf_cstr
(
path
)
)
<
0
)
{
else
if
(
p_rmdir
(
path
)
<
0
)
{
int
en
=
errno
;
if
(
en
==
ENOENT
||
en
==
ENOTDIR
)
{
...
...
@@ -521,7 +521,7 @@ static int futils__rmdir_empty_parent(void *opaque, git_buf *path)
}
else
if
(
en
==
ENOTEMPTY
||
en
==
EEXIST
||
en
==
EBUSY
)
{
error
=
GIT_ITEROVER
;
}
else
{
error
=
git_path_set_error
(
errno
,
git_buf_cstr
(
path
)
,
"rmdir"
);
error
=
git_path_set_error
(
errno
,
path
,
"rmdir"
);
}
}
...
...
src/ignore.c
View file @
bbb988a5
...
...
@@ -91,11 +91,11 @@ static int push_ignore_file(
return
error
;
}
static
int
push_one_ignore
(
void
*
payload
,
git_buf
*
path
)
static
int
push_one_ignore
(
void
*
payload
,
const
char
*
path
)
{
git_ignores
*
ign
=
payload
;
ign
->
depth
++
;
return
push_ignore_file
(
ign
,
&
ign
->
ign_path
,
path
->
ptr
,
GIT_IGNORE_FILE
);
return
push_ignore_file
(
ign
,
&
ign
->
ign_path
,
path
,
GIT_IGNORE_FILE
);
}
static
int
get_internal_ignores
(
git_attr_file
**
out
,
git_repository
*
repo
)
...
...
src/path.c
View file @
bbb988a5
...
...
@@ -417,7 +417,7 @@ int git_path_fromurl(git_buf *local_path_out, const char *file_url)
int
git_path_walk_up
(
git_buf
*
path
,
const
char
*
ceiling
,
int
(
*
cb
)(
void
*
data
,
git_buf
*
),
int
(
*
cb
)(
void
*
data
,
const
char
*
),
void
*
data
)
{
int
error
=
0
;
...
...
@@ -435,12 +435,20 @@ int git_path_walk_up(
}
scan
=
git_buf_len
(
path
);
/* empty path: yield only once */
if
(
!
scan
)
{
error
=
cb
(
data
,
""
);
if
(
error
)
giterr_set_after_callback
(
error
);
return
error
;
}
iter
.
ptr
=
path
->
ptr
;
iter
.
size
=
git_buf_len
(
path
);
iter
.
asize
=
path
->
asize
;
while
(
scan
>=
stop
)
{
error
=
cb
(
data
,
&
ite
r
);
error
=
cb
(
data
,
iter
.
pt
r
);
iter
.
ptr
[
scan
]
=
oldc
;
if
(
error
)
{
...
...
@@ -460,6 +468,13 @@ int git_path_walk_up(
if
(
scan
>=
0
)
iter
.
ptr
[
scan
]
=
oldc
;
/* relative path: yield for the last component */
if
(
!
error
&&
stop
==
0
&&
iter
.
ptr
[
0
]
!=
'/'
)
{
error
=
cb
(
data
,
""
);
if
(
error
)
giterr_set_after_callback
(
error
);
}
return
error
;
}
...
...
src/path.h
View file @
bbb988a5
...
...
@@ -323,7 +323,7 @@ extern int git_path_cmp(
extern
int
git_path_walk_up
(
git_buf
*
pathbuf
,
const
char
*
ceiling
,
int
(
*
callback
)(
void
*
payload
,
git_buf
*
path
),
int
(
*
callback
)(
void
*
payload
,
const
char
*
path
),
void
*
payload
);
/**
...
...
tests/core/path.c
View file @
bbb988a5
...
...
@@ -356,7 +356,7 @@ typedef struct {
#define CANCEL_VALUE 1234
static
int
check_one_walkup_step
(
void
*
ref
,
git_buf
*
path
)
static
int
check_one_walkup_step
(
void
*
ref
,
const
char
*
path
)
{
check_walkup_info
*
info
=
(
check_walkup_info
*
)
ref
;
...
...
@@ -367,7 +367,7 @@ static int check_one_walkup_step(void *ref, git_buf *path)
info
->
cancel_after
--
;
cl_assert
(
info
->
expect
[
info
->
expect_idx
]
!=
NULL
);
cl_assert_equal_s
(
info
->
expect
[
info
->
expect_idx
],
path
->
ptr
);
cl_assert_equal_s
(
info
->
expect
[
info
->
expect_idx
],
path
);
info
->
expect_idx
++
;
return
0
;
...
...
@@ -376,18 +376,42 @@ static int check_one_walkup_step(void *ref, git_buf *path)
void
test_core_path__11_walkup
(
void
)
{
git_buf
p
=
GIT_BUF_INIT
;
char
*
expect
[]
=
{
"/a/b/c/d/e/"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
"/a/"
,
"/"
,
NULL
,
"/a/b/c/d/e"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
"/a/"
,
"/"
,
NULL
,
"/a/b/c/d/e"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
"/a/"
,
"/"
,
NULL
,
"/a/b/c/d/e"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
"/a/"
,
"/"
,
NULL
,
"/a/b/c/d/e"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
NULL
,
"/a/b/c/d/e"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
NULL
,
"this is a path"
,
NULL
,
"///a///b///c///d///e///"
,
"///a///b///c///d///"
,
"///a///b///c///"
,
"///a///b///"
,
"///a///"
,
"///"
,
NULL
,
NULL
/* 1 */
"/a/b/c/d/e/"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
"/a/"
,
"/"
,
NULL
,
/* 2 */
"/a/b/c/d/e"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
"/a/"
,
"/"
,
NULL
,
/* 3 */
"/a/b/c/d/e"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
"/a/"
,
"/"
,
NULL
,
/* 4 */
"/a/b/c/d/e"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
"/a/"
,
"/"
,
NULL
,
/* 5 */
"/a/b/c/d/e"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
NULL
,
/* 6 */
"/a/b/c/d/e"
,
"/a/b/c/d/"
,
"/a/b/c/"
,
"/a/b/"
,
NULL
,
/* 7 */
"this_is_a_path"
,
""
,
NULL
,
/* 8 */
"this_is_a_path/"
,
""
,
NULL
,
/* 9 */
"///a///b///c///d///e///"
,
"///a///b///c///d///"
,
"///a///b///c///"
,
"///a///b///"
,
"///a///"
,
"///"
,
NULL
,
/* 10 */
"a/b/c/"
,
"a/b/"
,
"a/"
,
""
,
NULL
,
/* 11 */
"a/b/c"
,
"a/b/"
,
"a/"
,
""
,
NULL
,
/* 12 */
"a/b/c/"
,
"a/b/"
,
"a/"
,
NULL
,
/* 13 */
""
,
NULL
,
/* 14 */
"/"
,
NULL
,
/* 15 */
NULL
};
char
*
root
[]
=
{
/* 1 */
NULL
,
/* 2 */
NULL
,
/* 3 */
"/"
,
/* 4 */
""
,
/* 5 */
"/a/b"
,
/* 6 */
"/a/b/"
,
/* 7 */
NULL
,
/* 8 */
NULL
,
/* 9 */
NULL
,
/* 10 */
NULL
,
/* 11 */
NULL
,
/* 12 */
"a/"
,
/* 13 */
NULL
,
/* 14 */
NULL
,
};
char
*
root
[]
=
{
NULL
,
NULL
,
"/"
,
""
,
"/a/b"
,
"/a/b/"
,
NULL
,
NULL
,
NULL
};
int
i
,
j
;
check_walkup_info
info
;
...
...
@@ -404,9 +428,8 @@ void test_core_path__11_walkup(void)
);
cl_assert_equal_s
(
p
.
ptr
,
expect
[
i
]);
/* skip to next run of expectations */
while
(
expect
[
i
]
!=
NULL
)
i
++
;
cl_assert
(
expect
[
info
.
expect_idx
]
==
NULL
);
i
=
info
.
expect_idx
;
}
git_buf_free
(
&
p
);
...
...
tests/path/core.c
View file @
bbb988a5
...
...
@@ -16,8 +16,6 @@ static void test_make_relative(
void
test_path_core__make_relative
(
void
)
{
git_buf
buf
=
GIT_BUF_INIT
;
test_make_relative
(
"foo.c"
,
"/path/to/foo.c"
,
"/path/to"
,
0
);
test_make_relative
(
"bar/foo.c"
,
"/path/to/bar/foo.c"
,
"/path/to"
,
0
);
test_make_relative
(
"foo.c"
,
"/path/to/foo.c"
,
"/path/to/"
,
0
);
...
...
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