O commit do Git não terminou, mas não pode continuar nessa máquina

11

Às vezes, encontro o problema de ter código não confirmado em uma estação de trabalho que não está pronta para uma confirmação, mas precisa ser concluída em uma estação de trabalho ou laptop diferente.

Alguém tem uma solução para esse problema, como um "commit suave" ou alguma outra maneira de transferir as alterações para outra máquina para trabalhar com elas em outro lugar?

Eu preferiria não ser forçado a confirmar e enviar alterações que não foram implementadas adequadamente.

csteifel
fonte
2
é difícil ler este post (parede de texto). Você se importaria de editá -lo em uma forma melhor?
Gnat #
.. parece que você está atrás git stash...?
Simon Whitehead
@SimonWhitehead sim, mas posso mover um stash git para outra máquina facilmente?
csteifel
Todos os commits do Git são "soft commits".
user253751
Não é realmente uma duplicata, porque aborda o problema de outra maneira, mas relacionado: Devo usar o git stash para salvar as alterações em andamento do meu projeto e enviá-lo ao github para acessar outros computadores?
try-catch-finalmente

Respostas:

12

O seguinte pressupõe que seu repositório local é um clone de um repositório em outro servidor, por exemplo, github; e que você tem direitos para fazer alterações no servidor upstream. No meu exemplo, chamei esse repositório upstream de "origem". Corra git remote showpara listar outros repositórios, isso pode lhe dar uma dica sobre como ele é chamado.

Eu sugeriria fazer uma filial, então você pode conferir a filial em outra máquina. De fato, se você criar uma ramificação assim que começar a trabalhar, poderá "confirmar" sua ramificação, rastrear e fazer backup do seu trabalho, sem ter que ter um conjunto de códigos estável. Quando estiver satisfeito com o seu trabalho, você poderá mesclá-lo novamente ao seu ramo "mestre".

  • Para ramificar seu repositório: git checkout -b MyNewBranch
  • Para enviar alterações confirmadas de sua nova ramificação: git push origin MyNewBranch
  • Para verificar uma ramificação em outra máquina: git checkout MyNewBranch
  • Para mudar para outra ramificação (por exemplo, "mestre"): git checkout master
  • Quando estiver no mestre, para mesclar MyNewBranch novamente: git merge MyNewBranch
  • Para listar ramificações: git branch
AMADANON Inc.
fonte
3
Sim, sempre trabalhando em seu próprio ramo particular resolve essencialmente esse problema. Você pode cometer quantas vezes quiser, sem afetar ninguém. Melhor ainda é criar uma nova ramificação sempre que você começar a trabalhar em um novo recurso ou a corrigir um novo defeito. Isso facilita muito a alternância entre as bases de código.
Gort o robô
Além disso, e a razão pela qual faço isso: se você cometer um erro no meio do caminho, poderá ir para confirmações anteriores no ramo atual. Ou pule para trás, pegue um pedaço, pule para frente e aplique.
AMADANON Inc.
1
Esse método também não incluiria as confirmações incompletas no ramo mestre mesclado?
eimrek
Sim, e (na minha opinião) isso provavelmente não é uma coisa ruim. Se você não quiser isso, faça o acima e, em vez de confirmar seu código, crie um diff (que inclui todas as alterações de arquivo, mas não confirmações), aplique-o a uma nova cópia da ramificação e pressione-o.
AMADANON Inc.
2
sobre " Para mudar para outro ramo dogit branch -d master ", estou confuso, isso não pede ao git para excluir o ramo principal? (essa é a impressão que eu tenho ao ler o manual do ramo git)
Tasos Papastylianou
2

Você pode usar git diffpara criar um patch e aplicá-lo em outra máquina. Ou você pode criar uma confirmação temporária e puxá-la de outra máquina. Você pode até criar uma ramificação temporária em alguma outra máquina, enviar sua confirmação temporária para lá e excluir a ramificação.

