ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] Q: использование git-config как хранилище дефолтных опций для  gear
@ 2008-09-08 14:09 Alexey I. Froloff
  2008-09-08 16:25 ` Damir Shayhutdinov
  2008-09-08 20:08 ` Alexey Gladkov
  0 siblings, 2 replies; 11+ messages in thread
From: Alexey I. Froloff @ 2008-09-08 14:09 UTC (permalink / raw)
  To: ALT Devel discussion list

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

Я немного накоммитил в gear в ветке git-config.  Основная идея в
том, чтобы некоторые опции для некоторых команд держать в
.git/config.  Например шаблон тега для gear-create-tag (если из
одного репозитария собираются несколько пакетов имеет смысл
добавлять @name@ к имени тега).

Работает оно так:

gear_config_option VARIABLE_NAME OPTION_NAME "значение по умолчанию"

1. проверяется gear.SUBCOMMAND.OPTION_NAME
2. если не задано, проверяется gear.OPTION_NAME
3. если и оно не задано, переменной VARIABLE_NAME присваивается
"значение по умолчанию"

SUBCOMMAND это имя команды без префикса "gear-".

Примеры использования:

$ git config --add gear.create-tag.name '@name@-@version@-@release@'
$ git config --global --add gear.changelog.name 'My Cool Name'
$ git config --global --add gear.changelog.email 'my@cool.email'
$ git config --global --add gear.verbose -v
$ git config --global --add gear.merge.verbose ''

Чтобы начать это использовать надо пропатчить соответствующие
команды, примеры опять же у меня в git.

Существует множество способов выстрелить самому себе в ногу:

$ git config --add gear.changelog.name 'My Cool Name'
$ git config --add gear.changelog.name 'My Another Name'
$ gear-changelog --no-rules
error: More than one value for the key gear.changelog.name: My Another Name
* Mon Sep 08 2008 My Cool Name <my@cool.email> 1.5.0-alt1

Теоретически могут быть пересечения по именам опций, например
gear.changelog.rules (не реализовано) и gear.rules (реализовано).
Значения разные, но если gear.changelog.rules не определён, будет
fallback на gear.rules и в результате получится фигня.

Комментарии?

-- 
Regards,
Sir Raorn.

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

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

* Re: [devel] Q: использование git-config как хранилище дефолтных опций для gear
  2008-09-08 14:09 [devel] Q: использование git-config как хранилище дефолтных опций для gear Alexey I. Froloff
@ 2008-09-08 16:25 ` Damir Shayhutdinov
  2008-09-08 16:45   ` Alexey I. Froloff
  2008-09-08 20:08 ` Alexey Gladkov
  1 sibling, 1 reply; 11+ messages in thread
From: Damir Shayhutdinov @ 2008-09-08 16:25 UTC (permalink / raw)
  To: ALT Linux Team development discussions

> Комментарии?
Лично я бы разделил настройки на две части

1) Настройки, относящиеся к ведению конкретного репозитария. Сюда пока
подходит шаблон тега, список бранчей для автоматического merge и т.п.
В примере это gear.create-tag.name

2) Настройки, не относящиеся к ведению конкретного репозитария -
gear.changelog.name и прочие зависящие от персоны (gear.verbose etc).

Так вот, настройки первого типа хотелось бы копировать при
клонировании репозитария. Потому как они в общем-то составляют с ним
единое логическое целое "репозитарий + как с ним правильно работать".
В связи с этим считаю нормальным эти настройки держать где-нить в
.gear/config рабочего бранча.

Настройки второго типа при клонировании репозитария копировать не надо
- так как они нуждаются в индивидуальной настройке под конкретного
пользователя. Такие настройки удобнее хранить в .git/config (или в
глобальном .gitconfig).

В общем я за то, чтобы мухи были отделены от котлет.

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

* Re: [devel] Q: использование git-config как хранилище дефолтных опций для gear
  2008-09-08 16:25 ` Damir Shayhutdinov
@ 2008-09-08 16:45   ` Alexey I. Froloff
  2008-09-08 18:32     ` Damir Shayhutdinov
  0 siblings, 1 reply; 11+ messages in thread
From: Alexey I. Froloff @ 2008-09-08 16:45 UTC (permalink / raw)
  To: ALT Devel discussion list

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

* Damir Shayhutdinov <damir@> [080908 20:38]:
> Так вот, настройки первого типа хотелось бы копировать при
> клонировании репозитария.
При помощи файла настроек специального вида злоумышленник может.
Чтобы он этого не мог, надо устраивать очередной неестественный
интеллект.  Плюс, .gear/config получается не per-repo, а
per-package, если не сказать per-master-branch.  Например,
настройки для gear-update не подхватятся в бранче "upstream".  Я
уже не говорю про резолв конфликтов и gear-merge...

