[devel] [PATCH] Verbose QueryTags prints whether tag is an extension
Vladimir D. Seleznev
vseleznv на altlinux.org
Пн Апр 13 21:20:21 MSK 2020
On Mon, Apr 13, 2020 at 09:04:37PM +0300, Dmitry V. Levin wrote:
> On Sun, Apr 12, 2020 at 06:02:26AM +0300, Vladimir D. Seleznev wrote:
> > Verbose QueryTags prints four field: tagname, tagvalue, tagtype and whether
> > it is an extension. To make it possible QueryTags uses new function
> > rpmTagIsExtension() that returns 0 if tag is real, 1 if tag is an extension
> > or -1 if tag is not found.
> >
> > * lib/query.c(rpmDisplayQueryTags): Print whether tag is an extension.
> > * lib/rpmtag.h(rpmTagIsExtension): New definition.
> > * lib/tagname.c(rpmTagIsExtension): New function.
> > ---
> > lib/query.c | 5 +++++
> > lib/rpmtag.h | 7 +++++++
> > lib/tagname.c | 14 ++++++++++++++
> > 3 files changed, 26 insertions(+)
> >
> > diff --git a/lib/query.c b/lib/query.c
> > index 60d3a0269..f27b15a7c 100644
> > --- a/lib/query.c
> > +++ b/lib/query.c
> > @@ -253,9 +253,14 @@ void rpmDisplayQueryTags(FILE * fp)
> > if (rpmIsVerbose()) {
> > rpmTagVal tag = rpmTagGetValue(sname);
> > rpmTagType type = rpmTagGetTagType(tag);
> > + int ext = rpmTagIsExtension(tag);
> > fprintf(fp, "%-20s %6d", sname, tag);
> > if (type > RPM_NULL_TYPE && type <= RPM_MAX_TYPE)
> > fprintf(fp, " %s", tagTypeNames[type]);
> > + else if (ext == 1)
> > + fprintf(fp, " -");
> > + if (ext == 1)
> > + fprintf(fp, " ext");
> > } else {
> > fprintf(fp, "%s", sname);
> > }
>
> This changes rpmDisplayQueryTags output in an incompatible way.
rpm --verbose --querytags is missing in rpm 4.0.4, and is undocumented
feature of modern rpm. Should we care about compatibility in this
particular case?
--
WBR,
Vladimir D. Seleznev
Подробная информация о списке рассылки Devel