Участник:HihinRuslan/Памятка по работе с git/gear
Памятка по работе с git/gear
Создана для личного применения. Т.к. я сборкой через git пользуюсь редко, буду вносить сюда всё, что нужно запомнить для работы с git/Gear.
Термины и сокращения применяемой в памятке:
ЛР = Локальный репозиторий — репозиторий на моём компе.
УР = Удалённый репозиторий — личный репозиторий на git.altlinux.ru.
СР = Системный репозиторий — репозиторий входящий в различные ветки системных репозиториев — Сизифа и различных бренчей.
ДР = другой репозиторий — удалённые репозитории других пользователей.
ЧР = чужой репозиторий — все другие репозитории, не относящиеся к ALT Linux
Создать ЛР
mkdir имя_пакета; cd имя_пакета; git init
Создать УР
ssh git.alt init-db имя_пакета ssh git.alt init-db public/имя_пакета
Добавление файла README в ЛР
touch README git add README git commit -m 'first commit'
Удаление файла README из ЛР
git rm README git commit
Забросить ЛР в УР
git remote add origin git.alt:packages/test.git git push origin master
Указание УР origin и бранча master в команде push необходимо только в первый раз для создания бранча master в УР. git remote add создаёт в конфиг-файле ЛР запись, подобную такой:
[remote "origin"] url = ssh://git.alt/people/dottedmag/packages/test.git fetch = +refs/heads/*:refs/remotes/origin/*
И поэтому в дальнейшем
git push
будет отправлять в нужный УР все локальные ветки.
Удалить УР
ssh git.alt rm-db <path to git repository>
Например:
ssh git.alt rm-db public/имя_пакета
Копировать ДР в ур
ssh git.alt clone git.alt:/people/ИМЯ_ПОЛЬЗОВАТЕЛЯ/packages/ИМЯ_ПАКЕТА
Копировать УР в ЛР
git clone git.alt:packages/ИМЯ_ПАКЕТА
Для синхронизации веток УР с ЛР можно выполнить последовательно (или одной строкой через &&) команды:
git branch tmp git checkout tmp git fetch origin 'refs/heads/*:refs/heads/*' git checkout master git branch -d tmp
где tmp - это произвольная ветвь (назвать можно как угодно), которая должна отсутствовать в УР (иначе fetch завершится с ошибкой).
В результате в ЛР будут созданы локальные ветки (бранчи) аналогичные одноименным в УР и связанные с ними для последующих обменов изменениями (pull и push).
Копировать ЧР в ЛР
git clone url_чужого_репозитория
Базовые операции c ЛР
Добавление списка файлов в комит:
git add file1 file2 ... fileN
Добавление всех недобавленных файлов в комит: git add -a
Удаление файла из комита и с жесткого диска:
git rm file1 file2 ... fileN
Комит в локальный репозиторий (надо отметить, что в таком случае закомитятся только файлы, которые были обработаны с помощью git add/rm):
git commit
Переписать последний комит в локальный репозиторий (добавить к последнему коммиту изменения не меняя историю):
git commit --amend
При работе с gear очень полезно при многократной пересборке пакета до публикации изменений в УР.
Комит всех изменений в локальный репозиторий:
git commit -a
Отмена всех изменений, сделанных в дереве, до состояния, которое было при последнем комите в локальный репозиторий( очень опасная команда, подумайте прежде чем пользоваться ею):
git reset --hard HEAD
Создание файла различий относительно последнего комита:
git diff
Визуальный просмотр состояния ЛР
- Устанавливаем пакет gitk (,или git-gui, или qgit)
apt-get install gitk
- Перееходим в каталог с ЛР
cd каталог_пректа
- Запускаем gitk (для просмотра истории всех ветвей gitk --all)
- Изучаем состояние репозитория
Сборка пакета в Сизиф
Создаём подписанный тэг:
$ gear-create-tag запрос подписи имя_тэга будет равно версии пакета
$ git push origin --follow-tags записываем себе в ЛР
Отправляем пакет на сборку в Сизиф:
$ ssh git.alt build packages/ИМЯ_пакета.git имя_тега
имя_тэга равно версии пакета
Импорт пакета из СР
git clone http://git.altlinux.org/gears/h/hello.git
Удаляем из
[remote "origin"]
fetch = +refs/heads/*:refs/remotes/origin/*
Url = git://git.altlinux.org/gears/h/hello.git
git remote rm origin
Задаём свой ЛР
git remote add origin git.alt:packages/hello.git
Сбросить неудачный merge
(спасибо cas@)
git reset --hard HEAD
git clean -fd
Или: (спасибо qa@)
git merge --abort