Arhn - архитектура программирования

Отменить поэтапные изменения, сохранить неустановленные изменения

У меня есть несколько поэтапных и неустановленных изменений в git, а также несколько неотслеживаемых файлов. Я хотел бы сохранить неустановленные изменения и неотслеживаемые файлы и отказаться от поэтапных изменений.

Какой самый простой способ сделать это в командной строке?

22.06.2016

Ответы:


1

У меня есть несколько поэтапных и неустановленных изменений в git, а также несколько неотслеживаемых файлов. Я хотел бы сохранить незафиксированные изменения и неотслеживаемые файлы и отказаться от зафиксированных изменений.

Как вы пояснили в своем комментарии, вы имеете в виду «... и отмените поэтапные изменения» (а не зафиксированные изменения). Обычно вы используете git reset для отмены git add. Но в вашем случае вы хотите сохранить свои неустановленные изменения, поэтому:

git commit     # move staged to a commit, does not touch unstaged changes/unadded files

git checkout HEAD^    # checkout the previously committed version while keeping unstaged changes/unadded files   

git branch yourbranchname --force    # to grab the branch and move it back as well
22.06.2016
  • На самом деле, вопрос имеет смысл в моем случае использования. Поэтому я не хочу удалять этапы, но действительно отключаю этапы и отбрасываю поэтапные изменения, не теряя (в настоящее время) неустановленных изменений... 22.06.2016
  • Да, но вы написали отменить внесенные изменения. Вы имеете в виду поэтапные изменения. Важное отличие здесь, вы можете обновить свой вопрос. 22.06.2016
  • О, тут вы правы, конечно, это была опечатка. Спасибо за подсказку, я обновил вопрос! 22.06.2016

  • 2
    git reset HEAD^
    

    Сбросьте HEAD до его родителя, и теперь изменения фиксации отбрасываются в индексе, но сохраняются в рабочем дереве.

    git checkout -- paths_of_files_whose_changes_are_to_be_discarded_in_the_work_tree
    

    Отменить изменения в рабочем дереве.

    22.06.2016
  • Извините, в вопросе была ошибка, поэтому я обновил его (я ошибочно написал «совершил», а не «поставил»). Так что я думаю, что ваш ответ больше не подходит ... 22.06.2016
  • @JanRüegg Затем git reset -- path_of_file может отменить изменения файла в индексе. Еще git checkout -- path_of_file может отменить изменения в рабочем дереве. 22.06.2016
  • Хорошая идея ... однако в индексе довольно много файлов, поэтому я выбрал другое решение, чтобы сэкономить время на наборе текста;) 22.06.2016
  • @JanRüegg все в порядке, если это может помочь. 22.06.2016

  • 3

    Чтобы отменить неустановленные изменения и сохранить поэтапные изменения, добавьте это в свой ~/.gitconfig:

    [alias]
        revert-unstaged = "!sh -c '{ git commit -m=tmp && git reset --hard HEAD && git reset --soft HEAD^ || git reset --hard HEAD; } > /dev/null 2>&1; git status'"
    

    Затем вы можете сделать git revert-unstaged, что делает следующее:

    • Создайте локальную фиксацию, если есть поэтапные изменения

    • Удалите все неустановленные изменения с помощью git reset --hard HEAD

    • Если изменения были поэтапными, отмените локальную фиксацию, чтобы восстановить их.

    • Запустите git status для обзора нового состояния

    07.11.2018
    Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..