From: mookid@sigent.ru (Mikhail Zabaluev)
To: devel@linux.iplabs.ru
Subject: Re: [devel] rpm macros
Date: Mon, 13 Nov 2000 02:27:41 +0300
Message-ID: <20001113022741.B1235@localhost.localdomain> (raw)
In-Reply-To: <20001112194832.A21006@LDV.fandra.org>; from ldv@fandra.org on Sun, Nov 12, 2000 at 07:48:32PM +0300
Hello Dmitry,
On Sun, Nov 12, 2000 at 19:48 +0300, Dmitry V. Levin wrote:
>
> On Sun, Nov 12, 2000 at 01:55:03PM +0300, Mikhail Zabaluev wrote:
> > > $ rpm --eval='%embrace a b'
> > >
> > > %embrace() %brace
> > > %brace() begin %2 %1 end
> > > результат: begin b a end
> >
> > То есть %*, %1, %2 передаются как есть макросу "со скобочками", если он
> > подставляется без параметров? Бред, так быть не должно. Эти параметры
> > должны быть локальными.
>
> Не совсем так: %*, %1, %2 и пр. создаются при каждом расширении по мере
> надобности. Дело в том, что в rpm не существует понятия локальных
> макросов. В результате, в область видимости попадают порой позиционные
> параметры макроса, раскрытого уровнем выше.
Как бы это "порой" более четко сформулировать? Когда позиционные параметры
не используются подчиненным макросом, их значения сохраняются теми, что
были на уровень выше? Почему все-таки %* не инициализируется правильным
образом для каждой подстановки параметризованного макроса?
> Например, следующие макросы
> %embrace() %brace X %1
> %brace() %ONE %1 TWO %2 THREE %3 FOUR
>
> по команде
> $ rpm --eval='%embrace все что угодно'
>
> раскрываются в
> %ONE X TWO X THREE угодно FOUR
Даже по вышеописанной извращенной логике должно получаться
%ONE X TWO все THREE угодно FOUR
> А если в процессе раскрытия парсер обнаружит, что %1 имеет значение %1,
> или %2 - значение %2, и т.д., причем не обязательно на последнем уровне
> раскрытия, то получается рекурсия.
>
> Это все, конечно, плохо, однако именно так оно реализовано - это Вам не
> cpp, где макрос, открытый один раз, выпадает из области видимости.
>
> Какие будут предложения?
Считать обработку параметризованных макросов в rpm кривой,
контр-интуитивной (если считать, что за образец взят механизм
позиционных параметров shell) и не полагаться без крайней нужды на такие
макросы.
--
Stay tuned,
MhZ mailto:mookid@sigent.ru
-----------
The world is coming to an end! Repent and return those library books!
_______________________________________________
Devel mailing list
Devel@linux.iplabs.ru
http://www.logic.ru/mailman/listinfo/devel
next prev parent reply other threads:[~2000-11-12 23:27 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2000-11-10 15:12 Mikhail Zabaluev
2000-11-11 21:25 ` Dmitry V. Levin
2000-11-12 1:01 ` Mikhail Zabaluev
2000-11-11 22:06 ` Ivan Zakharyaschev
2000-11-11 23:29 ` Dmitry V. Levin
2000-11-12 9:46 ` Ivan Zakharyaschev
2000-11-12 10:55 ` Mikhail Zabaluev
2000-11-12 14:07 ` Ivan Zakharyaschev
2000-11-12 23:13 ` Mikhail Zabaluev
2000-11-14 22:35 ` Dmitry V. Levin
2000-11-12 16:48 ` Dmitry V. Levin
2000-11-12 23:27 ` Mikhail Zabaluev [this message]
2000-11-13 10:14 ` Dmitry V. Levin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20001113022741.B1235@localhost.localdomain \
--to=mookid@sigent.ru \
--cc=devel@linux.iplabs.ru \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
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