Git Ignorar y .gitignore
Ignorar
Al compartir su código con otros, a menudo hay archivos o partes de su proyecto que no desea compartir.
Ejemplos
- archivos de registro
- archivos temporales
- archivos ocultos
- archivos personales
- etc
Git puede especificar qué archivos o partes de su proyecto deben ser ignorados por Git usando un .gitignore
archivo.
Git no rastreará los archivos y carpetas especificados en .gitignore
. Sin embargo, Git realiza un seguimiento del archivo en .gitignore
sí .
Crear .gitignore
Para crear un .gitignore
archivo, vaya a la raíz de su Git local y créelo:
Ejemplo
touch .gitignore
Ahora abra el archivo usando un editor de texto.
Solo vamos a agregar dos reglas simples:
- Ignora cualquier archivo con la
.log
extensión - Ignorar todo en cualquier directorio llamado
temp
Ejemplo
# ignore ALL .log files
*.log
# ignore ALL files in ANY directory named temp
temp/
Ahora Git ignorará todos los .log
archivos y cualquier cosa en
las carpetas.temp
Nota: En este caso, usamos uno único .gitignore
que se aplica a todo el repositorio.
También es posible tener .gitignore
archivos adicionales en subdirectorios. Estos solo se aplican a archivos o carpetas dentro de ese directorio.
Reglas para .gitignore
Estas son las reglas generales para hacer coincidir patrones en .gitignore
archivos:
Pattern | Explanation/Matches | Examples |
---|---|---|
Blank lines are ignored | ||
# text comment | Lines starting with # are ignored | |
name | All name files, name folders, and files and folders in any name folder | /name.log /name/file.txt /lib/name.log |
name/ | Ending with / specifies the pattern is for a folder. Matches all files and folders in any name folder | /name/file.txt /name/log/name.log no match: /name.log |
name.file | All files with the name.file | /name.file /lib/name.file |
/name.file | Starting with / specifies the pattern matches only files in the root folder | /name.file no match: /lib/name.file |
lib/name.file | Patterns specifiing files in specific folders are always realative to root (even if you do not start with / ) | /lib/name.file no match: name.file /test/lib/name.file |
**/lib/name.file | Starting with ** before / specifies that it matches any folder in the repository. Not just on root. | /lib/name.file /test/lib/name.file |
**/name | All name folders, and files and folders in any name folder | /name/log.file /lib/name/log.file /name/lib/log.file |
/lib/**/name | All name folders, and files and folders in any name folder within the lib folder. | /lib/name/log.file /lib/test/name/log.file /lib/test/ver1/name/log.file no match: /name/log.file |
*.file | All files withe .file extention | /name.file /lib/name.file |
*name/ | All folders ending with name | /lastname/log.file /firstname/log.file |
name?.file | ? matches a single non-specific character | /names.file /name1.file no match: /names1.file |
name[a-z].file | [range] matches a single character in the specified range (in this case a character in the range of a-z, and also be numberic.) | /names.file /nameb.file no match: /name1.file |
name[abc].file | [set] matches a single character in the specified set of characters (in this case either a, b, or c) | /namea.file /nameb.file no match: /names.file |
name[!abc].file | [!set] matches a single character, except the ones spesified in the set of characters (in this case a, b, or c) | /names.file /namex.file no match: /namesb.file |
*.file | All files withe .file extention | /name.file /lib/name.file |
name/ !name/secret.log |
! specifies a negation or exception. Matches all files and folders in any name folder, except name/secret.log | /name/file.txt /name/log/name.log no match: /name/secret.log |
*.file !name.file |
! specifies a negation or exception. All files withe .file extention, except name.file | /log.file /lastname.file no match: /name.file |
*.file !name/*.file junk.* |
Adding new patterns after a negation will re-ignore a previous negated file All files withe .file extention, except the ones in name folder. Unless the file name is junk |
/log.file /name/log.file no match: /name/junk.file |
Reglas locales y personales para ignorar Git
También es posible ignorar archivos o carpetas pero no mostrarlos en el .gitignore
archivo distubuido.
Estos tipos de ignorados se especifican en el
.git/info/exclude
archivo. Funciona de la misma manera
.gitignore
pero no se muestra a nadie más.