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
dc5b678f
Commit
dc5b678f
authored
Sep 12, 2015
by
Carlos Martín Nieto
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #3422 from ethomson/workdir_diff
diff: examine pathlist on non-files
parents
049dbf42
8ab4d0e1
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
60 additions
and
8 deletions
+60
-8
src/diff.c
+17
-8
tests/diff/workdir.c
+43
-0
No files found.
src/diff.c
View file @
dc5b678f
...
@@ -75,18 +75,27 @@ static int diff_insert_delta(
...
@@ -75,18 +75,27 @@ static int diff_insert_delta(
}
}
static
bool
diff_pathspec_match
(
static
bool
diff_pathspec_match
(
const
char
**
matched_pathspec
,
git_diff
*
diff
,
const
char
*
path
)
const
char
**
matched_pathspec
,
git_diff
*
diff
,
const
git_index_entry
*
entry
)
{
{
/* The iterator has filtered out paths for us, so the fact that we're
bool
disable_pathspec_match
=
* seeing this patch means that it must match the given path list.
DIFF_FLAG_IS_SET
(
diff
,
GIT_DIFF_DISABLE_PATHSPEC_MATCH
);
/* If we're disabling fnmatch, then the iterator has already applied
* the filters to the files for us and we don't have to do anything.
* However, this only applies to *files* - the iterator will include
* directories that we need to recurse into when not autoexpanding,
* so we still need to apply the pathspec match to directories.
*/
*/
if
(
DIFF_FLAG_IS_SET
(
diff
,
GIT_DIFF_DISABLE_PATHSPEC_MATCH
))
{
if
((
S_ISLNK
(
entry
->
mode
)
||
S_ISREG
(
entry
->
mode
))
&&
*
matched_pathspec
=
path
;
disable_pathspec_match
)
{
*
matched_pathspec
=
entry
->
path
;
return
true
;
return
true
;
}
}
return
git_pathspec__match
(
return
git_pathspec__match
(
&
diff
->
pathspec
,
path
,
false
,
&
diff
->
pathspec
,
entry
->
path
,
disable_pathspec_match
,
DIFF_FLAG_IS_SET
(
diff
,
GIT_DIFF_IGNORE_CASE
),
DIFF_FLAG_IS_SET
(
diff
,
GIT_DIFF_IGNORE_CASE
),
matched_pathspec
,
NULL
);
matched_pathspec
,
NULL
);
}
}
...
@@ -127,7 +136,7 @@ static int diff_delta__from_one(
...
@@ -127,7 +136,7 @@ static int diff_delta__from_one(
DIFF_FLAG_ISNT_SET
(
diff
,
GIT_DIFF_INCLUDE_UNREADABLE
))
DIFF_FLAG_ISNT_SET
(
diff
,
GIT_DIFF_INCLUDE_UNREADABLE
))
return
0
;
return
0
;
if
(
!
diff_pathspec_match
(
&
matched_pathspec
,
diff
,
entry
->
path
))
if
(
!
diff_pathspec_match
(
&
matched_pathspec
,
diff
,
entry
))
return
0
;
return
0
;
delta
=
diff_delta__alloc
(
diff
,
status
,
entry
->
path
);
delta
=
diff_delta__alloc
(
diff
,
status
,
entry
->
path
);
...
@@ -768,7 +777,7 @@ static int maybe_modified(
...
@@ -768,7 +777,7 @@ static int maybe_modified(
const
char
*
matched_pathspec
;
const
char
*
matched_pathspec
;
int
error
=
0
;
int
error
=
0
;
if
(
!
diff_pathspec_match
(
&
matched_pathspec
,
diff
,
oitem
->
path
))
if
(
!
diff_pathspec_match
(
&
matched_pathspec
,
diff
,
oitem
))
return
0
;
return
0
;
memset
(
&
noid
,
0
,
sizeof
(
noid
));
memset
(
&
noid
,
0
,
sizeof
(
noid
));
...
...
tests/diff/workdir.c
View file @
dc5b678f
...
@@ -2054,3 +2054,46 @@ void test_diff_workdir__only_writes_index_when_necessary(void)
...
@@ -2054,3 +2054,46 @@ void test_diff_workdir__only_writes_index_when_necessary(void)
git_index_free
(
index
);
git_index_free
(
index
);
}
}
void
test_diff_workdir__to_index_pathlist
(
void
)
{
git_index
*
index
;
git_diff
*
diff
;
git_diff_options
opts
=
GIT_DIFF_OPTIONS_INIT
;
git_vector
pathlist
=
GIT_VECTOR_INIT
;
git_vector_insert
(
&
pathlist
,
"foobar/asdf"
);
git_vector_insert
(
&
pathlist
,
"subdir/asdf"
);
git_vector_insert
(
&
pathlist
,
"ignored/asdf"
);
g_repo
=
cl_git_sandbox_init
(
"status"
);
cl_git_mkfile
(
"status/.gitignore"
,
".gitignore
\n
"
"ignored/
\n
"
);
cl_must_pass
(
p_mkdir
(
"status/foobar"
,
0777
));
cl_git_mkfile
(
"status/foobar/one"
,
"one
\n
"
);
cl_must_pass
(
p_mkdir
(
"status/ignored"
,
0777
));
cl_git_mkfile
(
"status/ignored/one"
,
"one
\n
"
);
cl_git_mkfile
(
"status/ignored/two"
,
"two
\n
"
);
cl_git_mkfile
(
"status/ignored/three"
,
"three
\n
"
);
cl_git_pass
(
git_repository_index
(
&
index
,
g_repo
));
opts
.
flags
=
GIT_DIFF_INCLUDE_IGNORED
;
opts
.
pathspec
.
strings
=
pathlist
.
contents
;
opts
.
pathspec
.
count
=
pathlist
.
length
;
cl_git_pass
(
git_diff_index_to_workdir
(
&
diff
,
g_repo
,
index
,
&
opts
));
cl_assert_equal_i
(
0
,
git_diff_num_deltas
(
diff
));
git_diff_free
(
diff
);
opts
.
flags
|=
GIT_DIFF_DISABLE_PATHSPEC_MATCH
;
cl_git_pass
(
git_diff_index_to_workdir
(
&
diff
,
g_repo
,
index
,
&
opts
));
cl_assert_equal_i
(
0
,
git_diff_num_deltas
(
diff
));
git_diff_free
(
diff
);
git_index_free
(
index
);
git_vector_free
(
&
pathlist
);
}
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