Большие толченые git коммиты толкаются? - PullRequest
1 голос
/ 23 апреля 2020

Я добавил несколько больших файлов в репозиторий, а затем pu sh не удалось (коммит 1). Я решил, что могу жить без больших файлов на пульте, поэтому я отменил коммит в моем локальном репо, это проявляется как коммит 2, который отменяет коммит 1. Теперь любой pu sh все еще не работает.

  1. ПУ sh пытается загрузить файл, потому что оба коммита есть в истории?

  2. Будет ли git reset --hard коммиту непосредственно перед решением коммита 1 проблема, например, будет ли pu sh игнорировать коммит 1 и 2?

1 Ответ

2 голосов
/ 23 апреля 2020
  1. Да. 2. Да.

Причина, по которой это происходит, заключается в том, что если какой-то другой пользователь извлечет коммит 1, он будет иметь большой файл в своей локальной файловой системе, поэтому он должен существовать в истории.

Сброс до коммита до его решения или, если вы уже сделали дальнейшие коммиты и не хотите потом их забирать, вы можете просто интерактивно перебазировать, и squa sh коммит 1 и 2 вместе. В вашем случае сброс, вероятно, является самым простым, но ребаз может быть более чистым, если бы не был зафиксирован возвратный коммит, скажем, это был коммит 5. Во время интерактивного ребазирования вы можете изменить порядок коммита 5, чтобы он произошел сразу после коммита 1, и squa sh это в коммит 1 (или 1 и 5 в предыдущий коммит). Как обычно в Git, есть много способов снять кожу с этой кошки.

...