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
4e1b3b3b
Commit
4e1b3b3b
authored
Nov 07, 2014
by
Edward Thomson
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2691 from libgit2/cmn/submodule-and-dir
submodules: stale module entries
parents
dd83e602
62a617dc
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
167 additions
and
31 deletions
+167
-31
src/checkout.c
+9
-3
src/checkout.h
+1
-0
src/diff.c
+7
-2
src/index.c
+1
-1
src/iterator.c
+70
-1
src/iterator.h
+5
-1
src/pathspec.c
+1
-1
tests/diff/iterator.c
+3
-3
tests/repo/iterator.c
+17
-17
tests/status/submodules.c
+48
-0
tests/submodule/status.c
+4
-1
tests/threads/iterator.c
+1
-1
No files found.
src/checkout.c
View file @
4e1b3b3b
...
@@ -2242,6 +2242,7 @@ cleanup:
...
@@ -2242,6 +2242,7 @@ cleanup:
int
git_checkout_iterator
(
int
git_checkout_iterator
(
git_iterator
*
target
,
git_iterator
*
target
,
git_index
*
index
,
const
git_checkout_options
*
opts
)
const
git_checkout_options
*
opts
)
{
{
int
error
=
0
;
int
error
=
0
;
...
@@ -2278,7 +2279,7 @@ int git_checkout_iterator(
...
@@ -2278,7 +2279,7 @@ int git_checkout_iterator(
if
((
error
=
git_iterator_reset
(
target
,
data
.
pfx
,
data
.
pfx
))
<
0
||
if
((
error
=
git_iterator_reset
(
target
,
data
.
pfx
,
data
.
pfx
))
<
0
||
(
error
=
git_iterator_for_workdir_ext
(
(
error
=
git_iterator_for_workdir_ext
(
&
workdir
,
data
.
repo
,
data
.
opts
.
target_directory
,
&
workdir
,
data
.
repo
,
data
.
opts
.
target_directory
,
index
,
NULL
,
iterflags
|
GIT_ITERATOR_DONT_AUTOEXPAND
,
iterflags
|
GIT_ITERATOR_DONT_AUTOEXPAND
,
data
.
pfx
,
data
.
pfx
))
<
0
||
data
.
pfx
,
data
.
pfx
))
<
0
||
(
error
=
git_iterator_for_tree
(
(
error
=
git_iterator_for_tree
(
...
@@ -2388,7 +2389,7 @@ int git_checkout_index(
...
@@ -2388,7 +2389,7 @@ int git_checkout_index(
GIT_REFCOUNT_INC
(
index
);
GIT_REFCOUNT_INC
(
index
);
if
(
!
(
error
=
git_iterator_for_index
(
&
index_i
,
index
,
0
,
NULL
,
NULL
)))
if
(
!
(
error
=
git_iterator_for_index
(
&
index_i
,
index
,
0
,
NULL
,
NULL
)))
error
=
git_checkout_iterator
(
index_i
,
opts
);
error
=
git_checkout_iterator
(
index_i
,
index
,
opts
);
if
(
owned
)
if
(
owned
)
GIT_REFCOUNT_OWN
(
index
,
NULL
);
GIT_REFCOUNT_OWN
(
index
,
NULL
);
...
@@ -2405,6 +2406,7 @@ int git_checkout_tree(
...
@@ -2405,6 +2406,7 @@ int git_checkout_tree(
const
git_checkout_options
*
opts
)
const
git_checkout_options
*
opts
)
{
{
int
error
;
int
error
;
git_index
*
index
;
git_tree
*
tree
=
NULL
;
git_tree
*
tree
=
NULL
;
git_iterator
*
tree_i
=
NULL
;
git_iterator
*
tree_i
=
NULL
;
...
@@ -2439,10 +2441,14 @@ int git_checkout_tree(
...
@@ -2439,10 +2441,14 @@ int git_checkout_tree(
}
}
}
}
if
((
error
=
git_repository_index
(
&
index
,
repo
))
<
0
)
return
error
;
if
(
!
(
error
=
git_iterator_for_tree
(
&
tree_i
,
tree
,
0
,
NULL
,
NULL
)))
if
(
!
(
error
=
git_iterator_for_tree
(
&
tree_i
,
tree
,
0
,
NULL
,
NULL
)))
error
=
git_checkout_iterator
(
tree_i
,
opts
);
error
=
git_checkout_iterator
(
tree_i
,
index
,
opts
);
git_iterator_free
(
tree_i
);
git_iterator_free
(
tree_i
);
git_index_free
(
index
);
git_tree_free
(
tree
);
git_tree_free
(
tree
);
return
error
;
return
error
;
...
...
src/checkout.h
View file @
4e1b3b3b
...
@@ -19,6 +19,7 @@
...
@@ -19,6 +19,7 @@
*/
*/
extern
int
git_checkout_iterator
(
extern
int
git_checkout_iterator
(
git_iterator
*
target
,
git_iterator
*
target
,
git_index
*
index
,
const
git_checkout_options
*
opts
);
const
git_checkout_options
*
opts
);
#endif
#endif
src/diff.c
View file @
4e1b3b3b
...
@@ -1214,7 +1214,7 @@ int git_diff_index_to_workdir(
...
@@ -1214,7 +1214,7 @@ int git_diff_index_to_workdir(
DIFF_FROM_ITERATORS
(
DIFF_FROM_ITERATORS
(
git_iterator_for_index
(
&
a
,
index
,
0
,
pfx
,
pfx
),
git_iterator_for_index
(
&
a
,
index
,
0
,
pfx
,
pfx
),
git_iterator_for_workdir
(
git_iterator_for_workdir
(
&
b
,
repo
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
pfx
,
pfx
)
&
b
,
repo
,
index
,
NULL
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
pfx
,
pfx
)
);
);
if
(
!
error
&&
DIFF_FLAG_IS_SET
(
*
diff
,
GIT_DIFF_UPDATE_INDEX
))
if
(
!
error
&&
DIFF_FLAG_IS_SET
(
*
diff
,
GIT_DIFF_UPDATE_INDEX
))
...
@@ -1230,15 +1230,20 @@ int git_diff_tree_to_workdir(
...
@@ -1230,15 +1230,20 @@ int git_diff_tree_to_workdir(
const
git_diff_options
*
opts
)
const
git_diff_options
*
opts
)
{
{
int
error
=
0
;
int
error
=
0
;
git_index
*
index
;
assert
(
diff
&&
repo
);
assert
(
diff
&&
repo
);
if
((
error
=
git_repository_index
(
&
index
,
repo
)))
return
error
;
DIFF_FROM_ITERATORS
(
DIFF_FROM_ITERATORS
(
git_iterator_for_tree
(
&
a
,
old_tree
,
0
,
pfx
,
pfx
),
git_iterator_for_tree
(
&
a
,
old_tree
,
0
,
pfx
,
pfx
),
git_iterator_for_workdir
(
git_iterator_for_workdir
(
&
b
,
repo
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
pfx
,
pfx
)
&
b
,
repo
,
index
,
old_tree
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
pfx
,
pfx
)
);
);
git_index_free
(
index
);
return
error
;
return
error
;
}
}
...
...
src/index.c
View file @
4e1b3b3b
...
@@ -2441,7 +2441,7 @@ int git_index_add_all(
...
@@ -2441,7 +2441,7 @@ int git_index_add_all(
goto
cleanup
;
goto
cleanup
;
if
((
error
=
git_iterator_for_workdir
(
if
((
error
=
git_iterator_for_workdir
(
&
wditer
,
repo
,
0
,
ps
.
prefix
,
ps
.
prefix
))
<
0
)
&
wditer
,
repo
,
NULL
,
NULL
,
0
,
ps
.
prefix
,
ps
.
prefix
))
<
0
)
goto
cleanup
;
goto
cleanup
;
while
(
!
(
error
=
git_iterator_advance
(
&
wd
,
wditer
)))
{
while
(
!
(
error
=
git_iterator_advance
(
&
wd
,
wditer
)))
{
...
...
src/iterator.c
View file @
4e1b3b3b
...
@@ -1268,6 +1268,16 @@ typedef struct {
...
@@ -1268,6 +1268,16 @@ typedef struct {
fs_iterator
fi
;
fs_iterator
fi
;
git_ignores
ignores
;
git_ignores
ignores
;
int
is_ignored
;
int
is_ignored
;
/*
* We may have a tree or the index+snapshot to compare against
* when checking for submodules.
*/
git_tree
*
tree
;
git_index
*
index
;
git_vector
index_snapshot
;
git_vector_cmp
entry_srch
;
}
workdir_iterator
;
}
workdir_iterator
;
GIT_INLINE
(
bool
)
workdir_path_is_dotgit
(
const
git_buf
*
path
)
GIT_INLINE
(
bool
)
workdir_path_is_dotgit
(
const
git_buf
*
path
)
...
@@ -1289,6 +1299,49 @@ GIT_INLINE(bool) workdir_path_is_dotgit(const git_buf *path)
...
@@ -1289,6 +1299,49 @@ GIT_INLINE(bool) workdir_path_is_dotgit(const git_buf *path)
return
(
len
==
4
||
path
->
ptr
[
len
-
5
]
==
'/'
);
return
(
len
==
4
||
path
->
ptr
[
len
-
5
]
==
'/'
);
}
}
/**
* Figure out if an entry is a submodule.
*
* We consider it a submodule if the path is listed as a submodule in
* either the tree or the index.
*/
static
int
is_submodule
(
workdir_iterator
*
wi
,
git_path_with_stat
*
ie
)
{
int
error
,
is_submodule
=
0
;
if
(
wi
->
tree
)
{
git_tree_entry
*
e
;
/* remove the trailing slash for finding */
ie
->
path
[
ie
->
path_len
-
1
]
=
'\0'
;
error
=
git_tree_entry_bypath
(
&
e
,
wi
->
tree
,
ie
->
path
);
ie
->
path
[
ie
->
path_len
-
1
]
=
'/'
;
if
(
error
<
0
&&
error
!=
GIT_ENOTFOUND
)
return
0
;
if
(
!
error
)
{
is_submodule
=
e
->
attr
==
GIT_FILEMODE_COMMIT
;
git_tree_entry_free
(
e
);
}
}
if
(
!
is_submodule
&&
wi
->
index
)
{
git_index_entry
*
e
;
size_t
pos
;
error
=
git_index_snapshot_find
(
&
pos
,
&
wi
->
index_snapshot
,
wi
->
entry_srch
,
ie
->
path
,
ie
->
path_len
-
1
,
0
);
if
(
error
<
0
&&
error
!=
GIT_ENOTFOUND
)
return
0
;
if
(
!
error
)
{
e
=
git_vector_get
(
&
wi
->
index_snapshot
,
pos
);
is_submodule
=
e
->
mode
==
GIT_FILEMODE_COMMIT
;
}
}
return
is_submodule
;
}
static
int
workdir_iterator__enter_dir
(
fs_iterator
*
fi
)
static
int
workdir_iterator__enter_dir
(
fs_iterator
*
fi
)
{
{
workdir_iterator
*
wi
=
(
workdir_iterator
*
)
fi
;
workdir_iterator
*
wi
=
(
workdir_iterator
*
)
fi
;
...
@@ -1321,7 +1374,7 @@ static int workdir_iterator__enter_dir(fs_iterator *fi)
...
@@ -1321,7 +1374,7 @@ static int workdir_iterator__enter_dir(fs_iterator *fi)
if
(
!
S_ISDIR
(
entry
->
st
.
st_mode
)
||
!
strcmp
(
GIT_DIR
,
entry
->
path
))
if
(
!
S_ISDIR
(
entry
->
st
.
st_mode
)
||
!
strcmp
(
GIT_DIR
,
entry
->
path
))
continue
;
continue
;
if
(
git_submodule__is_submodule
(
fi
->
base
.
repo
,
entry
->
path
))
{
if
(
is_submodule
(
wi
,
entry
))
{
entry
->
st
.
st_mode
=
GIT_FILEMODE_COMMIT
;
entry
->
st
.
st_mode
=
GIT_FILEMODE_COMMIT
;
entry
->
path_len
--
;
entry
->
path_len
--
;
entry
->
path
[
entry
->
path_len
]
=
'\0'
;
entry
->
path
[
entry
->
path_len
]
=
'\0'
;
...
@@ -1363,6 +1416,8 @@ static int workdir_iterator__update_entry(fs_iterator *fi)
...
@@ -1363,6 +1416,8 @@ static int workdir_iterator__update_entry(fs_iterator *fi)
static
void
workdir_iterator__free
(
git_iterator
*
self
)
static
void
workdir_iterator__free
(
git_iterator
*
self
)
{
{
workdir_iterator
*
wi
=
(
workdir_iterator
*
)
self
;
workdir_iterator
*
wi
=
(
workdir_iterator
*
)
self
;
if
(
wi
->
index
)
git_index_snapshot_release
(
&
wi
->
index_snapshot
,
wi
->
index
);
fs_iterator__free
(
self
);
fs_iterator__free
(
self
);
git_ignore__free
(
&
wi
->
ignores
);
git_ignore__free
(
&
wi
->
ignores
);
}
}
...
@@ -1371,6 +1426,8 @@ int git_iterator_for_workdir_ext(
...
@@ -1371,6 +1426,8 @@ int git_iterator_for_workdir_ext(
git_iterator
**
out
,
git_iterator
**
out
,
git_repository
*
repo
,
git_repository
*
repo
,
const
char
*
repo_workdir
,
const
char
*
repo_workdir
,
git_index
*
index
,
git_tree
*
tree
,
git_iterator_flag_t
flags
,
git_iterator_flag_t
flags
,
const
char
*
start
,
const
char
*
start
,
const
char
*
end
)
const
char
*
end
)
...
@@ -1402,6 +1459,18 @@ int git_iterator_for_workdir_ext(
...
@@ -1402,6 +1459,18 @@ int git_iterator_for_workdir_ext(
return
error
;
return
error
;
}
}
if
(
tree
&&
(
error
=
git_object_dup
((
git_object
**
)
&
wi
->
tree
,
(
git_object
*
)
tree
))
<
0
)
return
error
;
wi
->
index
=
index
;
if
(
index
&&
(
error
=
git_index_snapshot_new
(
&
wi
->
index_snapshot
,
index
))
<
0
)
{
git_iterator_free
((
git_iterator
*
)
wi
);
return
error
;
}
wi
->
entry_srch
=
iterator__ignore_case
(
wi
)
?
git_index_entry_isrch
:
git_index_entry_srch
;
/* try to look up precompose and set flag if appropriate */
/* try to look up precompose and set flag if appropriate */
if
(
git_repository__cvar
(
&
precompose
,
repo
,
GIT_CVAR_PRECOMPOSE
)
<
0
)
if
(
git_repository__cvar
(
&
precompose
,
repo
,
GIT_CVAR_PRECOMPOSE
)
<
0
)
giterr_clear
();
giterr_clear
();
...
...
src/iterator.h
View file @
4e1b3b3b
...
@@ -86,6 +86,8 @@ extern int git_iterator_for_workdir_ext(
...
@@ -86,6 +86,8 @@ extern int git_iterator_for_workdir_ext(
git_iterator
**
out
,
git_iterator
**
out
,
git_repository
*
repo
,
git_repository
*
repo
,
const
char
*
repo_workdir
,
const
char
*
repo_workdir
,
git_index
*
index
,
git_tree
*
tree
,
git_iterator_flag_t
flags
,
git_iterator_flag_t
flags
,
const
char
*
start
,
const
char
*
start
,
const
char
*
end
);
const
char
*
end
);
...
@@ -96,11 +98,13 @@ extern int git_iterator_for_workdir_ext(
...
@@ -96,11 +98,13 @@ extern int git_iterator_for_workdir_ext(
GIT_INLINE
(
int
)
git_iterator_for_workdir
(
GIT_INLINE
(
int
)
git_iterator_for_workdir
(
git_iterator
**
out
,
git_iterator
**
out
,
git_repository
*
repo
,
git_repository
*
repo
,
git_index
*
index
,
git_tree
*
tree
,
git_iterator_flag_t
flags
,
git_iterator_flag_t
flags
,
const
char
*
start
,
const
char
*
start
,
const
char
*
end
)
const
char
*
end
)
{
{
return
git_iterator_for_workdir_ext
(
out
,
repo
,
NULL
,
flags
,
start
,
end
);
return
git_iterator_for_workdir_ext
(
out
,
repo
,
NULL
,
index
,
tree
,
flags
,
start
,
end
);
}
}
/* for filesystem iterators, you have to explicitly pass in the ignore_case
/* for filesystem iterators, you have to explicitly pass in the ignore_case
...
...
src/pathspec.c
View file @
4e1b3b3b
...
@@ -524,7 +524,7 @@ int git_pathspec_match_workdir(
...
@@ -524,7 +524,7 @@ int git_pathspec_match_workdir(
assert
(
repo
);
assert
(
repo
);
if
(
!
(
error
=
git_iterator_for_workdir
(
if
(
!
(
error
=
git_iterator_for_workdir
(
&
iter
,
repo
,
pathspec_match_iter_flags
(
flags
),
NULL
,
NULL
)))
{
&
iter
,
repo
,
NULL
,
NULL
,
pathspec_match_iter_flags
(
flags
),
NULL
,
NULL
)))
{
error
=
pathspec_match_from_iterator
(
out
,
iter
,
flags
,
ps
);
error
=
pathspec_match_from_iterator
(
out
,
iter
,
flags
,
ps
);
...
...
tests/diff/iterator.c
View file @
4e1b3b3b
...
@@ -586,7 +586,7 @@ static void workdir_iterator_test(
...
@@ -586,7 +586,7 @@ static void workdir_iterator_test(
git_repository
*
repo
=
cl_git_sandbox_init
(
sandbox
);
git_repository
*
repo
=
cl_git_sandbox_init
(
sandbox
);
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
repo
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
start
,
end
));
&
i
,
repo
,
NULL
,
NULL
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
start
,
end
));
error
=
git_iterator_current
(
&
entry
,
i
);
error
=
git_iterator_current
(
&
entry
,
i
);
cl_assert
((
error
==
0
&&
entry
!=
NULL
)
||
cl_assert
((
error
==
0
&&
entry
!=
NULL
)
||
...
@@ -797,7 +797,7 @@ void test_diff_iterator__workdir_builtin_ignores(void)
...
@@ -797,7 +797,7 @@ void test_diff_iterator__workdir_builtin_ignores(void)
cl_git_mkfile
(
"attr/sub/.git"
,
"whatever"
);
cl_git_mkfile
(
"attr/sub/.git"
,
"whatever"
);
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
repo
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
"dir"
,
"sub/sub/file"
));
&
i
,
repo
,
NULL
,
NULL
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
"dir"
,
"sub/sub/file"
));
cl_git_pass
(
git_iterator_current
(
&
entry
,
i
));
cl_git_pass
(
git_iterator_current
(
&
entry
,
i
));
for
(
idx
=
0
;
entry
!=
NULL
;
++
idx
)
{
for
(
idx
=
0
;
entry
!=
NULL
;
++
idx
)
{
...
@@ -832,7 +832,7 @@ static void check_wd_first_through_third_range(
...
@@ -832,7 +832,7 @@ static void check_wd_first_through_third_range(
static
const
char
*
expected
[]
=
{
"FIRST"
,
"second"
,
"THIRD"
,
NULL
};
static
const
char
*
expected
[]
=
{
"FIRST"
,
"second"
,
"THIRD"
,
NULL
};
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
repo
,
GIT_ITERATOR_IGNORE_CASE
,
start
,
end
));
&
i
,
repo
,
NULL
,
NULL
,
GIT_ITERATOR_IGNORE_CASE
,
start
,
end
));
cl_git_pass
(
git_iterator_current
(
&
entry
,
i
));
cl_git_pass
(
git_iterator_current
(
&
entry
,
i
));
for
(
idx
=
0
;
entry
!=
NULL
;
++
idx
)
{
for
(
idx
=
0
;
entry
!=
NULL
;
++
idx
)
{
...
...
tests/repo/iterator.c
View file @
4e1b3b3b
...
@@ -665,19 +665,19 @@ void test_repo_iterator__workdir(void)
...
@@ -665,19 +665,19 @@ void test_repo_iterator__workdir(void)
g_repo
=
cl_git_sandbox_init
(
"icase"
);
g_repo
=
cl_git_sandbox_init
(
"icase"
);
/* auto expand with no tree entries */
/* auto expand with no tree entries */
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
0
,
NULL
,
NULL
));
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
NULL
,
NULL
,
0
,
NULL
,
NULL
));
expect_iterator_items
(
i
,
20
,
NULL
,
20
,
NULL
);
expect_iterator_items
(
i
,
20
,
NULL
,
20
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
/* auto expand with tree entries */
/* auto expand with tree entries */
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
GIT_ITERATOR_INCLUDE_TREES
,
NULL
,
NULL
));
&
i
,
g_repo
,
NULL
,
NULL
,
GIT_ITERATOR_INCLUDE_TREES
,
NULL
,
NULL
));
expect_iterator_items
(
i
,
22
,
NULL
,
22
,
NULL
);
expect_iterator_items
(
i
,
22
,
NULL
,
22
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
/* no auto expand (implies trees included) */
/* no auto expand (implies trees included) */
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
NULL
,
NULL
));
&
i
,
g_repo
,
NULL
,
NULL
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
NULL
,
NULL
));
expect_iterator_items
(
i
,
12
,
NULL
,
22
,
NULL
);
expect_iterator_items
(
i
,
12
,
NULL
,
22
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
}
}
...
@@ -692,66 +692,66 @@ void test_repo_iterator__workdir_icase(void)
...
@@ -692,66 +692,66 @@ void test_repo_iterator__workdir_icase(void)
flag
=
GIT_ITERATOR_DONT_IGNORE_CASE
;
flag
=
GIT_ITERATOR_DONT_IGNORE_CASE
;
/* auto expand with no tree entries */
/* auto expand with no tree entries */
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
,
"c"
,
"k/D"
));
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
NULL
,
NULL
,
flag
,
"c"
,
"k/D"
));
expect_iterator_items
(
i
,
7
,
NULL
,
7
,
NULL
);
expect_iterator_items
(
i
,
7
,
NULL
,
7
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
,
"k"
,
"k/Z"
));
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
NULL
,
NULL
,
flag
,
"k"
,
"k/Z"
));
expect_iterator_items
(
i
,
3
,
NULL
,
3
,
NULL
);
expect_iterator_items
(
i
,
3
,
NULL
,
3
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
/* auto expand with tree entries */
/* auto expand with tree entries */
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
|
GIT_ITERATOR_INCLUDE_TREES
,
"c"
,
"k/D"
));
&
i
,
g_repo
,
NULL
,
NULL
,
flag
|
GIT_ITERATOR_INCLUDE_TREES
,
"c"
,
"k/D"
));
expect_iterator_items
(
i
,
8
,
NULL
,
8
,
NULL
);
expect_iterator_items
(
i
,
8
,
NULL
,
8
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
|
GIT_ITERATOR_INCLUDE_TREES
,
"k"
,
"k/Z"
));
&
i
,
g_repo
,
NULL
,
NULL
,
flag
|
GIT_ITERATOR_INCLUDE_TREES
,
"k"
,
"k/Z"
));
expect_iterator_items
(
i
,
4
,
NULL
,
4
,
NULL
);
expect_iterator_items
(
i
,
4
,
NULL
,
4
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
/* no auto expand (implies trees included) */
/* no auto expand (implies trees included) */
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
|
GIT_ITERATOR_DONT_AUTOEXPAND
,
"c"
,
"k/D"
));
&
i
,
g_repo
,
NULL
,
NULL
,
flag
|
GIT_ITERATOR_DONT_AUTOEXPAND
,
"c"
,
"k/D"
));
expect_iterator_items
(
i
,
5
,
NULL
,
8
,
NULL
);
expect_iterator_items
(
i
,
5
,
NULL
,
8
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
|
GIT_ITERATOR_DONT_AUTOEXPAND
,
"k"
,
"k/Z"
));
&
i
,
g_repo
,
NULL
,
NULL
,
flag
|
GIT_ITERATOR_DONT_AUTOEXPAND
,
"k"
,
"k/Z"
));
expect_iterator_items
(
i
,
1
,
NULL
,
4
,
NULL
);
expect_iterator_items
(
i
,
1
,
NULL
,
4
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
flag
=
GIT_ITERATOR_IGNORE_CASE
;
flag
=
GIT_ITERATOR_IGNORE_CASE
;
/* auto expand with no tree entries */
/* auto expand with no tree entries */
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
,
"c"
,
"k/D"
));
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
NULL
,
NULL
,
flag
,
"c"
,
"k/D"
));
expect_iterator_items
(
i
,
13
,
NULL
,
13
,
NULL
);
expect_iterator_items
(
i
,
13
,
NULL
,
13
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
,
"k"
,
"k/Z"
));
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
NULL
,
NULL
,
flag
,
"k"
,
"k/Z"
));
expect_iterator_items
(
i
,
5
,
NULL
,
5
,
NULL
);
expect_iterator_items
(
i
,
5
,
NULL
,
5
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
/* auto expand with tree entries */
/* auto expand with tree entries */
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
|
GIT_ITERATOR_INCLUDE_TREES
,
"c"
,
"k/D"
));
&
i
,
g_repo
,
NULL
,
NULL
,
flag
|
GIT_ITERATOR_INCLUDE_TREES
,
"c"
,
"k/D"
));
expect_iterator_items
(
i
,
14
,
NULL
,
14
,
NULL
);
expect_iterator_items
(
i
,
14
,
NULL
,
14
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
|
GIT_ITERATOR_INCLUDE_TREES
,
"k"
,
"k/Z"
));
&
i
,
g_repo
,
NULL
,
NULL
,
flag
|
GIT_ITERATOR_INCLUDE_TREES
,
"k"
,
"k/Z"
));
expect_iterator_items
(
i
,
6
,
NULL
,
6
,
NULL
);
expect_iterator_items
(
i
,
6
,
NULL
,
6
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
/* no auto expand (implies trees included) */
/* no auto expand (implies trees included) */
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
|
GIT_ITERATOR_DONT_AUTOEXPAND
,
"c"
,
"k/D"
));
&
i
,
g_repo
,
NULL
,
NULL
,
flag
|
GIT_ITERATOR_DONT_AUTOEXPAND
,
"c"
,
"k/D"
));
expect_iterator_items
(
i
,
9
,
NULL
,
14
,
NULL
);
expect_iterator_items
(
i
,
9
,
NULL
,
14
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
i
,
g_repo
,
flag
|
GIT_ITERATOR_DONT_AUTOEXPAND
,
"k"
,
"k/Z"
));
&
i
,
g_repo
,
NULL
,
NULL
,
flag
|
GIT_ITERATOR_DONT_AUTOEXPAND
,
"k"
,
"k/Z"
));
expect_iterator_items
(
i
,
1
,
NULL
,
6
,
NULL
);
expect_iterator_items
(
i
,
1
,
NULL
,
6
,
NULL
);
git_iterator_free
(
i
);
git_iterator_free
(
i
);
}
}
...
@@ -804,13 +804,13 @@ void test_repo_iterator__workdir_depth(void)
...
@@ -804,13 +804,13 @@ void test_repo_iterator__workdir_depth(void)
build_workdir_tree
(
"icase/dir02/sUB01"
,
50
,
0
);
build_workdir_tree
(
"icase/dir02/sUB01"
,
50
,
0
);
/* auto expand with no tree entries */
/* auto expand with no tree entries */
cl_git_pass
(
git_iterator_for_workdir
(
&
iter
,
g_repo
,
0
,
NULL
,
NULL
));
cl_git_pass
(
git_iterator_for_workdir
(
&
iter
,
g_repo
,
NULL
,
NULL
,
0
,
NULL
,
NULL
));
expect_iterator_items
(
iter
,
125
,
NULL
,
125
,
NULL
);
expect_iterator_items
(
iter
,
125
,
NULL
,
125
,
NULL
);
git_iterator_free
(
iter
);
git_iterator_free
(
iter
);
/* auto expand with tree entries (empty dirs silently skipped) */
/* auto expand with tree entries (empty dirs silently skipped) */
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
iter
,
g_repo
,
GIT_ITERATOR_INCLUDE_TREES
,
NULL
,
NULL
));
&
iter
,
g_repo
,
NULL
,
NULL
,
GIT_ITERATOR_INCLUDE_TREES
,
NULL
,
NULL
));
expect_iterator_items
(
iter
,
337
,
NULL
,
337
,
NULL
);
expect_iterator_items
(
iter
,
337
,
NULL
,
337
,
NULL
);
git_iterator_free
(
iter
);
git_iterator_free
(
iter
);
}
}
...
...
tests/status/submodules.c
View file @
4e1b3b3b
...
@@ -476,3 +476,51 @@ void test_status_submodules__broken_stuff_that_git_allows(void)
...
@@ -476,3 +476,51 @@ void test_status_submodules__broken_stuff_that_git_allows(void)
cl_assert_equal_i
(
7
,
counts
.
entry_count
);
cl_assert_equal_i
(
7
,
counts
.
entry_count
);
}
}
void
test_status_submodules__entry_but_dir_tracked
(
void
)
{
git_repository
*
repo
;
git_status_list
*
status
;
git_diff
*
diff
;
git_index
*
index
;
git_tree
*
tree
;
cl_git_pass
(
git_repository_init
(
&
repo
,
"mixed-submodule"
,
0
));
cl_git_mkfile
(
"mixed-submodule/.gitmodules"
,
"[submodule
\"
sub
\"
]
\n
path = sub
\n
url = ../foo
\n
"
);
cl_git_pass
(
p_mkdir
(
"mixed-submodule/sub"
,
0777
));
cl_git_mkfile
(
"mixed-submodule/sub/file"
,
""
);
/* Create the commit with sub/file as a file, and an entry for sub in the modules list */
{
git_oid
tree_id
,
commit_id
;
git_signature
*
sig
;
git_reference
*
ref
;
cl_git_pass
(
git_repository_index
(
&
index
,
repo
));
cl_git_pass
(
git_index_add_bypath
(
index
,
".gitmodules"
));
cl_git_pass
(
git_index_add_bypath
(
index
,
"sub/file"
));
cl_git_pass
(
git_index_write
(
index
));
cl_git_pass
(
git_index_write_tree
(
&
tree_id
,
index
));
cl_git_pass
(
git_signature_now
(
&
sig
,
"Sloppy Submoduler"
,
"sloppy@example.com"
));
cl_git_pass
(
git_tree_lookup
(
&
tree
,
repo
,
&
tree_id
));
cl_git_pass
(
git_commit_create
(
&
commit_id
,
repo
,
NULL
,
sig
,
sig
,
NULL
,
"message"
,
tree
,
0
,
NULL
));
cl_git_pass
(
git_reference_create
(
&
ref
,
repo
,
"refs/heads/master"
,
&
commit_id
,
1
,
sig
,
"commit: foo"
));
git_reference_free
(
ref
);
git_signature_free
(
sig
);
}
cl_git_pass
(
git_diff_tree_to_index
(
&
diff
,
repo
,
tree
,
index
,
NULL
));
cl_assert_equal_i
(
0
,
git_diff_num_deltas
(
diff
));
git_diff_free
(
diff
);
cl_git_pass
(
git_diff_index_to_workdir
(
&
diff
,
repo
,
index
,
NULL
));
cl_assert_equal_i
(
0
,
git_diff_num_deltas
(
diff
));
git_diff_free
(
diff
);
cl_git_pass
(
git_status_list_new
(
&
status
,
repo
,
NULL
));
cl_assert_equal_i
(
0
,
git_status_list_entrycount
(
status
));
git_status_list_free
(
status
);
git_index_free
(
index
);
git_tree_free
(
tree
);
git_repository_free
(
repo
);
}
tests/submodule/status.c
View file @
4e1b3b3b
...
@@ -317,14 +317,17 @@ void test_submodule_status__iterator(void)
...
@@ -317,14 +317,17 @@ void test_submodule_status__iterator(void)
};
};
submodule_expectations
exp
=
{
0
,
expected
,
expected_flags
};
submodule_expectations
exp
=
{
0
,
expected
,
expected_flags
};
git_status_options
opts
=
GIT_STATUS_OPTIONS_INIT
;
git_status_options
opts
=
GIT_STATUS_OPTIONS_INIT
;
git_index
*
index
;
cl_git_pass
(
git_iterator_for_workdir
(
&
iter
,
g_repo
,
cl_git_pass
(
git_repository_index
(
&
index
,
g_repo
));
cl_git_pass
(
git_iterator_for_workdir
(
&
iter
,
g_repo
,
index
,
NULL
,
GIT_ITERATOR_IGNORE_CASE
|
GIT_ITERATOR_INCLUDE_TREES
,
NULL
,
NULL
));
GIT_ITERATOR_IGNORE_CASE
|
GIT_ITERATOR_INCLUDE_TREES
,
NULL
,
NULL
));
for
(
i
=
0
;
!
git_iterator_advance
(
&
entry
,
iter
);
++
i
)
for
(
i
=
0
;
!
git_iterator_advance
(
&
entry
,
iter
);
++
i
)
cl_assert_equal_s
(
expected
[
i
],
entry
->
path
);
cl_assert_equal_s
(
expected
[
i
],
entry
->
path
);
git_iterator_free
(
iter
);
git_iterator_free
(
iter
);
git_index_free
(
index
);
opts
.
flags
=
GIT_STATUS_OPT_INCLUDE_UNTRACKED
|
opts
.
flags
=
GIT_STATUS_OPT_INCLUDE_UNTRACKED
|
GIT_STATUS_OPT_INCLUDE_UNMODIFIED
|
GIT_STATUS_OPT_INCLUDE_UNMODIFIED
|
...
...
tests/threads/iterator.c
View file @
4e1b3b3b
...
@@ -16,7 +16,7 @@ static void *run_workdir_iterator(void *arg)
...
@@ -16,7 +16,7 @@ static void *run_workdir_iterator(void *arg)
const
git_index_entry
*
entry
=
NULL
;
const
git_index_entry
*
entry
=
NULL
;
cl_git_pass
(
git_iterator_for_workdir
(
cl_git_pass
(
git_iterator_for_workdir
(
&
iter
,
_repo
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
NULL
,
NULL
));
&
iter
,
_repo
,
NULL
,
NULL
,
GIT_ITERATOR_DONT_AUTOEXPAND
,
NULL
,
NULL
));
while
(
!
error
)
{
while
(
!
error
)
{
if
(
entry
&&
entry
->
mode
==
GIT_FILEMODE_TREE
)
{
if
(
entry
&&
entry
->
mode
==
GIT_FILEMODE_TREE
)
{
...
...
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