ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] gear: tar by sha-1/tag
@ 2008-04-06 14:05 Eugene Prokopiev
  2008-04-06 14:49 ` Alexey I. Froloff
  2008-04-06 14:51 ` Alexey I. Froloff
  0 siblings, 2 replies; 7+ messages in thread
From: Eugene Prokopiev @ 2008-04-06 14:05 UTC (permalink / raw)
  To: Devel

Здравствуйте!

Как с помощью gear сделать tar по идентификатору коммита?

$ mkdir mypackage
$ cd mypackage
$ git-init
$ mkdir .gear
$ touch .gear/rules
$ git-add .
$ git-commit -a -m 'initial commit'
$ git-branch upstream
$ touch file
$ git-add .
$ git-commit -a -m '0.1'
$ git-checkout master
$ touch mypackage.spec
$ git-add .
$ PAGER=cat git-log
commit 15c4e518bc37a8277dc72d3d4cb2321edc0b812b
...
$ echo "tar: 15c4e518bc37a8277dc72d3d4cb2321edc0b812b:mypackage" > .gear/rules
$ gear -v --commit --export-dir=/tmp
Created commit b9d4f7d: Temporary commit by gear.
 1 files changed, 1 insertions(+), 0 deletions(-)
 create mode 100644 mypackage.spec
gear: Temporarily committed local changes.
gear: .gear/rules line 1: Empty @version@ "" specified
gear: Reverted temporary commit b9d4f7dfa330e40ba4f619c0840446453c52442e.

Или по тегу?

$ git-checkout upstream
$ git-tag last
$ git-checkout master
$ echo "tar: last:mypackage" > .gear/rules
$ gear -v --commit --export-dir=/tmp
Created commit 1deec5b: Temporary commit by gear.
 1 files changed, 1 insertions(+), 0 deletions(-)
 create mode 100644 mypackage.spec
gear: Temporarily committed local changes.
gear: .gear/rules line 1: Empty @version@ "" specified
gear: Reverted temporary commit 1deec5b1bd5b7569f517ada84d31b0efa42625c6.

@version@ использовать обязательно? Если да, то как вывернуться в
такой ситуации: у меня в спеке version - 1.2 и вряд ли в ближайшее
время изменится, а release - alt0.svnNNNN или 0.alt0.svnNNNN.M40 (для
branch/4.0). Планировал иметь тег, который при каждом обновлении из
апстрима будет сдвигаться на последний коммит и уже этот тег указывать
в .gear/rules

-- 
С уважением,
Прокопьев Евгений

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [devel] gear: tar by sha-1/tag
  2008-04-06 14:05 [devel] gear: tar by sha-1/tag Eugene Prokopiev
@ 2008-04-06 14:49 ` Alexey I. Froloff
  2008-04-06 17:25   ` Eugene Prokopiev
  2008-04-06 14:51 ` Alexey I. Froloff
  1 sibling, 1 reply; 7+ messages in thread
From: Alexey I. Froloff @ 2008-04-06 14:49 UTC (permalink / raw)
  To: ALT Devel discussion list

[-- Attachment #1: Type: text/plain, Size: 428 bytes --]

* Eugene Prokopiev <enp@> [080406 18:11]:
> $ touch mypackage.spec
...
> $ echo "tar: 15c4e518bc37a8277dc72d3d4cb2321edc0b812b:mypackage" > .gear/rules
...
> gear: .gear/rules line 1: Empty @version@ "" specified

> @version@ использовать обязательно?
По умолчанию создаётся архив с именем @dir@-@version@.tar и
каталогом внутри @dir@-@version@.  А у вас спек пустой.  См.
gear-rules(5).

-- 
Regards,
Sir Raorn.

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 189 bytes --]

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [devel] gear: tar by sha-1/tag
  2008-04-06 14:05 [devel] gear: tar by sha-1/tag Eugene Prokopiev
  2008-04-06 14:49 ` Alexey I. Froloff
@ 2008-04-06 14:51 ` Alexey I. Froloff
  2008-04-06 17:31   ` Eugene Prokopiev
  1 sibling, 1 reply; 7+ messages in thread
From: Alexey I. Froloff @ 2008-04-06 14:51 UTC (permalink / raw)
  To: ALT Devel discussion list

