Git/SomeDestReposViaBranches: различия между версиями
< Git
Ilis (обсуждение | вклад) Нет описания правки |
м (+категория) |
||
(не показаны 2 промежуточные версии 2 участников) | |||
Строка 1: | Строка 1: | ||
{{DISPLAYTITLE:git/SomeDestReposViaBranches}} | {{DISPLAYTITLE:git/SomeDestReposViaBranches}} | ||
{{MovedFromFreesourceInfo|AltLinux/Sisyphus/devel/git/SomeDestReposViaBranches}} | {{MovedFromFreesourceInfo|AltLinux/Sisyphus/devel/git/SomeDestReposViaBranches}} | ||
== Поддержка пакета для нескольких apt-репозиториев с помощью бранчей git в картинках == | |||
{| class="standard" | |||
{| | |||
|- | |- | ||
!Действия | |||
Действия | !Команды | ||
!Результат в gitk --all | |||
Команды | |||
Результат в gitk --all | |||
|- | |- | ||
| | |Создание репозитория | ||
Создание | |||
| | | | ||
$ mkdir ser2net | $ mkdir ser2net | ||
Строка 20: | Строка 15: | ||
$ git init-db | $ git init-db | ||
| | | | ||
|- | |- | ||
| | |Создание и сохранение в бранче master файла .gear/rules, описывающего правила построения srpm | ||
Создание и сохранение в бранче master файла .gear/rules, описывающего правила построения srpm | |||
| | | | ||
$ mkdir .gear | $ mkdir .gear | ||
Строка 30: | Строка 23: | ||
$ git add . | $ git add . | ||
$ git commit -m 'Initial commit' | $ git commit -m 'Initial commit' | ||
| | |[[Image:0.png]] | ||
[[Image:0.png]] | |||
|- | |- | ||
| | |Создание дополнительных бранчей | ||
Создание дополнительных бранчей | |||
| | | | ||
$ git branch upstream | $ git branch upstream | ||
$ git branch srpm | $ git branch srpm | ||
$ git branch srpm-4.0 | $ git branch srpm-4.0 | ||
| | |[[Image:1.png]] | ||
[[Image:1.png]] | |||
|- | |- | ||
| | |Загрузка исходного кода в бранч upstream | ||
Загрузка исходного кода в бранч upstream | |||
| | | | ||
$ git checkout upstream | $ git checkout upstream | ||
Строка 53: | Строка 42: | ||
$ git commit -m 'Upstream initial commit' | $ git commit -m 'Upstream initial commit' | ||
$ git tag ser2net-2.3 | $ git tag ser2net-2.3 | ||
| | |[[Image:2.png]] | ||
[[Image:2.png]] | |||
|- | |- | ||
| | |Создание спека и инитскрипта в бранче srpm | ||
Создание спека и инитскрипта в бранче srpm | |||
| | | | ||
$ git checkout srpm | $ git checkout srpm | ||
Строка 64: | Строка 51: | ||
$ git add . | $ git add . | ||
$ git commit -m 'Initial spec and initscript' | $ git commit -m 'Initial spec and initscript' | ||
| | |[[Image:3.png]] | ||
[[Image:3.png]] | |||
|- | |- | ||
| | |Объединение бранчей srpm и upstream, правка спека, создание пакета для Sisyphus | ||
Объединение бранчей srpm и upstream, правка спека, создание пакета для Sisyphus | |||
| | | | ||
$ git checkout srpm | $ git checkout srpm | ||
Строка 79: | Строка 64: | ||
$ git tag srpm-ser2net-2.3 | $ git tag srpm-ser2net-2.3 | ||
$ gear --rpmbuild -- rpm -bs --sign --nodeps | $ gear --rpmbuild -- rpm -bs --sign --nodeps | ||
$ rsync -va --partial --stats --delete-after -e ssh /RPM/SRPMS/ser2net-2.3-alt1.src.rpm devel:/incoming/Sisyphus/ | $ rsync -va --partial --stats --delete-after \ | ||
| | -e ssh /RPM/SRPMS/ser2net-2.3-alt1.src.rpm \ | ||
[[Image:4.png]] | devel:/incoming/Sisyphus/ | ||
|[[Image:4.png]] | |||
|- | |- | ||
| | |Объединение бранчей srpm-4.0 и srpm, правка спека, создание пакета для branch/4.0 | ||
Объединение бранчей srpm-4.0 и srpm, правка спека, создание пакета для branch/4.0 | |||
| | | | ||
$ git checkout srpm-4.0 | $ git checkout srpm-4.0 | ||
Строка 95: | Строка 80: | ||
$ git tag srpm-4.0-ser2net-2.3 | $ git tag srpm-4.0-ser2net-2.3 | ||
$ gear --rpmbuild -- rpm -bs --sign --nodeps | $ gear --rpmbuild -- rpm -bs --sign --nodeps | ||
$ rsync -va --partial --stats --delete-after -e ssh /RPM/SRPMS/ser2net-2.3-alt0.M40.src.rpm devel:/incoming/updates/4.0/ | $ rsync -va --partial --stats --delete-after \ | ||
| | -e ssh /RPM/SRPMS/ser2net-2.3-alt0.M40.src.rpm \ | ||
[[Image:5.png]] | devel:/incoming/updates/4.0/ | ||
|[[Image:5.png]] | |||
|- | |- | ||
| | |Обновление исходного кода из апстрима | ||
Обновление исходного кода из апстрима | |||
| | | | ||
$ git checkout upstream | $ git checkout upstream | ||
Строка 106: | Строка 91: | ||
$ git commit -a -m 'Upstream update' | $ git commit -a -m 'Upstream update' | ||
$ git tag ser2net-2.4 | $ git tag ser2net-2.4 | ||
| | |[[Image:6.png]] | ||
[[Image:6.png]] | |||
|- | |- | ||
| | |Объединение бранчей srpm и upstream, правка спека, создание новой версии пакета для Sisyphus | ||
Объединение бранчей srpm и upstream, правка спека, создание новой версии пакета для Sisyphus | |||
| | | | ||
$ git checkout srpm | $ git checkout srpm | ||
Строка 121: | Строка 104: | ||
$ git tag srpm-ser2net-2.4 | $ git tag srpm-ser2net-2.4 | ||
$ gear --rpmbuild -- rpm -bs --sign --nodeps | $ gear --rpmbuild -- rpm -bs --sign --nodeps | ||
$ rsync -va --partial --stats --delete-after -e ssh /RPM/SRPMS/ser2net-2.4-alt1.src.rpm devel:/incoming/Sisyphus/ | $ rsync -va --partial --stats --delete-after \ | ||
| | -e ssh /RPM/SRPMS/ser2net-2.4-alt1.src.rpm \ | ||
[[Image:7.png]] | devel:/incoming/Sisyphus/ | ||
|[[Image:7.png]] | |||
|- | |- | ||
| | |Объединение бранчей srpm и upstream, правка спека, создание новой версии пакета для branch/4.0 | ||
Объединение бранчей srpm и upstream, правка спека, создание новой версии пакета для branch/4.0 | |||
| | | | ||
$ git checkout srpm-4.0 | $ git checkout srpm-4.0 | ||
Строка 137: | Строка 120: | ||
$ git tag srpm-4.0-ser2net-2.4 | $ git tag srpm-4.0-ser2net-2.4 | ||
$ gear --rpmbuild -- rpm -bs --sign --nodeps | $ gear --rpmbuild -- rpm -bs --sign --nodeps | ||
$ rsync -va --partial --stats --delete-after -e ssh /RPM/SRPMS/ser2net-2.4-alt0.M40.src.rpm devel:/incoming/updates/4.0/ | $ rsync -va --partial --stats --delete-after \ | ||
| | -e ssh /RPM/SRPMS/ser2net-2.4-alt0.M40.src.rpm \ | ||
[[Image:8.png]] | devel:/incoming/updates/4.0/ | ||
|[[Image:8.png]] | |||
|} | |} | ||
Если вы сделали коммит, о котором потом пожалели, можно откатиться с помощью git reset --hard HEAD^. Если --hard заменить на --soft, то изменения, сделанные в удаленном коммите, останутся в файлах, но окажутся незакоммиченными. Аналогично вместо HEAD^ можно указать другой коммит, явно или косвенно. | Если вы сделали коммит, о котором потом пожалели, можно откатиться с помощью git reset --hard HEAD^. Если --hard заменить на --soft, то изменения, сделанные в удаленном коммите, останутся в файлах, но окажутся незакоммиченными. Аналогично вместо HEAD^ можно указать другой коммит, явно или косвенно. | ||
Строка 147: | Строка 130: | ||
{{Category navigation|title=git|category=git|sortkey={{SUBPAGENAME}}}} | {{Category navigation|title=git|category=git|sortkey={{SUBPAGENAME}}}} | ||
{{Category navigation|title=gear|category=gear|sortkey=*}} | |||
Текущая версия от 01:12, 19 февраля 2015
Поддержка пакета для нескольких apt-репозиториев с помощью бранчей git в картинках
Если вы сделали коммит, о котором потом пожалели, можно откатиться с помощью git reset --hard HEAD^. Если --hard заменить на --soft, то изменения, сделанные в удаленном коммите, останутся в файлах, но окажутся незакоммиченными. Аналогично вместо HEAD^ можно указать другой коммит, явно или косвенно.