-- 
Regards,
Sir Raorn.

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

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

* Re: [devel] Q: использование git-config как хранилище дефолтных опций для gear
  2008-09-08 16:45   ` Alexey I. Froloff
@ 2008-09-08 18:32     ` Damir Shayhutdinov
  2008-09-08 18:59       ` Alexey I. Froloff
  0 siblings, 1 reply; 11+ messages in thread
From: Damir Shayhutdinov @ 2008-09-08 18:32 UTC (permalink / raw)
  To: ALT Linux Team development discussions

>> Так вот, настройки первого типа хотелось бы копировать при
>> клонировании репозитария.
> При помощи файла настроек специального вида злоумышленник может.
> Чтобы он этого не мог, надо устраивать очередной неестественный
> интеллект.  Плюс, .gear/config получается не per-repo, а
> per-package, если не сказать per-master-branch.  Например,
> настройки для gear-update не подхватятся в бранче "upstream".
Это и требуется. Для таких настроек, которые per-master-branch. Чтобы
клонирование репозитария приводило к сохранению важных настроек.

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

* Re: [devel] Q: использование git-config как хранилище дефолтных опций для gear
  2008-09-08 18:32     ` Damir Shayhutdinov
@ 2008-09-08 18:59       ` Alexey I. Froloff
  2008-09-08 19:03         ` Damir Shayhutdinov
  0 siblings, 1 reply; 11+ messages in thread
From: Alexey I. Froloff @ 2008-09-08 18:59 UTC (permalink / raw)
  To: ALT Devel discussion list

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

* Damir Shayhutdinov <damir@> [080908 22:33]:
> >> Так вот, настройки первого типа хотелось бы копировать при
> >> клонировании репозитария.
> > При помощи файла настроек специального вида злоумышленник может.
> > Чтобы он этого не мог, надо устраивать очередной неестественный
> > интеллект.  Плюс, .gear/config получается не per-repo, а
> > per-package, если не сказать per-master-branch.  Например,
> > настройки для gear-update не подхватятся в бранче "upstream".
> Это и требуется. Для таких настроек, которые per-master-branch. Чтобы
> клонирование репозитария приводило к сохранению важных настроек.
Ты не понял.  Эти настройки подхватятся только если ты стоишь в
этом master-branch.

-- 
Regards,
Sir Raorn.

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

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

* Re: [devel] Q: использование git-config как хранилище дефолтных опций для gear
  2008-09-08 18:59       ` Alexey I. Froloff
@ 2008-09-08 19:03         ` Damir Shayhutdinov
  2008-09-08 19:33           ` Alexey I. Froloff
  0 siblings, 1 reply; 11+ messages in thread
From: Damir Shayhutdinov @ 2008-09-08 19:03 UTC (permalink / raw)
  To: ALT Linux Team development discussions

> Ты не понял.  Эти настройки подхватятся только если ты стоишь в
> этом master-branch.
Не обязательно. Вот как раз мастер-бранч можно указывать в
.git/config, со значением "master" по умолчанию. Поэтому он будет
доступен и из других бранчей.

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

* Re: [devel] Q: использование git-config как хранилище дефолтных опций для gear
  2008-09-08 19:03         ` Damir Shayhutdinov
@ 2008-09-08 19:33           ` Alexey I. Froloff
  2008-09-09  7:28             ` Damir Shayhutdinov
  0 siblings, 1 reply; 11+ messages in thread
From: Alexey I. Froloff @ 2008-09-08 19:33 UTC (permalink / raw)
  To: ALT Devel discussion list

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

* Damir Shayhutdinov <damir@> [080908 23:06]:
> > Ты не понял.  Эти настройки подхватятся только если ты стоишь в
> > этом master-branch.
> Не обязательно. Вот как раз мастер-бранч можно указывать в
> .git/config, со значением "master" по умолчанию. Поэтому он будет
> доступен и из других бранчей.
У меня шесть "мастер-бранчей" только для сизифа в одном
репозитарии.

Короче, ерунду ты придумал.

-- 
Regards,
Sir Raorn.

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

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