[-- Attachment #1: Type: text/plain, Size: 518 bytes --]

* Eugene Prokopiev <enp@> [080406 18:11]:
> такой ситуации: у меня в спеке version - 1.2 и вряд ли в ближайшее
> время изменится, а release - alt0.svnNNNN или 0.alt0.svnNNNN.M40 (для
> branch/4.0). Планировал иметь тег, который при каждом обновлении из
> апстрима будет сдвигаться на последний коммит и уже этот тег указывать
> в .gear/rules
Лучше использовать для tar: тег от версии 1.2 плюс делать diff:
от тега до HEAD (откуда собирается пакет).  См. такж.
gear-update-tag(1).

-- 
Regards,
Sir Raorn.

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 189 bytes --]

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [devel] gear: tar by sha-1/tag
  2008-04-06 14:49 ` Alexey I. Froloff
@ 2008-04-06 17:25   ` Eugene Prokopiev
  0 siblings, 0 replies; 7+ messages in thread
From: Eugene Prokopiev @ 2008-04-06 17:25 UTC (permalink / raw)
  To: ALT Linux Team development discussions

>  > $ touch mypackage.spec
>
> ...
>  > $ echo "tar: 15c4e518bc37a8277dc72d3d4cb2321edc0b812b:mypackage" > .gear/rules
>  ...
>
> > gear: .gear/rules line 1: Empty @version@ "" specified
>
>
> > @version@ использовать обязательно?
>  По умолчанию создаётся архив с именем @dir@-@version@.tar и
>  каталогом внутри @dir@-@version@.  А у вас спек пустой.  См.
>  gear-rules(5).

$ cat > mypackage.spec << EOF
> Name: mypackage
> Version: 0.1
> EOF
$ gear -v --commit --export-dir=/tmp
Created commit 1195348: Temporary commit by gear.
 2 files changed, 3 insertions(+), 0 deletions(-)
 create mode 100644 mypackage.spec
gear: Temporarily committed local changes.
gear: .gear/rules line 1: Name "last" not found in tag list
gear: .gear/rules line 1: Failed to make archive
gear: Reverted temporary commit 119534891218020e57dc5abe974faa6ddea96892.
$ gear-update-tag -ac
gear-update-tag: Commit 852bd18a935b8fe1383a02bf246665da58c10242 for
tag "last" is not an ancestor of current HEAD or commits to be merged
$ git-merge upstream
Updating 15c4e51..852bd18
Fast forward
 0 files changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 file
$ gear-update-tag -ac
$ gear -v --commit --export-dir=/tmp
Created commit ce38be8: Temporary commit by gear.
 3 files changed, 4 insertions(+), 0 deletions(-)
 create mode 100644 .gear/tags/list
 create mode 100644 mypackage.spec
gear: Temporarily committed local changes.
gear: .gear/rules line 1: tree "mypackage" not found in
"852bd18a935b8fe1383a02bf246665da58c10242"
gear: Reverted temporary commit ce38be89383a60494966a63a14cfbd45bf9b3d23.
$ echo "tar: last:." > .gear/rules
$ gear -v --commit --export-dir=/tmp
Created commit bc59cba: Temporary commit by gear.
 3 files changed, 4 insertions(+), 0 deletions(-)
 create mode 100644 .gear/tags/list
 create mode 100644 mypackage.spec
gear: Temporarily committed local changes.
gear: Extracted archive: mypackage-0.1.tar
gear: Extracted specfile: mypackage.spec
gear: Reverted temporary commit bc59cba57e8c8c4c7850ada9b17bbe78e424b8ff.

Получилось. Но внутри mypackage-0.1.tar оказался каталог .gear
(логично, раз мы сделали merge) - как от этого избавиться? Да и сама
необходимость merge огорчает - я думал, что бранчи с апстримовскими
исходниками и со спеком вообще можно будет не мержить. Или я плохо
понимаю происходящее и другого способа получить tar нет?

-- 
С уважением,
Прокопьев Евгений

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [devel] gear: tar by sha-1/tag
  2008-04-06 14:51 ` Alexey I. Froloff
@ 2008-04-06 17:31   ` Eugene Prokopiev
  2008-04-06 19:35     ` Anton Farygin
  0 siblings, 1 reply; 7+ messages in thread
From: Eugene Prokopiev @ 2008-04-06 17:31 UTC (permalink / raw)
  To: ALT Linux Team development discussions

> > такой ситуации: у меня в спеке version - 1.2 и вряд ли в ближайшее
>  > время изменится, а release - alt0.svnNNNN или 0.alt0.svnNNNN.M40 (для
>  > branch/4.0). Планировал иметь тег, который при каждом обновлении из
>  > апстрима будет сдвигаться на последний коммит и уже этот тег указывать
>  > в .gear/rules
>
>  Лучше использовать для tar: тег от версии 1.2 плюс делать diff:
>  от тега до HEAD (откуда собирается пакет).  См. такж.
>  gear-update-tag(1).

Совсем не понял. diff вроде используют только для того, чтобы разница
меду бранчами автомагически оформилась в src.rpm как патч. Мне в
src.rpm пока патчи не нужны, только tar и спек.

Или речь о другом сценарии? Пример можно?

-- 
С уважением,
Прокопьев Евгений

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [devel] gear: tar by sha-1/tag
  2008-04-06 17:31   ` Eugene Prokopiev
