[pacman-dev] [PATCH v2 2/6] pacsearch: indexing by 'name version' instead of 'name'

Andrew Gregory andrew.gregory.8 at gmail.com
Thu Feb 6 21:07:58 EST 2014


On 02/05/14 at 04:15pm, Pierre Neidhardt wrote:
> On 14-02-05 09:15:28, Andrew Gregory wrote:
> > On 02/04/14 at 12:16am, Pierre Neidhardt wrote:
> > > Signed-off-by: Pierre Neidhardt <ambrevar at gmail.com>
> > > ---
> > >  contrib/pacsearch.in | 6 +++---
> > >  1 file changed, 3 insertions(+), 3 deletions(-)
> > 
> > What is the gain here?  The pacman output already includes the local
> > version in the sync results if it's different from the sync version.
> 
> Not sure I understood your comment correctly. In the old pacsearch pkgname
> and pkgver were stored in the same cell. When I changed that later on, I
> inadvertently introduced a regression... This fixes it.

Ah, I see.  That would have been a good detail to include in the
commit message.

> > > diff --git a/contrib/pacsearch.in b/contrib/pacsearch.in
> > > index 71e0107..d3d461f 100644
> > > --- a/contrib/pacsearch.in
> > > +++ b/contrib/pacsearch.in
> > > @@ -124,7 +124,7 @@ foreach $_ (@syncpkgs) {
> > >  	# add a last field that indicates original order
> > >  	push (@pkgfields, $cnt++);
> > >  	# add each sync pkg by name/ver to a hash table for quick lookup
> > > -	$allpkgs{$pkgfields[1]} = [ @pkgfields ];
> > > +	$allpkgs{$pkgfields[1] . $pkgfields[2]} = [ @pkgfields ];
> > >  }
> > >  
> > >  my $queryout = `pacman -Qs '@ARGV'`;
> > > @@ -141,14 +141,14 @@ foreach $_ (@querypkgs) {
> > >  	# skip any non-matching line
> > >  	next if not defined $pkgfields[1];
> > >  	# check if the package was listed in the sync out
> > > -	if (not exists $allpkgs{$pkgfields[1]}) {
> > > +	if (not exists $allpkgs{$pkgfields[1] . $pkgfields[2]}) {
> > >  		# since 'group' is optional, we should fill it in if necessary
> > >  		$pkgfields[3] = "" if not defined $pkgfields[3];
> > >  		$pkgfields[4] = "[$LC_INSTALLED]";
> > >  		# add a last field that indicates original order (after sync)
> > >  		push (@pkgfields, $cnt++);
> > >  		# add our local-only package to the hash
> > > -		$allpkgs{$pkgfields[1]} = [ @pkgfields ];
> > > +		$allpkgs{$pkgfields[1] . $pkgfields[2]} = [ @pkgfields ];
> > >  	}
> > >  }
> > >  
> > > -- 
> > > 1.8.5.3


More information about the pacman-dev mailing list