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 01/10/25
- 2.47.1 → 2.47.2 no changes
- 2.47.0 10/06/24
- 2.45.1 → 2.46.3 no changes
- 2.45.0 04/29/24
- 2.44.1 → 2.44.3 no changes
- 2.44.0 02/23/24
- 2.43.1 → 2.43.6 no changes
- 2.43.0 11/20/23
- 2.42.1 → 2.42.4 no changes
- 2.42.0 08/21/23
- 2.38.1 → 2.41.3 no changes
- 2.38.0 10/02/22
- 2.35.1 → 2.37.7 no changes
- 2.35.0 01/24/22
- 2.30.1 → 2.34.8 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.21.1 → 2.26.3 no changes
- 2.21.0 02/24/19
- 2.13.7 → 2.20.5 no changes
- 2.12.5 09/22/17
- 2.10.5 → 2.11.4 no changes
- 2.9.5 07/30/17
- 2.5.6 → 2.8.6 no changes
- 2.4.12 05/05/17
- 2.3.10 no changes
- 2.2.3 09/04/15
- 2.1.4 no changes
- 2.0.5 12/17/14
SINOPSIS
git init [-q | --quiet] [--bare] [--template=<template-directory>] [--separate-git-dir <git-dir>] [--object-format=<format>] [--ref-format=<format>] [-b <branch-name> | --initial-branch=<branch-name>] [--shared[=<permissions>]] [<directory>]
DESCRIPCIÓN
Este comando crea un repositorio Git vacío. Básicamente un directorio .git
con subdirectorios para objects
, reas/heads
, reos/tags
, y ficheros de plantillas. Se creará una rama inicial sin confirmaciones (ver la opción --initial-branch
abajo por su nombre).
If the GIT_DIR
environment variable is set then it specifies a path to use instead of ./.git
for the base of the repository.
If the object storage directory is specified via the GIT_OBJECT_DIRECTORY
environment variable then the sha1 directories are created underneath; otherwise, the default $GIT_DIR/objects
directory is used.
Ejecutar git init
en un repositorio existente es seguro. No sobre-escribirá cosas que ya existan ahí. La razón primaria para volver a ejecutar git init
es para recoger plantillas agregadas recientemente (o para mover el repositorio a otro lugar si se proporciona --separate-git-dir
).
OPCIONES
-
-q
-
--quiet
-
Mostrar sólo los mensajes de error y advertencia; el resto de mensajes se suprimirán.
-
--bare
-
Crea un repositorio básico. Si la variable de ambiente
GIT_DIR
no está configurada, se configura al directorio de trabajo actual. -
--object-format=<format>
-
Especifica el <formato> de objeto (algoritmo hash )dado para el repositorio. Los valores válidos son
sha1
y -si esta habilitado-sha256
.sha1
es el predeterminado.Nota: En el presente, no hay interoperabilidad entre repositorios SHA-256 y SHA-1.
Históricamente, hemos advertido que repositorios SHA-256 puedan necesitar después cambios incompatibles hacia atrás cuando introduzcamos tales características de interoperabilidad. Hoy, sólo esperamos cambios compatibles. Además, si tales cambios prueban ser necesarios, se puede esperar que repositorios SHA-256 creados con el Git de hoy sean usables por versiones futuras de Git sin pérdida de datos.
Warning
|
Missing See original version for this content. |
-
--template=<template-directory>
-
Especifica el directorio de dónde usar plantillas. (Ver la sección "DIRECTORIO DE PLANTILLAS" mas adelante.)
-
--separate-git-dir=<git-dir>
-
En lugar de inicializar el repositorio como un directorio ya sea de
$GIT_DIR
o./.git
, crea un fichero de texto conteniendo la ruta al repositorio actual. Este fichero actúa como una liga simbólica de Git agnóstica de sistema de ficheros hacia el repositorio.Si es una re-inicialización, el repositorio se moverá a la ruta especificada.
-
-b <branch-name>
-
--initial-branch=<branch-name>
-
Usar el <nombre-de-rama> especificado para la rama inicial en el repositorio recientemente creado. Si no se especifica, recae en el nombre predeterminado (actualmente
master
, pero está sujeto a cambio en el futuro; el nombre puede ser personalizado con la variable de configuracióninit.defaultBranch
). -
Especifica que el repositorio Git será compartido entre varios usuarios. Esto permite a los usuarios pertenecientes al mismo grupo hacer push en ese repositorio. Cuando se especifica, la variable de configuración
core.sharedRepository
se asigna de tal manera que esos ficheros y directorios bajo$GIT_DIR
son creados con los permisos solicitados. Cuando no se especifica, Git usará los permisos reportados porumask
(2).La opción puede tomar los siguientes valores, predeterminando a
group
si no se da algún valor:-
umask
-
false
-
Use los permisos obtenidos con
umask
(2). El predeterminado, cuando no se indica--shared
. -
group
-
true
-
Hace al repositorio escribible para el grupo, (y
g+sx
, ya que el grupo git podría no ser el grupo primario de todos los usuarios). Esto se usa para relajar los permisos de un valor -por el contrario- seguro deumask
(2). Note que umask aún aplica a los otros bits de permisos (ej. si umask es0022
, usandogroup
no quitará privilegios de lectura de otros usuarios (no del grupo) ). Ver0xxx
para cómo especificar exactamente los permisos del repositorio. -
all
-
world
-
everybody
-
Igual que
group
, pero permite que cualquier usuario lea el repositorio. - <permisos>
-
<permisos>
es un número octal de tres dígitos prefijado con0
y cada fichero tendrá el modo<permisos>
.<permisos>
sobre-escribirá el valorumask
(2) del usuario (y no solo permisos mas holgados como lo hacengroup
yall
).0640
creará un repositorio legible por el grupo, pero no escribible o accesible para otros.0660
creará un repositorio que es legible y escribible por el usuario actual y grupo, pero inaccesible para otros (directorios y ficheros ejecutables obtienen su bitx
del bitr
para sus clases de usuarios correspondientes).
-
Predeterminadamente, la bandera de configuración receive.denyNonFastForwards
está habilitada en repositorios compartidos, de tal manera que no se pueda forzar un push no-fast-forward en él.
Si se proporciona un <directorio>, el comando se ejecuta dentro de éste. Si éste directorio no existe, se creará.
DIRECTORIO DE PLANTILLAS
Ficheros y directorios en el directorio de plantillas cuyo nombre no comiencen con un punto serán copiados en el directorio $GIT_DIR
después de ser creado.
El directorio de plantilla será uno de los siguientes (en este orden):
-
el argumento proporcionado con la opción
--template
; -
el contenido de la variable de entorno
$GIT_TEMPLATE_DIR
; -
la variable de configuración
init.templateDir
; o -
el directorio de plantilla por defecto:
/usr/share/git-core/templates
.
El directorio de plantillas predeterminado incluye una estructura de directorio, algunos "patrones de exclusión" sugeridos (ver gitignore[5]) y ficheros de hook de ejemplo.
Todos los ganchos de ejemplo están deshabilitados predeterminadamente. Para habilitar uno de los ganchos de ejemplo renómbralo quitando el sufijo .sample
.
Ver githooks[5] para mas información general de la ejecución de hooks.
CONFIGURACIÓN
Todo debajo de ésta línea en ésta sección es incluido selectivamente de la documentación de git-config[1]. El contenido es el mismo al que se encuentra ahí:
Warning
|
Missing See original version for this content. |
GIT
Parte de la suite de git[1]