[devel] [PATCH] Verbose QueryTags prints whether tag is an extension

Dmitry V. Levin ldv на altlinux.org
Пн Апр 13 21:42:18 MSK 2020


On Mon, Apr 13, 2020 at 09:20:21PM +0300, Vladimir D. Seleznev wrote:
> 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?

Can we rely on any particular output format of this undocumented feature?


-- 
ldv


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