Meu método favorito é o segundo: criar uma confirmação temporária, depois ir para outra máquina e fazer algo assim:

$ git fetch ssh://first_machine/path/to/repo whatever_branch_i_was_working_on
$ git reset --hard FETCH_HEAD
$ git reset HEAD^
aragaer
fonte
Por que tão complicado e não apenas usando git format-patch?
try-catch-finalmente
Não é realmente diferente de git diff. Tem algo que estou perdendo?
Aragaer #
1
git format-patch deadbee..badcab1e- Ele cria .patcharquivos para cada confirmação separadamente, com um bom nome e uma mensagem de confirmação preservada.
try-catch-finalmente
Ele também cria um patch para alterações que ainda não foram confirmadas? Separa o índice atual e as coisas que ainda não foram preparadas? Parece que não.
Aragaer #
Não, não para as alterações não confirmadas / sem etapas. Mas como uma confirmação não prejudica ninguém, contanto que você não faça push, não há problema em confirmar (com uma mensagem clara que diz "WIP" - trabalho em andamento).
try-catch-finalmente
2

Eu comprometo . O empurrão para o ramo pessoal , confira do outro lado e altere. E exclua o ramo pessoal quando terminar.

É claro que você pode enviar diretamente entre os repositórios, pode usar o pacote ou format-patch/ am, mas um ramo pessoal é de longe a solução mais fácil. E reescrever o histórico não é grande coisa, desde que não seja enviado a nenhum ramo compartilhado. Em muitos projetos, as pessoas devem retroceder as ramificações dos recursos para mantê-las mais fáceis de entender para revisão.

Jan Hudec
fonte
0

A abordagem fácil é a que você descreve: copie o .gitdiretório oculto e os arquivos do projeto para outra máquina onde você pode confirmar e finalizar, ou simplesmente continuar trabalhando.

O .gitdiretório é onde seu histórico do git é mantido, portanto, preservá-lo junto com os arquivos reais mantém todo o histórico do projeto intacto.

Se você estiver usando a máquina original de forma permanente, provavelmente recomendo essa abordagem.

joshin4colours
fonte
0

Como outros responderam, com o Git, você não deve se importar com o código não finalizado em seus ramos pessoais. No entanto, se por algum motivo, você realmente não quer que seu trabalho inacabado toque o repositório principal, você pode utilizar a natureza distribuída do Git!

Existe uma ferramenta simples chamada git bundleque pode ajudá-lo a passar facilmente as mudanças sem um repositório central. Primeiro, clone o repositório:

git clone https://github.com/octocat/Spoon-Knife.git working_copy_1
cd working_copy_1

faça algumas alterações e as comprometa em uma ramificação temporária:

git checkout -b tmp_branch
git commit -a -m "temporary changes"

Agora, agrupe as alterações:

git bundle create ../tmp.bundle tmp_branch

Agora você tem um arquivo de pacote configurável que pode ser enviado para sua nova máquina. Como você usa isso aí? Vamos criar uma nova cópia de trabalho:

cd ..
git clone https://github.com/octocat/Spoon-Knife.git working_copy_2
cd working_copy_2

precisamos tratar nosso pacote como outro controle remoto, para que possamos buscar as alterações nele

git remote add tmp ../tmp.bundle
git fetch tmp

Como o objetivo principal era transferir as alterações sem deixar rastro, queremos compactá-las na cópia de trabalho para perder a confirmação temporária:

git merge tmp/tmp_branch --squash

e tudo o que resta é remover o controle remoto temporário:

git remote remove tmp

VIOLA! As alterações foram transferidas para a nova cópia de trabalho sem deixar rastro de ramificação nem confirmação!

Mas realmente - esse processo é bastante longo e complicado. Este é o Git, não o SVN - realmente não deve haver nenhuma razão para não levar seu ramo pessoal ao repositório central.

Idan Arye
fonte