Introdução ao "Git"
Git é um sistema de controle de
versão distribuído, gratuito e de código aberto, projetado para
lidar com tudo, desde projetos pequenos a muito grandes, com
velocidade e eficiência. Cada clone do Git é um repositório completo com histórico
completo e recursos completos de rastreamento de revisão, não
dependente de acesso à rede de comunicação ou de um servidor
central. Ramificar e mesclar são rápidos e fáceis de fazer.
Git é usado para controle de
versão de arquivos, assim como ferramentas como Mercurial-6.5.1,
Bazaar, Subversion-1.14.2,
CVS,
Perforce e Team Foundation Server.
Esse pacote é conhecido por construir e funcionar corretamente
usando uma plataforma LFS 12.0.
Informação do Pacote
-
Transferência (HTTP):
https://www.kernel.org/pub/software/scm/git/git-2.41.0.tar.xz
-
Transferência (FTP):
-
Soma de verificação MD5 da transferência:
c1f58a12b891ad73927b8e4a3aa29c7b
-
Tamanho da transferência: 11 MB
-
Espaço em disco estimado exigido: 252 MB (com documentação
baixada)
-
Tempo de construção estimado: 0,3 UPC (com paralelismo=4;
adicionar até 1,6 UPC (dependente da velocidade do disco)
para testes, ambos com paralelismo=4)
Transferências Adicionais
Dependências do "Git"
Recomendadas
cURL-8.2.1 (necessário para usar Git por meio de "HTTP", "HTTPS", "FTP" or
"FTPS")
Opcionais
Apache-2.4.57 (para alguns testes), GnuPG-2.4.3 (tempo de execução, possivelmente
seja usado para assinar commits ou tags do Git ou para verificar as assinaturas deles),
OpenSSH-9.4p1 (tempo de execução, necessário
para usar Git sobre ssh),
pcre2-10.42 (ou o obsoleto PCRE-8.45), em ambos os casos
configurados com --enable-jit
,
Subversion-1.14.2 com ligações Perl (tempo
de execução, para git
svn), Tk-8.6.13 (gitk, um visualizador simples de
repositórios Git, usa Tk em tempo de execução), Valgrind-3.21.0,
Authen::SASL e
MIME::Base64 (ambos
tempo de execução, para git
send-email) e IO-Socket-SSL-2.083 (tempo de execução,
para git send-email
conectar-se a um servidor SMTP com encriptação SSL)
Opcional (para criar as páginas de manual, documentos "HTML" e
outros documentos)
xmlto-0.0.28 e asciidoc-10.2.0 , e também dblatex (para a versão
"PDF" do manual de usuário(a)) e docbook2x para criar
páginas "info"
Instalação do "Git"
Instale Git executando os
seguintes comandos:
./configure --prefix=/usr \
--with-gitconfig=/etc/gitconfig \
--with-python=python3 &&
make
Você pode construir as páginas de manual e(ou) documentos "HTML" ou
usar os baixados. Se você decidir construí-los(as), [então] use as
próximas duas instruções.
Se você instalou asciidoc-10.2.0, [então] você pode criar a
versão "HTML" das páginas de manual e outros documentos:
make html
Se você instalou asciidoc-10.2.0 e xmlto-0.0.28, [então]
você pode criar as páginas de manual:
make man
A suíte de teste pode ser executada em modo paralelo. Para executar
a suíte de teste, emita: make -k
test. Se Apache-2.4.57
estiver instalado, três testes em t5559-http-fetch-smart-http2.sh
são conhecidos
por falhar devido ao cURL-8.1.x.
Agora, como o(a) usuário(a) root
:
make perllibdir=/usr/lib/perl5/5.38/site_perl install
Se você criou as páginas de manual e(ou) documentos "HTML"
Instale as páginas de manual como o(a) usuário(a) root
:
make install-man
Instale os documentos "HTML" como o(a) usuário(a) root
:
make htmldir=/usr/share/doc/git-2.41.0 install-html
Se você baixou as páginas de manual e(ou) documentos "HTML"
Se você baixou as páginas de manual, [então] descompacte-as como
o(a) usuário(a) root
:
tar -xf ../git-manpages-2.41.0.tar.xz \
-C /usr/share/man --no-same-owner --no-overwrite-dir
Se você baixou os documentos "HTML", [então] descompacte-os como
o(a) usuário(a) root
:
mkdir -vp /usr/share/doc/git-2.41.0 &&
tar -xf ../git-htmldocs-2.41.0.tar.xz \
-C /usr/share/doc/git-2.41.0 --no-same-owner --no-overwrite-dir &&
find /usr/share/doc/git-2.41.0 -type d -exec chmod 755 {} \; &&
find /usr/share/doc/git-2.41.0 -type f -exec chmod 644 {} \;
Reorganize o texto e o "HTML" no "html-docs" (ambos os métodos)
Para ambos os métodos, o "html-docs" inclue muitos arquivos planos
de texto. Reorganize os arquivos como o(a) usuário(a) root
:
mkdir -vp /usr/share/doc/git-2.41.0/man-pages/{html,text} &&
mv /usr/share/doc/git-2.41.0/{git*.txt,man-pages/text} &&
mv /usr/share/doc/git-2.41.0/{git*.,index.,man-pages/}html &&
mkdir -vp /usr/share/doc/git-2.41.0/technical/{html,text} &&
mv /usr/share/doc/git-2.41.0/technical/{*.txt,text} &&
mv /usr/share/doc/git-2.41.0/technical/{*.,}html &&
mkdir -vp /usr/share/doc/git-2.41.0/howto/{html,text} &&
mv /usr/share/doc/git-2.41.0/howto/{*.txt,text} &&
mv /usr/share/doc/git-2.41.0/howto/{*.,}html &&
sed -i '/^<a href=/s|howto/|&html/|' /usr/share/doc/git-2.41.0/howto-index.html &&
sed -i '/^\* link:/s|howto/|&html/|' /usr/share/doc/git-2.41.0/howto-index.txt
Explicações do Comando
--with-gitconfig=/etc/gitconfig
: Isso
configura /etc/gitconfig
como o
arquivo que armazena as configurações padrão do Git abrangente a todo o sistema.
--with-python=python3
: Use
esta chave para usar Python 3, em
vez do Python 2 com "EOL".
"Python" é usado para a interface git
p4 para repositórios "Perforce" e também usado em
alguns testes.
--with-libpcre2
: Use essa chave se
PCRE2 estiver instalado e tiver
sido construído com o "JIT" não padrão habilitado.
--with-libpcre1
: Como uma alternativa
ao "PCRE2", use essa chave se o obsoleto PCRE estiver instalado e tiver sido construído
com o "JIT" não padrão habilitado.
tar -xf ../git-manpages-2.41.0.tar.gz
-C /usr/share/man --no-same-owner: Isso descompacta
git-manpages-2.41.0.tar.gz
. A opção
-C
faz com que o "tar" mude o diretório
para /usr/share/man
antes de começar
a descomprimir os documentos. A opção --no-same-owner
impede que o "tar" preserve os
detalhes de usuário(a) e de grupo dos arquivos. Isso é útil porque
esse(a) usuário(a) ou grupo possivelmente não exista em seu
sistema; isso poderia (potencialmente) ser um risco de segurança.
mv /usr/share/doc/git-2.41.0
...: Esses comandos movem alguns dos arquivos para
subpastas para tornar mais fácil a ordenação ao longo dos
documentos e achar o que você está procurando.
find ... chmod ...:
Esses comandos corrigem as permissões no arquivo "tar" da
documentação enviada.