|  | /* | 
|  | * Copyright (C) the libgit2 contributors. All rights reserved. | 
|  | * | 
|  | * This file is part of libgit2, distributed under the GNU GPL v2 with | 
|  | * a Linking Exception. For full terms see the included COPYING file. | 
|  | */ | 
|  | #ifndef INCLUDE_ignore_h__ | 
|  | #define INCLUDE_ignore_h__ | 
|  |  | 
|  | #include "repository.h" | 
|  | #include "vector.h" | 
|  | #include "attr_file.h" | 
|  |  | 
|  | #define GIT_IGNORE_FILE			".gitignore" | 
|  | #define GIT_IGNORE_FILE_INREPO	"info/exclude" | 
|  | #define GIT_IGNORE_FILE_XDG		"ignore" | 
|  |  | 
|  | /* The git_ignores structure maintains three sets of ignores: | 
|  | * - internal ignores | 
|  | * - per directory ignores | 
|  | * - global ignores (at lower priority than the others) | 
|  | * As you traverse from one directory to another, you can push and pop | 
|  | * directories onto git_ignores list efficiently. | 
|  | */ | 
|  | typedef struct { | 
|  | git_repository *repo; | 
|  | git_buf dir; /* current directory reflected in ign_path */ | 
|  | git_attr_file *ign_internal; | 
|  | git_vector ign_path; | 
|  | git_vector ign_global; | 
|  | size_t dir_root; /* offset in dir to repo root */ | 
|  | int ignore_case; | 
|  | int depth; | 
|  | } git_ignores; | 
|  |  | 
|  | extern int git_ignore__for_path( | 
|  | git_repository *repo, const char *path, git_ignores *ign); | 
|  |  | 
|  | extern int git_ignore__push_dir(git_ignores *ign, const char *dir); | 
|  |  | 
|  | extern int git_ignore__pop_dir(git_ignores *ign); | 
|  |  | 
|  | extern void git_ignore__free(git_ignores *ign); | 
|  |  | 
|  | enum { | 
|  | GIT_IGNORE_UNCHECKED = -2, | 
|  | GIT_IGNORE_NOTFOUND = -1, | 
|  | GIT_IGNORE_FALSE = 0, | 
|  | GIT_IGNORE_TRUE = 1, | 
|  | }; | 
|  |  | 
|  | extern int git_ignore__lookup(int *out, git_ignores *ign, const char *path, git_dir_flag dir_flag); | 
|  |  | 
|  | /* command line Git sometimes generates an error message if given a | 
|  | * pathspec that contains an exact match to an ignored file (provided | 
|  | * --force isn't also given).  This makes it easy to check it that has | 
|  | * happened.  Returns GIT_EINVALIDSPEC if the pathspec contains ignored | 
|  | * exact matches (that are not already present in the index). | 
|  | */ | 
|  | extern int git_ignore__check_pathspec_for_exact_ignores( | 
|  | git_repository *repo, git_vector *pathspec, bool no_fnmatch); | 
|  |  | 
|  | #endif |