* Re: [devel] Q: использование git-config как хранилище дефолтных опций для  gear
  2008-09-08 14:09 [devel] Q: использование git-config как хранилище дефолтных опций для gear Alexey I. Froloff
  2008-09-08 16:25 ` Damir Shayhutdinov
@ 2008-09-08 20:08 ` Alexey Gladkov
  2008-09-08 20:37   ` Alexey I. Froloff
  1 sibling, 1 reply; 11+ messages in thread
From: Alexey Gladkov @ 2008-09-08 20:08 UTC (permalink / raw)
  To: ALT Linux Team development discussions

Alexey I. Froloff wrote:
> Теоретически могут быть пересечения по именам опций, например
> gear.changelog.rules (не реализовано) и gear.rules (реализовано).
> Значения разные, но если gear.changelog.rules не определён, будет
> fallback на gear.rules и в результате получится фигня.
> 
> Комментарии?

Мне кажется, что идея хорошая. У каждого мантейнера свои предпочтения 
среди ключей, имён тегов и т.д.

Меня смущает откат gear.changelog.rules -> gear.rules ... есть 
возможность ложных срабатываний и не очевидных ошибок.
Может стоит убрать эту функцию, дабы увеличить стабильность работы?

-- 
Rgrds, legion



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

* Re: [devel] Q: использование git-config как хранилище дефолтных опций для gear
  2008-09-08 20:08 ` Alexey Gladkov
@ 2008-09-08 20:37   ` Alexey I. Froloff
  0 siblings, 0 replies; 11+ messages in thread
From: Alexey I. Froloff @ 2008-09-08 20:37 UTC (permalink / raw)
  To: ALT Devel discussion list

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

* Alexey Gladkov <legion@> [080909 00:11]:
> Меня смущает откат gear.changelog.rules -> gear.rules ... есть 
> возможность ложных срабатываний и не очевидных ошибок.
> Может стоит убрать эту функцию, дабы увеличить стабильность работы?
Я тоже начинаю склоняться к этой мысли.

-- 
Regards,
Sir Raorn.

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

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

* Re: [devel] Q: использование git-config как хранилище дефолтных опций для gear
  2008-09-08 19:33           ` Alexey I. Froloff
@ 2008-09-09  7:28             ` Damir Shayhutdinov
  2008-09-09  9:13               ` Alexey I. Froloff
  0 siblings, 1 reply; 11+ messages in thread
From: Damir Shayhutdinov @ 2008-09-09  7:28 UTC (permalink / raw)
  To: ALT Linux Team development discussions

>> > Ты не понял.  Эти настройки подхватятся только если ты стоишь в
>> > этом master-branch.
>> Не обязательно. Вот как раз мастер-бранч можно указывать в
>> .git/config, со значением "master" по умолчанию. Поэтому он будет
>> доступен и из других бранчей.
> У меня шесть "мастер-бранчей" только для сизифа в одном
> репозитарии.
В том-то и смысл.


> Короче, ерунду ты придумал.
Ладно, ждем пока поймешь.

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

* Re: [devel] Q: использование git-config как хранилище дефолтных опций для gear
  2008-09-09  7:28             ` Damir Shayhutdinov
@ 2008-09-09  9:13               ` Alexey I. Froloff
  0 siblings, 0 replies; 11+ messages in thread
From: Alexey I. Froloff @ 2008-09-09  9:13 UTC (permalink / raw)
  To: ALT Devel discussion list

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

* Damir Shayhutdinov <damir@> [080909 11:40]:
> >> > Ты не понял.  Эти настройки подхватятся только если ты стоишь в
> >> > этом master-branch.
> >> Не обязательно. Вот как раз мастер-бранч можно указывать в
> >> .git/config, со значением "master" по умолчанию. Поэтому он будет
> >> доступен и из других бранчей.
> > У меня шесть "мастер-бранчей" только для сизифа в одном
> > репозитарии.
> В том-то и смысл.
И что писать в .git/config?

> > Короче, ерунду ты придумал.
> Ладно, ждем пока поймешь.
Жди ;-)

-- 
Regards,
Sir Raorn.

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

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

end of thread, other threads:[~2008-09-09  9:13 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2008-09-08 14:09 [devel] Q: использование git-config как хранилище дефолтных опций для gear Alexey I. Froloff
2008-09-08 16:25 ` Damir Shayhutdinov
2008-09-08 16:45   ` Alexey I. Froloff
2008-09-08 18:32     ` Damir Shayhutdinov
2008-09-08 18:59       ` Alexey I. Froloff
2008-09-08 19:03         ` Damir Shayhutdinov
2008-09-08 19:33           ` Alexey I. Froloff
2008-09-09  7:28             ` Damir Shayhutdinov
2008-09-09  9:13               ` Alexey I. Froloff
2008-09-08 20:08 ` Alexey Gladkov
2008-09-08 20:37   ` Alexey I. Froloff

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