mirror of
https://git.proxmox.com/git/libgit2
synced 2025-08-06 10:32:56 +00:00
Merge pull request #1356 from arrbee/fix-directory-as-ignore-file
Do not fail if .gitignore is directory
This commit is contained in:
commit
68fec637a2
10
src/attr.c
10
src/attr.c
@ -278,8 +278,14 @@ static int load_attr_file(
|
|||||||
return GIT_ENOTFOUND;
|
return GIT_ENOTFOUND;
|
||||||
|
|
||||||
error = git_futils_readbuffer(&content, filename);
|
error = git_futils_readbuffer(&content, filename);
|
||||||
if (error < 0)
|
if (error < 0) {
|
||||||
return error;
|
/* convert error into ENOTFOUND so failed permissions / invalid
|
||||||
|
* file type don't actually stop the operation in progress.
|
||||||
|
*/
|
||||||
|
return GIT_ENOTFOUND;
|
||||||
|
|
||||||
|
/* TODO: once warnings are available, issue a warning callback */
|
||||||
|
}
|
||||||
|
|
||||||
*data = git_buf_detach(&content);
|
*data = git_buf_detach(&content);
|
||||||
|
|
||||||
|
@ -1,32 +1,48 @@
|
|||||||
#include "clar_libgit2.h"
|
#include "clar_libgit2.h"
|
||||||
|
#include "posix.h"
|
||||||
|
#include "path.h"
|
||||||
|
|
||||||
static git_repository *g_repo = NULL;
|
static git_repository *g_repo = NULL;
|
||||||
|
|
||||||
void test_attr_ignore__initialize(void)
|
void test_attr_ignore__initialize(void)
|
||||||
{
|
{
|
||||||
g_repo = cl_git_sandbox_init("attr");
|
g_repo = cl_git_sandbox_init("attr");
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_attr_ignore__cleanup(void)
|
void test_attr_ignore__cleanup(void)
|
||||||
{
|
{
|
||||||
cl_git_sandbox_cleanup();
|
cl_git_sandbox_cleanup();
|
||||||
g_repo = NULL;
|
g_repo = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void assert_is_ignored(bool expected, const char *filepath)
|
void assert_is_ignored(bool expected, const char *filepath)
|
||||||
{
|
{
|
||||||
int is_ignored;
|
int is_ignored;
|
||||||
|
|
||||||
cl_git_pass(git_ignore_path_is_ignored(&is_ignored, g_repo, filepath));
|
cl_git_pass(git_ignore_path_is_ignored(&is_ignored, g_repo, filepath));
|
||||||
cl_assert_equal_i(expected, is_ignored == 1);
|
cl_assert_equal_i(expected, is_ignored == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_attr_ignore__honor_temporary_rules(void)
|
void test_attr_ignore__honor_temporary_rules(void)
|
||||||
{
|
{
|
||||||
cl_git_rewritefile("attr/.gitignore", "/NewFolder\n/NewFolder/NewFolder");
|
cl_git_rewritefile("attr/.gitignore", "/NewFolder\n/NewFolder/NewFolder");
|
||||||
|
|
||||||
assert_is_ignored(false, "File.txt");
|
assert_is_ignored(false, "File.txt");
|
||||||
assert_is_ignored(true, "NewFolder");
|
assert_is_ignored(true, "NewFolder");
|
||||||
assert_is_ignored(true, "NewFolder/NewFolder");
|
assert_is_ignored(true, "NewFolder/NewFolder");
|
||||||
assert_is_ignored(true, "NewFolder/NewFolder/File.txt");
|
assert_is_ignored(true, "NewFolder/NewFolder/File.txt");
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_attr_ignore__skip_gitignore_directory(void)
|
||||||
|
{
|
||||||
|
cl_git_rewritefile("attr/.git/info/exclude", "/NewFolder\n/NewFolder/NewFolder");
|
||||||
|
p_unlink("attr/.gitignore");
|
||||||
|
cl_assert(!git_path_exists("attr/.gitignore"));
|
||||||
|
p_mkdir("attr/.gitignore", 0777);
|
||||||
|
cl_git_mkfile("attr/.gitignore/garbage.txt", "new_file\n");
|
||||||
|
|
||||||
|
assert_is_ignored(false, "File.txt");
|
||||||
|
assert_is_ignored(true, "NewFolder");
|
||||||
|
assert_is_ignored(true, "NewFolder/NewFolder");
|
||||||
|
assert_is_ignored(true, "NewFolder/NewFolder/File.txt");
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user