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
6b833e3a
Commit
6b833e3a
authored
Apr 24, 2014
by
Russell Belfer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve docs for status rename detection limits
and make tests empty on platforms without iconv support.
parent
f608f3bb
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
32 additions
and
4 deletions
+32
-4
include/git2/status.h
+27
-2
tests/status/renames.c
+5
-2
No files found.
include/git2/status.h
View file @
6b833e3a
...
@@ -236,6 +236,11 @@ GIT_EXTERN(int) git_status_foreach(
...
@@ -236,6 +236,11 @@ GIT_EXTERN(int) git_status_foreach(
* in what order. See the `git_status_options` structure for details
* in what order. See the `git_status_options` structure for details
* about the additional controls that this makes available.
* about the additional controls that this makes available.
*
*
* Note that if a `pathspec` is given in the `git_status_options` to filter
* the status, then the results from rename detection (if you enable it) may
* not be accurate. To do rename detection properly, this must be called
* with no `pathspec` so that all files can be considered.
*
* @param repo Repository object
* @param repo Repository object
* @param opts Status options structure
* @param opts Status options structure
* @param callback The function to call on each file
* @param callback The function to call on each file
...
@@ -251,8 +256,20 @@ GIT_EXTERN(int) git_status_foreach_ext(
...
@@ -251,8 +256,20 @@ GIT_EXTERN(int) git_status_foreach_ext(
/**
/**
* Get file status for a single file.
* Get file status for a single file.
*
*
* This is not quite the same as calling `git_status_foreach_ext()` with
* This tries to get status for the filename that you give. If no files
* the pathspec set to the specified path.
* match that name (in either the HEAD, index, or working directory), this
* returns GIT_ENOTFOUND.
*
* If the name matches multiple files (for example, if the `path` names a
* directory or if running on a case- insensitive filesystem and yet the
* HEAD has two entries that both match the path), then this returns
* GIT_EAMBIGUOUS because it cannot give correct results.
*
* This does not do any sort of rename detection. Renames require a set of
* targets and because of the path filtering, there is not enough
* information to check renames correctly. To check file status with rename
* detection, there is no choice but to do a full `git_status_list_new` and
* scan through looking for the path that you are interested in.
*
*
* @param status_flags Output combination of git_status_t values for file
* @param status_flags Output combination of git_status_t values for file
* @param repo A repository object
* @param repo A repository object
...
@@ -269,6 +286,11 @@ GIT_EXTERN(int) git_status_file(
...
@@ -269,6 +286,11 @@ GIT_EXTERN(int) git_status_file(
/**
/**
* Gather file status information and populate the `git_status_list`.
* Gather file status information and populate the `git_status_list`.
*
*
* Note that if a `pathspec` is given in the `git_status_options` to filter
* the status, then the results from rename detection (if you enable it) may
* not be accurate. To do rename detection properly, this must be called
* with no `pathspec` so that all files can be considered.
*
* @param out Pointer to store the status results in
* @param out Pointer to store the status results in
* @param repo Repository object
* @param repo Repository object
* @param opts Status options structure
* @param opts Status options structure
...
@@ -282,6 +304,9 @@ GIT_EXTERN(int) git_status_list_new(
...
@@ -282,6 +304,9 @@ GIT_EXTERN(int) git_status_list_new(
/**
/**
* Gets the count of status entries in this list.
* Gets the count of status entries in this list.
*
*
* If there are no changes in status (at least according the options given
* when the status list was created), this can return 0.
*
* @param statuslist Existing status list object
* @param statuslist Existing status list object
* @return the number of status entries
* @return the number of status entries
*/
*/
...
...
tests/status/renames.c
View file @
6b833e3a
...
@@ -582,12 +582,13 @@ void test_status_renames__zero_byte_file_does_not_fail(void)
...
@@ -582,12 +582,13 @@ void test_status_renames__zero_byte_file_does_not_fail(void)
}
}
#ifdef GIT_USE_ICONV
#ifdef GIT_USE_ICONV
static
char
*
nfc
=
"
\xC3\x85\x73\x74\x72\xC3\xB6\x6D
"
;
static
char
*
nfc
=
"
\xC3\x85\x73\x74\x72\xC3\xB6\x6D
"
;
static
char
*
nfd
=
"
\x41\xCC\x8A\x73\x74\x72\x6F\xCC\x88\x6D
"
;
static
char
*
nfd
=
"
\x41\xCC\x8A\x73\x74\x72\x6F\xCC\x88\x6D
"
;
#endif
void
test_status_renames__precomposed_unicode_rename
(
void
)
void
test_status_renames__precomposed_unicode_rename
(
void
)
{
{
#ifdef GIT_USE_ICONV
git_status_list
*
statuslist
;
git_status_list
*
statuslist
;
git_status_options
opts
=
GIT_STATUS_OPTIONS_INIT
;
git_status_options
opts
=
GIT_STATUS_OPTIONS_INIT
;
struct
status_entry
expected0
[]
=
{
struct
status_entry
expected0
[]
=
{
...
@@ -634,10 +635,12 @@ void test_status_renames__precomposed_unicode_rename(void)
...
@@ -634,10 +635,12 @@ void test_status_renames__precomposed_unicode_rename(void)
cl_git_pass
(
git_status_list_new
(
&
statuslist
,
g_repo
,
&
opts
));
cl_git_pass
(
git_status_list_new
(
&
statuslist
,
g_repo
,
&
opts
));
check_status
(
statuslist
,
expected3
,
ARRAY_SIZE
(
expected3
));
check_status
(
statuslist
,
expected3
,
ARRAY_SIZE
(
expected3
));
git_status_list_free
(
statuslist
);
git_status_list_free
(
statuslist
);
#endif
}
}
void
test_status_renames__precomposed_unicode_toggle_is_rename
(
void
)
void
test_status_renames__precomposed_unicode_toggle_is_rename
(
void
)
{
{
#ifdef GIT_USE_ICONV
git_status_list
*
statuslist
;
git_status_list
*
statuslist
;
git_status_options
opts
=
GIT_STATUS_OPTIONS_INIT
;
git_status_options
opts
=
GIT_STATUS_OPTIONS_INIT
;
struct
status_entry
expected0
[]
=
{
struct
status_entry
expected0
[]
=
{
...
@@ -703,6 +706,6 @@ void test_status_renames__precomposed_unicode_toggle_is_rename(void)
...
@@ -703,6 +706,6 @@ void test_status_renames__precomposed_unicode_toggle_is_rename(void)
cl_git_pass
(
git_status_list_new
(
&
statuslist
,
g_repo
,
&
opts
));
cl_git_pass
(
git_status_list_new
(
&
statuslist
,
g_repo
,
&
opts
));
check_status
(
statuslist
,
expected3
,
ARRAY_SIZE
(
expected3
));
check_status
(
statuslist
,
expected3
,
ARRAY_SIZE
(
expected3
));
git_status_list_free
(
statuslist
);
git_status_list_free
(
statuslist
);
#endif
}
}
#endif
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