Setup and Config
Getting and Creating Projects
Basic Snapshotting
Branching and Merging
Sharing and Updating Projects
Inspection and Comparison
Patching
Debugging
External Systems
Server Admin
Guides
- gitattributes
- Command-line interface conventions
- Everyday Git
- Frequently Asked Questions (FAQ)
- Glossary
- Hooks
- gitignore
- gitmodules
- Revisions
- Submodules
- Tutorial
- Workflows
- All guides...
Administration
Plumbing Commands
- 2.48.1 no changes
- 2.48.0 no changes
- 2.47.1 → 2.47.2 no changes
- 2.47.0 10/06/24
- 2.46.1 → 2.46.3 no changes
- 2.46.0 07/29/24
- 2.45.2 → 2.45.3 no changes
- 2.45.1 04/29/24
- 2.45.0 04/29/24
- 2.44.2 → 2.44.3 no changes
- 2.44.1 04/19/24
- 2.44.0 02/23/24
- 2.43.5 → 2.43.6 no changes
- 2.43.4 04/19/24
- 2.43.2 → 2.43.3 no changes
- 2.43.1 02/09/24
- 2.43.0 11/20/23
- 2.42.3 → 2.42.4 no changes
- 2.42.2 04/19/24
- 2.42.1 11/02/23
- 2.42.0 08/21/23
- 2.41.2 → 2.41.3 no changes
- 2.41.1 04/19/24
- 2.41.0 06/01/23
- 2.40.3 → 2.40.4 no changes
- 2.40.2 04/19/24
- 2.40.1 no changes
- 2.40.0 no changes
- 2.39.5 no changes
- 2.39.4 04/19/24
- 2.39.1 → 2.39.3 no changes
- 2.39.0 12/12/22
- 2.38.3 → 2.38.5 no changes
- 2.38.2 12/11/22
- 2.38.1 no changes
- 2.38.0 10/02/22
- 2.37.3 → 2.37.7 no changes
- 2.37.2 08/11/22
- 2.37.1 no changes
- 2.37.0 06/27/22
- 2.36.1 → 2.36.6 no changes
- 2.36.0 04/18/22
- 2.35.1 → 2.35.8 no changes
- 2.35.0 01/24/22
- 2.34.1 → 2.34.8 no changes
- 2.34.0 11/15/21
- 2.33.3 → 2.33.8 no changes
- 2.33.2 03/23/22
- 2.33.1 10/12/21
- 2.32.1 → 2.33.0 no changes
- 2.32.0 06/06/21
- 2.31.1 → 2.31.8 no changes
- 2.31.0 03/15/21
- 2.30.1 → 2.30.9 no changes
- 2.30.0 12/27/20
- 2.29.1 → 2.29.3 no changes
- 2.29.0 10/19/20
- 2.28.1 no changes
- 2.28.0 07/27/20
- 2.27.1 no changes
- 2.27.0 06/01/20
- 2.26.1 → 2.26.3 no changes
- 2.26.0 03/22/20
- 2.25.2 → 2.25.5 no changes
- 2.25.1 02/17/20
- 2.25.0 01/13/20
- 2.23.1 → 2.24.4 no changes
- 2.23.0 08/16/19
- 2.22.2 → 2.22.5 no changes
- 2.22.1 08/11/19
- 2.22.0 06/07/19
- 2.20.1 → 2.21.4 no changes
- 2.20.0 12/09/18
- 2.19.3 → 2.19.6 no changes
- 2.19.2 11/21/18
- 2.19.1 no changes
- 2.19.0 09/10/18
- 2.18.1 → 2.18.5 no changes
- 2.18.0 06/21/18
- 2.17.1 → 2.17.6 no changes
- 2.17.0 04/02/18
- 2.16.6 12/06/19
- 2.15.4 12/06/19
- 2.14.6 12/06/19
- 2.13.7 no changes
- 2.12.5 09/22/17
- 2.11.4 09/22/17
- 2.10.5 09/22/17
- 2.9.5 07/30/17
- 2.8.6 07/30/17
- 2.7.6 07/30/17
- 2.6.7 05/05/17
- 2.5.6 05/05/17
- 2.4.12 05/05/17
- 2.3.10 09/28/15
- 2.2.3 09/04/15
- 2.1.4 12/17/14
- 2.0.5 12/17/14
SINOPSIS
git [-v | --version] [-h | --help] [-C <ruta>] [-c <nombre>=<valor>] [--exec-path[=<ruta>]] [--html-path] [--man-path] [--info-path] [-p | --paginate| -P | --no-pager] [--no-replace-objects] [--no-lazy-fetch] [--no-optional-locks] [--no-advice] [--bare] [--git-dir=<ruta>] [--work-tree=<ruta>] [--namespace=<nombre>] [--config-env=<nombre>=<var-ambiente>] <comando> [<argumentos>]
DESCRIPCIÓN
Git es un sistema de control de revisiones distribuido, rápido y escalable con un conjunto de comandos inusualmente rico que permite tanto operaciones de alto nivel como acceso completo a componentes internos.
Ver gittutorial[7] para comenzar, luego ver giteveryday[7] para un útil conjunto de comandos mínimo. El Manual de Usuario de Git tiene una introducción mas a fondo.
Después que domines los conceptos básicos, puedes regresar a ésta página para aprender qué comandos ofrece Git. Puedes aprender mas sobre comandos Git individuales con el comando "git help comando". La página del manual gitcli[7] te da una vistazo de la sintáxis de comandos en la línea de comandos.
Una copia formateada e hipervinculada de la mas reciente documentación de Git puede verse en https://git.github.io/htmldocs/git.html o https://git-scm.com/docs.
OPCIONES
- -v
- --version
-
Imprime la versión de la suite Git de la cual proviene el programa git.
Esta opción es internamente convertida a
git version ...
y acepta las mismas opciones que el comando git-version[1]. Si también se da--help
toma precedencia sobre--version
. - -h
- --help
-
Imprime la sinopsis y una lista de los comandos más usados comúnmente. Si se da la opción
--all
o-a
entonces todos los comandos disponibles se imprimen. Si un comando Git es nombrado, esta opción traerá la página del manual para ese comando.Hay otras opciones disponibles para controlar cómo se muestra la página del manual. Ver git-help[1] para mayor información, porque
git --help ...
es convertido internamente engit help ...
. - -C <ruta>
-
Corre como si git hubiera iniciado en
<ruta>
en lugar del directorio de trabajo actual. Cuando se dan múltiples opciones-C
, cada-C <ruta>
no-absoluta subsecuente se interpreta como relativa al-C <ruta>
precedente. Si<ruta>
esta presente pero vacía, ej.-C ""
, entonces el directorio de trabajo actual queda sin modificaciones.Esta opción afecta opciones que esperan una ruta (como
--git-dir
y--work-tree
), en donde sus interpretaciones de los nombres de ruta se harían relativos al directorio de trabajo a causa de la opción-C
. Por ejemplo, las invocaciones siguientes son equivalentes:git --git-dir=a.git --work-tree=b -C c status git --git-dir=c/a.git --work-tree=c/b status
- -c <nombre>=<valor>
-
Pasa un parámetro de configuración al comando. El valor dado sobreescribirá valores de ficheros de configuración. El <nombre> se espera en el mismo formato como se lista por git config (subclaves separadas por puntos).
Nota que es permitido omitir el
=
engit -c foo.bar ...
y se asignará afoo.bar
el valor booleano true (así como[foo]bar
lo haría en un fichero de configuración). Incluir el igual pero con un valor vacío (comogit -c foo.bar= ...
) asigna afoo.bar
la cadena vacía quegit config --type=bool
convertirá afalse
. - --config-env=<nombre>=<variable-de-ambiente>
-
Como
-c <nombre>=<valor>
, da a la variable de configuración <nombre> un valor, donde <variable-de-ambiente> es el nombre de una variable de ambiente de la cual se obtiene el valor. Al contrario que-c
no hay un atajo para asignar directamente el valor a una cadena vacía, en cambio, a la variable de ambiente misma se le debe asignar la cadena vacía. Es un error si la<variable-de-ambiente>
no existe en el ambiente.<variable-de-ambiente>
no puede contener un signo de igual para evitar ambigüedad con<nombre>
que contenga.Esto es útil en casos donde quieres pasar a git opciones de configuración transitorias, pero se hacen tan en el sistema oprativo donde otros procesos pueden ser capaces de leer tu línea de comandos (ej.
/proc/self/cmdline
), pero no tu ambiente (ej./proc/self/environ
). Ese es el comportamiento predeterminado en Linux, pero pudiera no serlo en tu sistema.Nota que esto puede agregar seguridad para variables como
http.extraHeader
donde la información sensible es parte del valor, pero no ej.url.<base>.insteadOf
donde la información sensible puede ser parte de la clave. - --exec-path[=<ruta>]
-
Ruta a dondequiera que estén instalados tus programas del núcleo de Git. Esto también puede ser controlado asignando la variable de ambiente GIT_EXEC_PATH. Si no se proporciona ruta git imprimirá la configuración actual y saldrá.
- --html-path
-
Imprime la ruta, sin la última diagonal, donde esta instalada la documentación HTML de Git y sale.
- --man-path
-
Imprime la ruta del manual (ver
man(1)
) para las páginas del manual de esta versión de Git y sale. - --info-path
-
Imprime la ruta donde están instalados los ficheros de información documentando esta versión de Git y sale.
- -p
- --paginate
-
Entuba toda la salida hacia less (o si esta configurado, $PAGER) si la salida estándar es una terminal. Esto sobreescribe las opciones de configuración
pager.<comando>
(ver la sección "Mecanismo de Configuración" mas abajo). - -P
- --no-pager
-
No entuba la salida de Git hacia el paginador.
- --git-dir=<ruta>
-
Asigna la ruta al repositorio (directorio ".git"). Esto también puede ser controlado configurando la variable de ambiente
GIT_DIR
. Puede ser una ruta absoluta o relativa al directorio de trabajo actual.Especificando la ubicación del directorio ".git" usando esta opción (o la variable de ambiente
GIT_DIR
) apaga el descubrimiento de repositorio que intenta encontrar un directorio con subdirectorio ".git" (que es como se descubren el repositorio y el nivel mas alto del árbol de trabajo), y le dice a Git que estás en el nivel mas alto del árbol de trabajo. Si no estas en el directorio de nivel mas alto del árbol de trabajo, deberías decirle a Git dónde esta el nivel más alto del árbol de trabajo con la opción--work-tree=<ruta>
(o la variable de ambienteGIT_WORK_TREE
)Si sólo quieres correr git como si fuera arrancado en
<ruta>
entonces usagit -C <ruta>
. - --work-tree=<ruta>
-
Asigna la ruta al árbol de trabajo. Puede ser una ruta absoluta o relativa al directorio de trabajo actual. Esto puede se controlado asignando la variable de ambiente GIT_WORK_TREE y la variable de configuración core.worktree (ver core.worktree en git-config[1] para una discusión mas detallada).
- --namespace=<ruta>
-
Asigna el espacio de nombres de Git. Ver gitnamespaces[7] para mas detalles. Equivalente a asignar la variable de ambiente
GIT_NAMESPACE
. - --bare
-
Trata el repositorio como un repositorio básico. Si la variable de ambiente GIT_DIR no esta asignada, se asigna al directorio de trabajo actual.
- --no-replace-objects
-
No usa remplazamiento de referencias para remplazar objetos Git. Esto equivale a exportar la variable de ambiente
GIT_NO_REPLACE_OBJECTS
con cualquier valor. Ver git-replace[1] para mas información. - --no-lazy-fetch
-
No trae objetos faltantes desde el remoto prometente bajo demanda. Útil junto con
git cat-file -e <objeto>
para ver si el objeto esta localmente disponible. Esto es equivalente a asignar1
a la variable de ambienteGIT_NO_LAZY_FETCH
. - --no-optional-locks
-
No realiza operaciones opcionales que requieran bloqueos. Es equivalente a asignar
0
aGIT_OPTIONAL_LOCKS
. - --no-advice
-
Deshabilita la impresión de todas las sugerencias.
- --literal-pathspecs
-
Trata las especificaciones de ruta literalmente (ej. sin interpretar glob, sin especificaciones de ruta mágicas). Es equivalente a asignar la variable de ambiente
GIT_LITERAL_PATHSPECS
con1
. - --glob-pathspecs
-
Agrega magia "glob" a todas las especificaciones de ruta. Es equivalente a asignar
1
a la variable de ambienteGIT_GLOB_PATHSPECS
. Se puede deshabilitar interpretación de glob en especificaciones de ruta individuales usando la especificación de ruta mágica ":(literal)" - --noglob-pathspecs
-
Agrega magia "literal" a todas las especificaciones de ruta. Es equivalente a asignar
1
a la variable de ambienteGIT_NOGLOB_PATHSPECS
. Se puede habilitar interpretación de glob en especificaciones de ruta individuales usando la especificación de ruta mágica ":(glob)" - --icase-pathspecs
-
Agrega magia "icase" a todas las especificaciones de ruta. Es equivalente a asignar
1
a la variable de ambienteGIT_ICASE_PATHSPECS
. - --list-cmds=<grupo>[,<grupo>…]
-
Lista comandos por grupo. Es una opción interna/experimental y puede cambiar o ser removida en el futuro. Los grupos soportados son: builtins, parseopt (comandos interconstruidos que usan opciones de parseo), main (todos los comandos en el directorio libexec), others (todos los otros comandos en
$PATH
que tienen el prefijo git-), list-<categoría> (ver categorías en command-list.txt), nohelpers (excluye comandos auxiliares), alias y config (obtiene la lista de comandos de la variable de configuración completion.commands) - --attr-source=<árbol-ismo>
-
Lee atributos git de <árbol-ismo> en lugar del árbol de trabajo. Ver gitattributes[5]. Equivale a asignar la variable de ambiente
GIT_ATTR_SOURCE
.
COMANDOS GIT
Dividimos Git en comandos de alto nivel ("porcelana") y comandos de bajo nivel ("plomería").
Comandos de alto nivel (porcelana)
Separamos los comandos porcelana en comandos principales y algunas utilidades de usuario auxiliares.
Comandos porcelana principales
Warning
|
Missing See original version for this content. |
Comandos Auxiliares
Manipuladores:
Warning
|
Missing See original version for this content. |
Interrogadores:
Warning
|
Missing See original version for this content. |
Interactuando con Otros
Estos comandos son para interactuar con otros SCM y con otra gente vía parche sobre correo electrónico.
Warning
|
Missing See original version for this content. |
Resetear, restaurar y revertir
Hay tres comandos con nombres similares: git reset
, git restore
y git revert
.
-
git-revert[1] es acerca de hacer un nuevo commit que revierta los cambios hechos por otros commits.
-
git-restore[1] es acerca de restaurar ficheros en el árbol de trabajo de ya sea el índice u otro commit. Este comando no actualiza tu rama. El comando también puede usarse para restaurar ficheros en el índice de otro commit.
-
git-reset[1] es acerca de actualizar tu rama, moviendo la punta con el fin de agregar o eliminar commits de la rama. Esta operación cambia el historial de commits.
git reset
también puede usarse para restaurar el índice, traslapando congit restore
.
Comandos de bajo nivel (plomería)
Aunque Git incluye su propia capa de porcelana, sus comandos de bajo nivel son suficientes para soportar desarrollo de porcelanas alternativas. Desarrolladores de tales porcelanas podrían comenzar leyendo acerca de git-update-index[1] y git-read-tree[1].
La interfase (entrada, salida, conjunto de opciones y la semántica) a esos comandos de bajo nivel tienen la intención de ser mucho mas estables que comandos a nivel porcelana, porque esos comandos son primordialmente para ser usados por scripts. Por otro lado, la interface a comandos porcelana esta sujeta a cambios con el fin de mejorar la experiencia de usuario final.
La descripción siguiente divide los comandos de bajo nivel en comandos que manipulan objetos (en el repositorio, índice y árbol de trabajo), comandos que interrogan y comparan objetos, y comandos que mueven objetos y referencias entre repositorios.
Comandos de manipulación
Warning
|
Missing See original version for this content. |
Comandos de interrogación
Warning
|
Missing See original version for this content. |
En general, los comandos de interrogación no tocan los ficheros en el árbol de trabajo.
Sincronizando repositorios
Warning
|
Missing See original version for this content. |
Los siguientes son comandos auxiliares usados por los anteriores; usuarios finales típicamente no los usan directamente.
Warning
|
Missing See original version for this content. |
Guías
Las páginas de documentación siguientes son guías acerca de conceptos de Git.
Warning
|
Missing See original version for this content. |
Interfases de repositorio, comando y fichero
Esta documentación discute interfases de repositorio y comando con las cuales se espera que los usuarios interactúen directamente. Ver --user-formats
en git-help[1] para mas detalles sobre los criterios.
Warning
|
Missing See original version for this content. |
Formatos de fichero, protocolos y otras interfaces para el desarrollador
Esta documentación discute los formatos de fichero, protocolos sobre-el-cable y otras interfases de desarrollador git. Ver --developer-interfaces
en git-help[1].
Warning
|
Missing See original version for this content. |
Mecanismo de Configuración
Git usa un formato de texto simple para almacenar personalizaciones que son por repositorio y por usuario. Tal fichero de configuración puede parecerse a éste:
# # Un caracter '#' o ';' indica un comentario. # ; variables esenciales [core] ; No confiar modos de fichero filemode = false ; identidad del usuario [user] name = "Junio C Hamano" email = "gitster@pobox.com"
Varios comandos leen del fichero de configuración y ajustan su operación respectivamente. Ver git-config[1] para una lista y mas detalles acerca del mecanismo de configuración.
Terminología Identificadora
- <objeto>
-
Indica el nombre del objeto para cualquier tipo de objeto.
- <blob>
-
Indica un nombre de objeto blob.
- <árbol>
-
Indica un nombre de objeto árbol.
- <confirmación>
-
Indica un nombre de objeto commit.
- <árbol-ismo>
-
Indica un nombre de objeto árbol, commit o etiqueta. Un comando que toma un argumento <arbol-ismo> quiere operar en última instancia sobre un objeto <árbol> pero automáticamente desreferencia objetos <commit> y <etiqueta> que apuntan a un <árbol>.
- <confirmacion-ismo>
-
Indica un nombre de objeto commit o etiqueta. Un comando que toma un argumento <commit-ish> de último quiere operar sobre un objeto <commit> pero automáticamente desreferencia objetos <etiqueta> que apunten a un <commit>.
- <tipo>
-
Indica que un tipo de objeto es requerido. Actualmente uno de:
blob
,tree
,commit
, otag
. - <fichero>
-
Indica un nombre de fichero - casi siempre relativo a la raíz de la estructura del árbol que describe
GIT_INDEX_FILE
.
Identificadores Simbólicos
Cualquier comando Git que acepte cualquier <objeto> también puede usar la notación simbólica siguiente:
Para una lista completa de las maneras de deletrear nombres de objetos ver la sección "ESPECIFICANDO REVISIONES" en gitrevisions[7].
Estructura de Ficheros/Directorios
Por favor ver el documento gitrepository-layout[5].
Leer githooks[5] para mas detalles sobre cada gancho.
Gestores de Código Fuente de alto nivel pueden proveer y manejar información adicional en el $GIT_DIR
.
Terminología
Favor de ver gitglossary[7].
Variables de Ambiente
Varios comandos de Git prestan atención a variables de ambiente y alteran su funcionamiento. Las variables de ambiente marcadas como "Booleanas" toman sus valores de la misma manera que variables de configuración booleanas, ej. "true", "yes", "on" y números positivos se consideran como "yes".
Aquí las variables:
El Repositorio Git
Esas variables de ambiente aplican a todos los comandos de núcleo de Git. Nótese bien: cabe notar que pueden ser usadas/sobremontadas por Gestores de Código Fuente asentados sobre Git, entonces tener cuidado si se usa un front-end foráneo.
-
GIT_INDEX_FILE
-
Esta variable de ambiente especifica un fichero de índice alterno. Si no se especifica, se usa el valor predeterminado en
$GIT_DIR/index
. -
GIT_INDEX_VERSION
-
Esta variable de ambiente especifica qué versión de índice se usa al escribir el fichero de índice. No afectará ficheros de índice existentes. De manera predeterminada se usa la versión 2 o 3 del fichero de índice. Ver git-update-index[1] para mas información.
-
GIT_OBJECT_DIRECTORY
-
Si el directorio de almacenamiento de objetos se especifica por medio de esta variable de ambiente, entonces los directorios sha1 se crean debajo - de lo contrario se usa el directorio predeterminado
$GIT_DIR/objects
. -
GIT_ALTERNATE_OBJECT_DIRECTORIES
-
Debido a la naturaleza inmutable de los objetos Git, objetos antiguos pueden ser archivados en directorios compartidos de sólo lectura. Esta variable especifica una lista separada por ":" (en Windows separada por ";") de directorios de objetos Git que pueden ser usados para buscar objetos Git. Objetos nuevos no serán escritos en esos directorios.
Entradas que comienzan con
"
(comilla doble) serán interpretadas como rutas entrecomilladas estilo C, quitando la comillas dobles iniciales y finales y respetando escapes de diagonal invertida. Ej. el valor"ruta-con-\"-y-:-en-ella":ruta-vainilla
tiene dos rutas:ruta-con-"-y-:-en-ella
yruta-vainilla
. -
GIT_DIR
-
Si la variable de ambiente
GIT_DIR
esta asignada entonces especifica una ruta para usarse en lugar de la predeterminada.git
para la base del repositorio. La opción de línea de comando--git-dir
también asigna éste valor. -
GIT_WORK_TREE
-
Asigna la ruta de la raíz del árbol de trabajo. También puede controlarse con la opción de línea de comando
--work-tree
y la variable de configuración core.worktree. -
GIT_NAMESPACE
-
Asigna el espacio de nombres de Git; ver gitnamespaces[7] para detalles. La opción de línea de comandos
--namespace
también asigna éste valor. -
GIT_CEILING_DIRECTORIES
-
Esta debe ser una lista separada por dos puntos de rutas absolutas. Si se asigna, es una lista de directorios en los que Git no debería hacer chdir al buscar un directorio de repositorio (útil para excluir directorios de red de carga lenta). No excluirá el directorio de trabajo actual o un GIT_DIR configurado en línea de comandos o en el ambiente. Normalmente, Git tiene que leer las entradas en esta lista y resolver cualquier enlace simbólico que pueda estar presente con el fin de compararlos con el directorio actual. Sin embargo, si incluso éste acceso es lento, puedes agregar a la lista una entrada vacía para indicarle a Git que las entradas subsecuentes no son enlaces simbólicos y que por lo tanto no necesitan resolverse; ej.
GIT_CEILING_DIRECTORIES=/posible/enlace::/no/enlace/muy/lento
. -
GIT_DISCOVERY_ACROSS_FILESYSTEM
-
Cuando se ejecuta en un directorio que no tiene directorio de repositorio ".git", Git intenta encontrarlo en los directorios padres para encontrar el tope del directorio de trabajo, pero predeterminadamente no cruza los límites del sistema de ficheros. A esta variable de ambiente booleana se le puede asignar true para indicarle a Git que no pare en los límites del sistema operativo. Así como
GIT_CEILING_DIRECTORIES
, no afectará un directorio de repositorio explícito configurado enGIT_DIR
o en la línea de comandos. -
GIT_COMMON_DIR
-
Si a esta variable se le asigna una ruta, los ficheros que no son del árbol de trabajo que normalmente están en $GIT_DIR serán tomados en cambio de esta ruta. Ficheros específicos del árbol de trabajo como HEAD y index se toman de $GIT_DIR. Ver gitrepository-layout[5] y git-worktree[1] para detalles. Esta variable tiene precedencia mas baja que otras variables de ruta como GIT_INDEX_FILE, GIT_OBJECT_DIRECTORY…
-
GIT_DEFAULT_HASH
-
Si se configura esta variable, el algoritmo predeterminado de hash para repositorios nuevos será asignado con éste valor. Al clonar se ignora este valor y siempre se usa la configuración del repositorio remoto. El predeterminado es "sha1". Ver
--object-format
en git-init[1]. -
GIT_DEFAULT_REF_FORMAT
-
Si se configura esta variable, el formato predeterminado de almacenamiento de referencias para repositorios nuevos será asignado con éste valor. El predeterminado es "files". Ver
--ref-format
en git-init[1].
Confirmaciones de Git
-
GIT_AUTHOR_NAME
-
El nombre legible al humano usado en la identidad del autor cuando se crean objetos confirmación o etiqueta, o cuando se escriben reflogs. Anula las configuraciones
user.name
yauthor.name
. -
GIT_AUTHOR_EMAIL
-
La dirección de correo electrónico usada en la identidad del autor cuando se crean objetos confirmación o etiqueta, o cuando se escriben reflogs. Anula las configuraciones
user.email
yauthor.email
. -
GIT_AUTHOR_DATE
-
La fecha usada para la identidad del autor cuando se crean objetos confirmación o etiqueta, o cuando se escriben reflogs. Ver git-commit[1] para formatos válidos.
-
GIT_COMMITTER_NAME
-
El nombre legible al humano usado en la identidad del confirmante cuando se crean objetos confirmación o etiqueta, o cuando se escriben referencias de bitácora. Anula las configuraciones de
user.name
ycommitter.name
. -
GIT_COMMITTER_EMAIL
-
La dirección de correo electrónico usada en la identidad del autor cuando se crean objetos confirmación o etiqueta, o cuando se escriben referencias de bitácora. Anula las configuraciones de
user.email
ycommitter.email
. -
GIT_COMMITTER_DATE
-
La fecha usada para la identidad del confirmante cuando se crean objetos confirmación o etiqueta, o cuando se escriben referencias de bitácora. Ver git-commit[1] para formatos válidos.
-
EMAIL
-
La dirección de correo electrónico usada en las identidades de autor y confirmante si no se ha asignado alguna otra variable de ambiente o configuración relevante.
Diffs de Git
-
GIT_DIFF_OPTS
-
La única configuración válida es "--unified=??" o "-u??" para asignar el número de líneas de contexto a mostrarse cuando se crea un diff unificado. Toma precedencia sobre cualquier valor de opción "-U" o "--unified" pasada en la línea de comandos del diff Git.
-
GIT_EXTERNAL_DIFF
-
Cuando se asigna la variable de ambiente
GIT_EXTERNAL_DIFF
, se llama al programa nombrado en ella para generar diffs, y Git no usa su maquinaria de diff interconstruida. Para una ruta que es agregada, removida, o modificada, se llama aGIT_EXTERNAL_DIFF
con 7 parámetros:ruta fichero-anterior hex-anterior modo-anterior fichero-nuevo hex-nuevo modo-nuevo
donde:
- fichero-<anterior|nuevo>
-
son los ficheros que GIT_EXTERNAL_DIFF puede usar para leer el contenido de <anterior|nuevo>,
- hex-<anterior|nuevo>
-
son los hash SHA1 de 40 dígitos hexadecimal,
- modo-<anterior|nuevo>
-
son la representación octal de los modos del fichero.
Los parámetros fichero pueden apuntar al fichero de trabajo del usuario (ej.
fichero-nuevo
en "git-diff-files"),/dev/null
(ej.fichero-anterior
cuando se agrega un fichero nuevo), o un fichero temporal (ej.fichero-anterior
en el índice).GIT_EXTERNAL_DIFF
no debería preocuparse por desenlazar el fichero temporal — es eliminado cuandoGIT_EXTERNAL_DIFF
sale.Para una ruta no-fusionada, se llama a
GIT_EXTERNAL_DIFF
con 1 parámetro, <ruta>.Para cada ruta se llama a
GIT_EXTERNAL_DIFF
, dos variables de ambiente se asignan,GIT_DIFF_PATH_COUNTER
yGIT_DIFF_PATH_TOTAL
. -
GIT_EXTERNAL_DIFF_TRUST_EXIT_CODE
-
Si a esta variable de ambiente booleana se le asigna true entonces se espera que el comando
GIT_EXTERNAL_DIFF
regrese un código de salida 0 si considera que los ficheros de entrada son iguales, o 1 si considera que son diferentes, comodiff(1)
. Si se le asigna false, el cual es el predeterminado, entonces se espera que el comando regrese un código de salida 0 independientemente de la igualdad. Cualquier otro código de salida provoca a Git a reportar un error fatal. -
GIT_DIFF_PATH_COUNTER
-
Un contador base 1 incrementado por uno por cada ruta.
-
GIT_DIFF_PATH_TOTAL
-
El número total de rutas.
otras
-
GIT_MERGE_VERBOSITY
-
Un número controlando la cantidad de salida mostrada por la estrategia de fusión recursiva. Anula merge.verbosity. Ver git-merge[1]
-
GIT_PAGER
-
Esta variable de ambiente anula
$PAGER
. Si se le asigna una cadena vacía o el valor "cat", Git no lanzará un paginador. Ver también la opcióncore.pager
en git-config[1]. -
GIT_PROGRESS_DELAY
-
Un número controlando cuántos segundos retardar antes de mostrar indicadores opcionales de progreso. Predeterminado a 2.
-
GIT_EDITOR
-
Esta variable de ambiente anula
$EDITOR
y$VISUAL
. Es usada por varios comandos Git cuando en modo interactivo se va a lanzar un editor. Ver también git-var[1] y la opcióncore.editor
en git-config[1]. -
GIT_SEQUENCE_EDITOR
-
Esta variable de ambiente anula el editor de Git configurado cuando se edita la lista de pendientes en un rebase interactivo. Ver también git-rebase[1] y la opción
sequence.editor
en git-config[1]. -
GIT_SSH
-
GIT_SSH_COMMAND
-
Si cualquiera de estas variables de ambiente se asigna entonces git fetch y git push usarán el comando especificado en lugar de ssh cuando se necesite conectar a un sistema remoto. Los parámetros de línea de comandos pasados al comando configurado los determina la variante de ssh. Ver la opción
ssh.variant
en git-config[1] para detalles.$GIT_SSH_COMMAND
toma precedencia sobre$GIT_SSH
, y es interpretado por el shell, el cual permite argumentos adicionales a incluirse. Por otro lado,$GIT_SSH
debe ser sólo la ruta al programa (el cual puede ser un script de shell envolvente, si se necesitan argumentos adicionales).Usualmente es mas fácil configurar cualquier opción deseada por medio de tu fichero personal
.ssh/config
. Por favor consulta tu documentación de ssh para mayores detalles. -
GIT_SSH_VARIANT
-
Si se asigna ésta variable de ambiente, anula que Git autodetecte si
GIT_SSH
/GIT_SSH_COMMAND
/core.sshCommand
se refiere a OpenSSH, link o tortoiseplink. Esta variable anula la configuraciónssh.variant
que sirve para el mismo propósito. -
GIT_SSL_NO_VERIFY
-
Asignando y exportando ésta variable de ambiente a cualquier valor le dice a Git que no verifique el certificado SSL cuando haga fetch o push sobre HTTPS.
-
GIT_ATTR_SOURCE
-
Asigna el árbol-ismo de donde se leerán gitattributes.
-
GIT_ASKPASS
-
Si se asigna esta variable de ambiente, entonces los comandos Git que necesiten recibir contraseñas o frases de acceso (ej. para autenticación HTTP o IMAP) llamarán a éste programa con una línea de entrada apropiada como argumento de línea de comandos y leer la contraseña de su STDOUT. Ver también la opción
core.askPass
en git-config[1]. -
GIT_TERMINAL_PROMPT
-
Si se asigna ésta variable de ambiente booleana, git no usará una línea de entrada en la terminal (ej. cuando se solicite una autenticación HTTP).
-
GIT_CONFIG_GLOBAL
-
GIT_CONFIG_SYSTEM
-
Toma la configuración de los ficheros dados en lugar de los ficheros de configuración global o a nivel sistema. Si
GIT_CONFIG_SYSTEM
es asignado, el fichero de configuración de sistema definido en tiempo de construcción (usualmente/etc/gitconfig
) no será leído. En el mismo sentido, siGIT_CONFIG_GLOBAL
es asignado, ninguno de$HOME/.gitconfig
o$XDG_CONFIG_HOME/git/config
será leído. Se le puede asignar/dev/null
para saltar la lectura de ficheros de configuración del nivel respectivo. -
GIT_CONFIG_NOSYSTEM
-
Si saltar la lectura de ajustes del fichero de ámbito de sistema
$(prefix)/etc/gitconfig
. Esta variable de ambiente booleana puede ser usada junto con$HOME
y$XDG_CONFIG_HOME
para crear un ambiente predecible para un script quisquilloso, o puedes asignarle verdadero para evitar temporalmente usar un fichero defectuoso/etc/gitconfig
mientras se espera a alguien con premisos suficientes para arreglarlo. -
GIT_FLUSH
-
Si a esta variable de ambiente booleana se le asigna true, entonces comandos como git-blame (en modo incremental), git rev-list, git log, git check-attr y git check-ignore forzarán un desalojo del flujo de salida después de que cada registro sea desalojado. Si a esta variable se le asigna false, la salida de esos comandos se hará usando búfer de E/S por completo. Si no se asigna esta variable de ambiente, Git elegirá desalojo por búfer u orientada a registro con base en si la salida estándar parece ser redirigida a un fichero o no.
-
GIT_TRACE
-
Habilita mensajes de rastreo general, ej. expansión de alias, ejecución de comando interconstruido y ejecución de comando externo.
Si a esta variable se le asigna "1", "2" o "true" (comparación sensible a mayúsculas), mensajes de rastreo se imprimirán en stderr.
Si a esta variable se le asigna un valor entero mayor a 2 y menor a 10 (estrictamente) entonces Git interpretará éste valor como un descriptor de fichero abierto e intentará escribir mensajes de rastro en éste descriptor de fichero.
Alternativamente, si a la variable se le asigna un ruta absoluta (iniciando con un caracter /), Git interpretará esta como una ruta de fichero e intentará adicionar mensajes de rastreo en él.
Desasignando la variable, o asignándole vacío, "0" o "false" (sensible a mayúsculas) deshabilita mensajes de rastreo.
-
GIT_TRACE_FSMONITOR
-
Habilita mensajes de rastreo para la extensión de monitoreo de sistema de ficheros. Ver
GIT_TRACE
para las opciones de salida de rastreo disponibles. -
GIT_TRACE_PACK_ACCESS
-
Habilita mensajes de rastreo para todos los accesos a cualquier paquete. Para cada acceso, se registra el nombre de fichero de paquete y un corrimiento. Esto puede ser de ayuda para diagnosticar algunos problemas de desempeño relacionados con paquetes. Ver
GIT_TRACE
para opciones de rastreo disponibles. -
GIT_TRACE_PACKET
-
Habilita mensajes de rastreo para todos los paquetes que vienen de o van hacia un programa dado. Esto puede ayudar con depuración de negociación de objetos u otros problemas de protocolo. El rastreo esta apagado en un paquete que comienza con "PACK" (pero ver
GIT_TRACE_PACKFILE
mas abajo). VerGIT_TRACE
para opciones de salida de rastreo disponibles. -
GIT_TRACE_PACKFILE
-
Habilita el rastreo de fichero de paquete enviados o recibidos por un programa dado. Contrario a otras salidas de rastreo, este rastreo es verboso: sin encabezados, y sin entrecomillar datos binarios. Seguramente querrás dirigirla a un fichero (ej.
GIT_TRACE_PACKFILE=/tmp/mi.paquete
) mas que desplegarla en la terminal o mezclarla con otra salida de rastreo.Note que esto esta actualmente implementado sólo para el lado del cliente de clonaciones y fetchs.
-
GIT_TRACE_PERFORMANCE
-
Habilita mensajes de rastreo relacionados con desempeño, ej. tiempo total de ejecución de cada comando Git. Ver
GIT_TRACE
para opciones de salida de rastreo disponibles. -
GIT_TRACE_REFS
-
Habilita mensajes de rastreo para operaciones en la base de datos de referencias. Ver
GIT_TRACE
para opciones de salida de rastreo disponibles. -
GIT_TRACE_SETUP
-
Habilita mensajes de rastreo imprimiendo el .git, el árbol de trabajo y el directorio de trabajo actual después que Git haya terminado su fase de configuración. Ver
GIT_TRACE
para opciones de salida de rastreo disponibles. -
GIT_TRACE_SHALLOW
-
Habilita mensajes de rastreo que pueden ayudar a depurar fetch / clonación de repositorios superficiales. Ver
GIT_TRACE
para opciones de salida de rastreo disponibles. -
GIT_TRACE_CURL
-
Habilita un volcado de rastreo completo de curl de todos los datos entrantes y salientes, incluyendo información descriptiva, del protocolo de transporte git. Es similar a hacer curl con
--trace-ascii
desde la línea de comandos. VerGIT_TRACE
para opciones de salida de rastreo disponibles. -
GIT_TRACE_CURL_NO_DATA
-
Cuando se habilita un rastreo curl (ver
GIT_TRACE_CURL
arriba), no vuelca los datos (esto es, sólo vuelca líneas de información y cabeceras). -
GIT_TRACE2
-
Habilita mensajes de rastreo mas detallados desde la librería "trace2". La salida de
GIT_TRACE2
es un formato simple basado en texto para legibilidad humana.Si a esta variable se le asigna "1", "2" o "true" (comparación sensible a mayúsculas), mensajes de rastreo se imprimirán en stderr.
Si a esta variable se le asigna un valor entero mayor a 2 y menor a 10 (estrictamente) entonces Git interpretará éste valor como un descriptor de fichero abierto e intentará escribir mensajes de rastro en éste descriptor de fichero.
Alternativamente, si a la variable se le asigna una ruta absoluta (que comience con el caracter /), Git la interpretará como una ruta de fichero e intentará añadir mensajes de rastreo en él. Si la ruta ya existe y es un directorio, los mensajes de rastreo serán escritos en ficheros (uno por proceso) en ese directorio, nombrados de acuerdo al último componente del SID y un contador opcional (para evitar colisiones de nombre de fichero).
Además, si a la variable se le asigna
af_unix:[<tipo-de-socket>:]<nombre-de-ruta-absoluta>
, Git intentará abrir la ruta como un Socket de Dominio de Unix. El tipo de socket puede serstream
odgram
.Desasignando la variable, o asignándole vacío, "0" o "false" (sensible a mayúsculas) deshabilita mensajes de rastreo.
Ver documentación de Trace2 para detalles completos.
-
GIT_TRACE2_EVENT
-
Este ajuste escribe un formato basado en JSON que es adecuado para interpretación por máquina. Ver
GIT_TRACE2
para opciones disponibles de salida de rastreo y documentación de Trace2 para detalles completos. -
GIT_TRACE2_PERF
-
Además de los mensajes basados en texto disponibles en
GIT_TRACE2
, este ajuste escribe un formato basado en columnas para entender regiones anidadas. VerGIT_TRACE
para opciones de salida de rastreo disponibles y documentación de Trace2 para detalles completos. -
GIT_TRACE_REDACT
-
Predeterminadamente, cuando se activa rastreo, Git redacta los valores de cookies, el encabezado "Authorization", el encabezado "Proxy-Authorization:" y fichero empaquetado de URIs. Asigne false a esta variable de ambiente booleana para prevenir esta redacción.
-
GIT_NO_REPLACE_OBJECTS
-
Asignando y exportando ésta variable de ambiente le dice a Git que ignore referencias de reemplazo y que no reemplace objetos Git.
-
GIT_LITERAL_PATHSPECS
-
Asignando verdadero a esta variable de ambiente booleana causará que Git trate a todas las especificaciones de ruta literalmente, mas que como patrones glob. Por ejemplo, corriendo
GIT_LITERAL_PATHSPECS=1 git log -- '*.c'
buscará confirmaciones que toquen la ruta*.c
, no cualquier ruta que coincida con el glob*.c
. Querrías esto si proporcionas rutas literales a Git (ej., rutas que te hayan resultado previamente degit ls-tree
,--raw
salida de diff, etc.). -
GIT_GLOB_PATHSPECS
-
Asignando verdadero a esta variable de ambiente booleana causará que Git trate todas las especificaciones de ruta como patrones glob (también conocido como magia "glob").
-
GIT_NOGLOB_PATHSPECS
-
Asignando verdadero a esta variable de ambiente booleana causará que Git trate a todas la especificaciones de ruta como literales (también conocido como magia "literal").
-
GIT_ICASE_PATHSPECS
-
Asignando verdadero a esta variable de ambiente booleana causará que Git trate a todas las especificaciones de ruta como insensibles a mayúsculas.
-
GIT_NO_LAZY_FETCH
-
Asignando verdadero a esta variable de ambiente booleana le dice a Git que no traiga perezosamente objetos faltantes del remoto promitente bajo demanda.
-
GIT_REFLOG_ACTION
-
Cuando se actualiza una referencia, se crean entradas de reflog para dar seguimiento a la razón por la cual la referencia fue actualizada (la cual es típicamente el nombre de un comando de alto nivel que actualizó la referencia), además de los valores anterior y nuevo de la referencia. Un comando porcelana en un script puede usar la función auxiliar set_reflog_action en
git-sh-setup
para asignar su nombre a esta variable cuando es invocada por el usuario final como el comando de máximo nivel, para ser registrado en el cuerpo del reflog. -
GIT_REF_PARANOIA
-
Si se asigna falso a esta variable de ambiente booleana, ignora referencias rotas o mal nombradas cuando se itera por la lista de referencias. Normalmente Git intentará incluir cualquiera de tales referencias, lo cual puede provocar que algunas operaciones fallen. Esto es usualmente preferible, ya que es mejor abortar operaciones potencialmente destructivas (ej. git-prune[1]) en vez de ignorar referencias rotas (y por lo tanto considerar que no vale guardar el historial al que apuntan). El valor predeterminado es
1
(ej. ser paranoico en la detección y abortar todas las operaciones). Normalmente no deberías asignarle0
, pero puede ser útil cuando se intenta salvar datos de un repositorio corrupto. -
GIT_COMMIT_GRAPH_PARANOIA
-
Cuando se carga un objeto confirmación desde el grafo de confirmaciones, Git hace una revisión de existencia en el objeto en la base de datos de objetos. Esto se hace para evitar problemas con grafos de confirmación viciados que contengan referencias a confirmaciones ya eliminadas, pero viene con una penalización de desempeño.
El predeterminado es "false", el cual deshabilita el comportamiento antes mencionado. Asignar "true" habilita la revisión de existencia de tal manera que nunca se regresaran confirmaciones viciadas del grafo de confirmaciones con el costo de desempeño.
-
GIT_ALLOW_PROTOCOL
-
Si se le asigna una lista de protocolos separada por dos puntos, se comporta como si a
protocolo.allow
se le asignanever
, y cada uno de los protocolos listadosprotocol.<nombre>.allow
tuviera asignadoalways
(anulando cualquier configuración existente). Ver la descripción deprotocol.allow
en git-config[1] para mas detalles. -
GIT_PROTOCOL_FROM_USER
-
Asigne falso a esta variable de ambiente booleana para prevenir el uso de protocolos por fetch/push/clone los cuales están configurados en el estado
user
. Esto es útil para restringir inicialización recursiva de submodulos desde un repositorio no confiable o para programas que alimenten URLs potencialmente no confiables a comandos git. Ver git-config[1] para mas detalles. -
GIT_PROTOCOL
-
Sólo para uso interno. Usado en el protocolo de estrechamiento de manos de conexión. Contiene una lista de claves separadas por dos puntos : con valores opcionales <clave>[=<valor>]. La presencia de claves y valores desconocidos debe ser ignorada.
Note que servidores pueden necesitar ser configurados para permitir que esta variable sobrepase algunos transportes. Será propagada automáticamente cuando se accesen repositorios locales (ej.
file://
o una ruta del sistema de ficheros), así como sobre el protocologit://
. Para git-over-http, debería funcionar automáticamente en la mayoría de las configuraciones, pero ver la discusión en git-http-backend[1]. Para git-over-ssh, el servidor ssh puede necesitar ser configurado para permitir a los clientes pasar esta variable (ej. usandoAcceptEnv GIT_PROTOCOL
con OpenSSH).Esta configuración es opcional. Si la variable no es propagada, entonces los clientes caerán de vuelta a protocolo "v0" original (pero pueden perder algunas mejoras de desempeño o características). Esta variable afecta actualmente únicamente a clonados y fetchs; aún no es usada para empujes (pero podría serlo en el futuro).
-
GIT_OPTIONAL_LOCKS
-
Si se le asigna falso a esta variable de ambiente, Git completará cualquier petición solicitada sin hacer cualquier sub-operación opcional que requiera un bloqueo. Por ejemplo, prevendrá que
git status
refresque el índice como efecto colateral. Esto es útil para procesos corriendo en segundo plano que no quieran provocar contención de bloqueos con otras operaciones en el repositorio. Es predeterminada a1
. -
GIT_REDIRECT_STDIN
-
GIT_REDIRECT_STDOUT
-
GIT_REDIRECT_STDERR
-
Sólo Windows: permite redirigir la entrada/salida/error estándar a las rutas especificadas por la variables de ambiente. Esto es particularmente útil en aplicaciones multi-hilo donde no es opción la forma canónica para pasar manejadores estándar mediante
CreateProcess()
ya que requeriría que los manejadores sean marcados como heredables (y consecuentemente todos los procesos derivados los heredarán, posiblemente bloqueando operaciones regulares de Git). El caso de uso primordial es usar pipes nombradas para comunicación (ej.\\.\pipe\mi-stdin-git-123
).Dos valores especiales son soportados:
off
simplemente cerrará el manejador estándar correspondiente, y siGIT_REDIRECT_STDERR
es2>&1
, error estándar será redireccionado al mismo manejador que la salida estándar. -
GIT_PRINT_SHA1_ELLIPSIS
(obsoleto) -
Si se le asigna
yes
, imprime una elipsis después de una valor (abreviado) SHA-1. Esto afecta indicaciones de HEADs separadas (git-checkout[1]) y la salida bruta de diff (git-diff[1]). Ya no se considera adecuado imprimir una elipsis en los casos mencionados y es probable que su soporte sea removido en el futuro previsible (junto con la variable). -
GIT_ADVICE
-
If set to
0
, then disable all advice messages. These messages are intended to provide hints to human users that may help them get out of problematic situations or take advantage of new features. Users can disable individual messages using theadvice.*
config keys. These messages may be disruptive to tools that execute Git processes, so this variable is available to disable the messages. (The--no-advice
global option is also available, but old Git versions may fail when this option is not understood. The environment variable will be ignored by Git versions that do not understand it.)
Discusión
Mas detalle de lo siguiente esta disponible en el capítulo de Conceptos de Git del Manual de usuario y gitcore-tutorial[7].
Un proyecto Git consiste normalmente de un directorio de trabajo con un subdirectorio ".git" en su nivel mas alto. El directorio .git contiene, entre otras cosas, una base de datos de objetos comprimida representando el historial completo del proyecto, un fichero "índice" el cual enlaza ese historial con el contenido actual del directorio de trabajo, y apuntadores nombrados hacia ese historial como etiquetas y cabezas de rama.
La base de datos de objetos contiene objetos de tres tipos principales: blobs, que contienen datos de fichero; árboles, los cuales apuntan a blobs y otros árboles para formar jerarquías de directorio; y confirmaciones, las que -cada una- referencían a un solo árbol y algún número de confirmaciones padre.
La confirmación, equivalente a lo que otros sistemas llaman "conjunto de cambios" o "versión", representa un paso en el historial del proyecto, y cada padre representa un paso inmediato anterior. Confirmaciones con mas de un padre representan fusiones de líneas independientes de desarrollo.
Todos los objetos se nombran con un hash SHA-1 de su contenido, normalmente escrito como una cadena de 40 dígitos hexadecimales. Dichos nombres son globalmente únicos. El historial completo hasta una confirmación puede ser garantizada firmando sólo esa confirmación. Para éste propósito, se proporciona un cuarto tipo de objeto, la etiqueta.
Recién creados, los objetos se almacenan en ficheros individuales, pero por eficiencia, posteriormente pueden ser comprimidos en conjunto en "paquetes de ficheros".
Apuntadores nombrados llamados referencias marcan puntos interesantes en el historial. Una referencia puede contener el nombre SHA-1 de un objeto o el nombre de otra referencia (ésta última se le llama una "referencia simbólica"). Referencias con nombres que comienzan con refs/head/
contienen el nombre SHA-1 de la confirmación más reciente (o "head") de una rama bajo desarrollo. Los nombres SHA-1 de etiquetas de interés se almacenan bajo refs/tags/
. Una referencia simbólica llamada HEAD
contiene el nombre de la rama actualmente en revisión.
El fichero índice se inicializa con una lista de todas las rutas y, para cada ruta, un objeto blob y un conjunto de atributos. El objeto blob representa el contenido del fichero como en la cabeza de la rama actual. Los atributos (última hora de modificación, tamaño, etc.) se toman del fichero correspondiente en el árbol de trabajo. Cambios subsecuentes al árbol de trabajo se pueden encontrar al comparar esos atributos. El índice puede ser actualizado con contenido nuevo, y nuevas confirmaciones pueden ser creadas a partir del contenido almacenado en el índice.
El índice también es capaz de almacenar entradas múltiples (llamadas "etapas") para cada nombre de ruta dado. Esas etapas se usan para mantener las varias versiones sin fusionar de un fichero cuando una fusión está en progreso.
SEGURIDAD
Algunas opciones de configuración y ficheros gancho pueden causar que Git corra arbitrariamente comandos de terminal. Ya que configuraciones y ganchos no se copian usando git clone
, es generalmente seguro clonar repositorios remotos con contenido no-confiable, inspeccionarlos con git log
, y así sucesivamente.
Sin embrago, no es seguro correr comandos Git en un directorio .git
(o el árbol de trabajo que lo rodea) cuando ese directorio .git
mismo viene de un origen no confiable. Los comandos en su configuración y ganchos se ejecutan como de costumbre.
Predeterminadamente, Git se negará a correr cuando el repositorio pertenezca a otro usuario al que corra el comando. Ver la entrada para safe.directory
en git-config[1]. Mientras esto puede ayudar a protegerte en un ambiente multiusuario, nota que también puedes obtener repositorios no confiables que te pertenezcan (por ejemplo, si descomprimes un fichero zip o tarball de una fuente no confiable). En tales casos, necesitarás primero "sanitizar" el repositorio no confiable.
Si tienes un directorio .git
no confiable, deberías primero clonarlo con git clone --no-local
para obtener una copia limpia. Git restringe el conjunto de opciones y ganchos que correrán por upload-pack
, el cual maneja el lado del servidor de un clone o fetch, pero ten cuidado que la superficie de ataque contra upload-pack
es muy grande, así que esto conlleva algún riesgo. Lo mas seguro es servir el repositorio como un usuario sin privilegios (ya sea por git-daemon[1], ssh, o usando otras herramientas para cambiar identificadores de usuario). Ver la discusión en la sección SEGURIDAD
de git-upload-pack[1].
MAS DOCUMENTACIÓN
Ver las referencias en la sección "descripción" para comenzar a usar Git. Lo siguiente es probablemente mas detalle del necesario para un usuario primerizo.
El capítulo de conceptos de Git del manual de usuario y gitcore-tutorial[7] ambos dan introducciones a la arquitectura subyacente de Git.
Ver gitworkflows[7] para un vistazo a los flujos de trabajo recomendados.
Ver también los documentos Cómo hacer para algunos ejemplos útiles.
Lo interno se documenta en la Documentación de la API de Git.
Usuarios migrando de CVS querrían leer gitcvs-migration[7].
Autores
Git lo comenzó Linus Torvalds, y actualmente es mantenido por Junio C Hamano. Numerosas contribuciones han venido de la lista de correos de Git <git@vger.kernel.org>. http://openhub.net/p/git/contributors/summary tiene una lista mas completa de contribuyentes.
Si tienes un clon mismo de git.git, la salida de git-shortlog[1] y git-blame[1] puede mostrarte los autores de partes específicas del proyecto.
Reportando Errores
Reporta errores en la lista de correo de Git <git@vger.kernel.org> donde se hace principalmente el desarrollo y mantenimiento. No tienes que estar suscrito en la lista para enviar un mensaje ahí. Ver el archivo de la lista en https://lore.kernel.org/git para reportes de error anteriores y otras discusiones.
Asuntos relevantes para la seguridad deben ser revelados en privado a la lista de correos de seguridad de Git <git-security@googlegroups.com>.
GIT
Parte de la suite de git[1]