O primeiro comando para iniciar o repositório local:
git init folder-nameO git init sem o nome da pasta faz com que seja inicializado na pasta que está.
Configurar sua conta
git config --global user.name "Mazoni"
git config --global user.email "mazoni@gmail.com"Adicionar os arquivos para o repositório local
git add file-namePara adicionar todos arquivos de uma vez:
git add .Salva as alterações feitas no repositório local
git commit -m "Mensagem do commit"Você pode também usar o comando git commit que irá abrir seu editor de texto padrão para escrever a mensagem do commit. Crie uma mensagem relacionado às alterações feitas. Para colocar o vim como o editor padrão ao fazer “git commit”:
git config --global core.editor vimA situação do repositório
git statusVer os últimos commits do repositório
git logCriar um repositório remoto
git remote add <remote> <url>
git remote add origin git@github.com:username/repository-name (SSH)
git remote add origin https://github.com/username/repository-name.git (HTTPS)Quando clonado com ssh não é necessário logar na conta do GitHub, mas clonando como https é preciso.
Adicionando SSH Key
Para gerar uma nova chave ssh é preciso digitar o comando abaixo com seu email do github.
ssh-keygen -t rsa -b 4096 -C "mazoni@gmail.com"Pressione enter 3x, ele irá criar uma pasta .ssh/id_rsa na pasta do seu usuário, e não será preciso utilizar senha para clonar repositórios utilizando o ssh(caso você queira colocar senha, adicione uma senha quando o prompt perguntar). Para iniciar o ssh-agent em plano de fundo:
eval "$(ssh-agent -s)"
> Agent pid 79294
ssh-add ~/.ssh/id_rsaVamos agora adicionar a chave ssh a sua conta. Entre no site do GitHub, vá em configurações, clique no SSH and GPG keys depois em New SSH key.
cat ~/.ssh/id_rsa.pubAgora coloque o nome dessa chave SSH, então copie o código que está no arquivo id_rsa.pub(retorno do comando acima) e cole no site onde está escrito key.
Enviar as alterações(commits) de uma branch para o repositório remoto
Primeira vez:
git push -u origin masterSe o envio for rejeitado o repositório local não foi sincronizado:
git push <remote> <branch>
git pushConfigurar o push padrão:
git config --global push.default simpleCriar uma branch(ramificação)
git branch <branch-name>Para criar e já mudar para a nova branch:
git checkout -b <branch_name>Caso essa branch ja exista, apenas para alterar de branch:
git checkout <branch_name>Navegar no histórico
git checkout <commit-number>É necessário o número do commit, não precisa ser todos os números apenas os primeiros números para diferencias dos outros. Ex: commit cfac2a8b98cef302b697320760ace3b6d88ba1ef, quando for usar o comando:
git checkout cfac2Se apenas esse commit começar com cfac2, você irá acessar esse commit. Usando o comando ls, os arquivos desse commit aparecerão.
Mostrar as diferenças entre repositório local e o remoto
git diffQuando for alterado algum arquivo e os repositórios local e remoto não estão iguais, aparece exatamente os arquivos e as linhas com as diferenças que precisa adicionar e commitar.
Desfazendo commit
Deleta um commit feito:
git revert <commit-number>Resetar um repositório para um determinado commit:
git reset <commit-number>
git reset HEAD~n
git reset --hardn: é a quantidade de commits para resetar.--hard: volta ao estado do commit anterior sem deixar as alterações feitas posteriormente.