@ 2008-04-06 19:35     ` Anton Farygin
  2008-04-07  5:04       ` Eugene Prokopiev
  0 siblings, 1 reply; 7+ messages in thread
From: Anton Farygin @ 2008-04-06 19:35 UTC (permalink / raw)
  To: ALT Linux Team development discussions



Eugene Prokopiev пишет:
>>> такой ситуации: у меня в спеке version - 1.2 и вряд ли в ближайшее
>>  > время изменится, а release - alt0.svnNNNN или 0.alt0.svnNNNN.M40 (для
>>  > branch/4.0). Планировал иметь тег, который при каждом обновлении из
>>  > апстрима будет сдвигаться на последний коммит и уже этот тег указывать
>>  > в .gear/rules
>>
>>  Лучше использовать для tar: тег от версии 1.2 плюс делать diff:
>>  от тега до HEAD (откуда собирается пакет).  См. такж.
>>  gear-update-tag(1).
> 
> Совсем не понял. diff вроде используют только для того, чтобы разница
> меду бранчами автомагически оформилась в src.rpm как патч. Мне в
> src.rpm пока патчи не нужны, только tar и спек.
> 
> Или речь о другом сценарии? Пример можно?
> 

$ cat .gear-rules
tar: v@version@-@release@:. name=psi-@version@-@release@
diff: v@version@-@release@:. .
spec: psi.spec

Отдельный бранч с source (без .gear-rules), и тэг v0.12-alt1.svnXXXX 
стоит там.




^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [devel] gear: tar by sha-1/tag
  2008-04-06 19:35     ` Anton Farygin
@ 2008-04-07  5:04       ` Eugene Prokopiev
  0 siblings, 0 replies; 7+ messages in thread
From: Eugene Prokopiev @ 2008-04-07  5:04 UTC (permalink / raw)
  To: ALT Linux Team development discussions

> > > > такой ситуации: у меня в спеке version - 1.2 и вряд ли в ближайшее
> > > >
> > >  > время изменится, а release - alt0.svnNNNN или 0.alt0.svnNNNN.M40 (для
> > >  > branch/4.0). Планировал иметь тег, который при каждом обновлении из
> > >  > апстрима будет сдвигаться на последний коммит и уже этот тег
> указывать
> > >  > в .gear/rules
> > >
> > >  Лучше использовать для tar: тег от версии 1.2 плюс делать diff:
> > >  от тега до HEAD (откуда собирается пакет).  См. такж.
> > >  gear-update-tag(1).
> > >
> >
> > Совсем не понял. diff вроде используют только для того, чтобы разница
> > меду бранчами автомагически оформилась в src.rpm как патч. Мне в
> > src.rpm пока патчи не нужны, только tar и спек.
> >
> > Или речь о другом сценарии? Пример можно?
> >
> >
>
>  $ cat .gear-rules
>  tar: v@version@-@release@:. name=psi-@version@-@release@
>  diff: v@version@-@release@:. .
>  spec: psi.spec
>
>  Отдельный бранч с source (без .gear-rules), и тэг v0.12-alt1.svnXXXX стоит
> там.

Ну ставить теги по полному version+release - это очевидно, но
некрасиво, т.к. из одного git-репозитария можно, как я уже говорил,
собирать пакеты для разных apt-репозитариев: sisyphus и branch/4.0,
например. И что ставить на один коммит столько тегов, сколько будет
apt-репозитариев (а тут скоро и branch/4.1 намечается ;) )?

Смысла использования diff я не понял: почему в спеке просто не
прописать дополнительные source вместо накладывания здоровенного
патча?

-- 
С уважением,
Прокопьев Евгений

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2008-04-07  5:04 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2008-04-06 14:05 [devel] gear: tar by sha-1/tag Eugene Prokopiev
2008-04-06 14:49 ` Alexey I. Froloff
2008-04-06 17:25   ` Eugene Prokopiev
2008-04-06 14:51 ` Alexey I. Froloff
2008-04-06 17:31   ` Eugene Prokopiev
2008-04-06 19:35     ` Anton Farygin
2008-04-07  5:04       ` Eugene Prokopiev

ALT Linux Team development discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
		devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
	public-inbox-index devel

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.devel


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git