[devel] gear - проблема с парсингом SPEC-файла.

Alexey I. Froloff =?iso-8859-1?q?raorn_=CE=C1_immo=2Eru?=
Вт Май 9 19:16:52 MSD 2006


* Dmitry V. Levin <ldv@> [060506 01:34]:
> Более логичным и универсальным выглядит "name=..." со значением по
> умолчанию @name на -@version@ (как и сейчас) и поддержкой 4-х ключевых слов:
> @dir@ - basename каталога (который указывается первым аргументом директивы);
> @name@ - значение тэга Name, извлечённое из spec-файла;
> @version@ - значение тэга Version, извлечённое из spec-файла;
> @name@ - значение тэга Release, извлечённое из spec-файла.
Я тут обнаружил, что в этом репозитарии можно хранить не только
исходники и патчи, но и вспомогательные скрипты ;-)

Есть у меня в vim такой scripts/getpatches, который выкачивает
патчи с vim.org в отдельный каталог files/official-patches

Я (как и всегда) хочу странного:

.gear-rules:
tar.bz2: files/official-patches name=vim-7.0- на dir@-001

Я хочу иметь архив с именем
%name-%mainver%{?pre:%pre}-official-patches-%patchlevel.tar.bz2,
но чтобы внутри был каталог "official-patches"...  Примерно так:

tar.bz2: files/official-patches name=vim-7.0- на dir@-001 basename=official-patches

Патч на gear в аттаче.  Я не стал copy-paste'ить раскрытие
макросов ещё и в basename, есть мнение что это вообще надо
перенести в функцию.

-- 
Regards,
Sir Raorn.
----------- следующая часть -----------
 gear |   12 ++++++++++--
 1 files changed, 10 insertions(+), 2 deletions(-)

diff --git a/gear b/gear
index 3613797..555ad62 100755
--- a/gear
+++ b/gear
@@ -246,6 +246,7 @@ get_tar_name()
 	else
 		tar_name='@dir на -@version@'
 	fi
+	base_name=
 
 	local opt quoted spec= spec_name= spec_version= spec_release=
 
@@ -256,6 +257,8 @@ get_tar_name()
 				;;
 			name=*) tar_name="${opt#name=}"
 				;;
+			basename=*) base_name="${opt#basename=}"
+				;;
 			*) rules_error "Unrecognized option: $opt"
 				;;
 		esac
@@ -306,7 +309,12 @@ make_tar()
 	dir="$1"
 	shift
 	name="$1"
+	base_name="$name"
 	shift
+	if [ $# -gt 0 ]; then
+	    base_name="$1"
+	    shift
+	fi
 
 	local id
 	if [ "$dir" = . ]; then
@@ -325,7 +333,7 @@ make_tar()
 
 	fi
 
-	git-tar-tree "$id" "$name" >"$outdir/$name.tar"
+	git-tar-tree "$id" "$base_name" >"$outdir/$name.tar"
 	case "$cmd" in
 		tar.gz:)
 			gzip -9 "$outdir/$name.tar"
@@ -346,7 +354,7 @@ make_archive()
 	check_path dirname "$dir_name"
 
 	get_tar_name "$(basename -- "$dir_name")" "$@"
-	make_tar "$cmd" "$dir_name" "$tar_name"
+	make_tar "$cmd" "$dir_name" "$tar_name" ${base_name:+"$base_name"}
 }
 
 copy_by_pattern()
----------- следующая часть -----------
Было удалено вложение не в текстовом формате...
Имя     : =?iso-8859-1?q?=CF=D4=D3=D5=D4=D3=D4=D7=D5=C5=D4?=
Тип     : application/pgp-signature
Размер  : 191 байтов
Описание: Digital signature
Url     : <http://lists.altlinux.org/pipermail/devel/attachments/20060509/fdac058a/attachment-0001.bin>


Подробная информация о списке рассылки Devel