Инициализация каталога как Git-репозитория
git init
Команда показывающая какие файлы в каком состоянии находятся
git status
Показать историю коммитов в текущей ветке / всех ветках
git log
/ git log --all
Отобразить активные ветки / все активные и доступные ветки
git branch / git branch -a
Переключиться на другую ветку
git checkout <branch-name>
Создать новую ветку и переключиться на неё
git checkout -b <branch-name>
Проиндексировать все файлы в папке (подготовка в след.коммит)
git add .
Создать коммит
git commit
Создать коммит с указанием имени
git commit -m "new commit"
Автоматическая индексация всех уже отслеживаемых файлов
git commit -a
git commit -am "new commit" (автоиндекс+имя)
Редактор названия коммитов по-умолчанию
git config --global core.editor "vim"
Изменить сообщение последнего коммита
git commit --amend
Клонировать удалённый репозиторий (папка с новым репозиторием создаётся сама)
git clone <link.repo>
Клонировать удалённый репозиторий по tag/branch
git clone <link.repo> --branch '<tag-name>'
Влить изменения удалённой ветки в вашу текущую ветку (аналог merge)
git pull <link.repo> <branch-name>
Получить изменения удалённой ветки (без merge, 1 fetch = 1 ветка)
git fetch <link.repo> <branch-name>
1.Удалённая ветка помещается во временное хранилище - так называемую 'FETCH_HEAD-ветку'
2.После переключения на 'FETCH_HEAD-ветку' мы узнаем её 'hash'
3.Изучив полученные изменения в 'FETCH_HEAD-ветке' мы можем замержить её с нужной нам веткой
2-мя способами:
1) Можно создать новую локальную ветку из 'FETCH_HEAD-ветки',изучить изменения и замержиться:
git branch <branch-name> <hash>
git merge <branch-name>
2) Можно замержить новую ветку с локальной используя только <hash> 'FETCH_HEAD-ветки':
git merge <hash>
Отправка всех веток локального репозитория на удалённый репозиторий
git push <link.repo> --all
git push --force <branch-name>
Забыть все последующие коммиты от указанного по <hash>
git reset --hard <hash>
Изменить дату текущего коммита
GIT_COMMITTER_DATE="Thu Jun 08 13:44:15 2023 +0300" git commit --amend
Алиас для графического формата команды git log:
#Подключить алиас с ключём --all (отображение всех ветвей)
git config --global alias.log0 "log --graph --abbrev-commit --decorate --format=format:'%C(bold blue)%h%C(reset) - %C(bold green)(%ci)%C(reset) %C(white)%s%C(reset) %C(dim white)- %an%C(reset)%C(bold yellow)%d%C(reset)' --all"
#Подключить алиас без ключа --all (отображение только текущей ветви)
git config --global alias.log1 "log --graph --abbrev-commit --decorate --format=format:'%C(bold blue)%h%C(reset) - %C(bold green)(%ci)%C(reset) %C(white)%s%C(reset) %C(dim white)- %an%C(reset)%C(bold yellow)%d%C(reset)'"
#Отключить алиас
git config --global --unset alias.log1