From 3dccce1411f644a67393d5805ade0c34c7fc0041 Mon Sep 17 00:00:00 2001 From: Kornel Benko Date: Sat, 22 Aug 2020 16:20:22 +0200 Subject: [PATCH] Tools(listFontWithLang.pl): Ignore white space while checking font name This allows for instance to find 'Deja Vu' also if searching for 'dejavu' --- development/tools/listFontWithLang.pl | 24 ++++++++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/development/tools/listFontWithLang.pl b/development/tools/listFontWithLang.pl index de27c1b064..64beba89ff 100644 --- a/development/tools/listFontWithLang.pl +++ b/development/tools/listFontWithLang.pl @@ -239,6 +239,26 @@ for my $charFld ("Contains", "NContains") { } } +for my $fn ("FontName", "NFontName") { + if (defined($options{$fn})) { + # split each entry and make a compiled regex + # Allow space between all characters + for my $e (@{$options{$fn}}) { + my $u = decode('utf-8', $e); + my $fill = decode('utf-8', "\\s?"); + my @u = split(//, $u); + my @ud = (); + for my $c (@u) { + push(@ud, $c, $fill); + } + my $ud = join('', @ud); + my $e1 = encode('utf-8', $ud); + $e1 =~ s/\\s\?$//; + $e = qr/$e1/i; + } + } +} + my $cmd = "fc-list"; if (defined($langs[0])) { $cmd .= " :lang=" . join(',', @langs); @@ -522,12 +542,12 @@ if (open(FI, "$cmd |")) { ($fontname, $style) = &buildFontName($family, $style); if (defined($options{NFontName})) { for my $fn (@{$options{NFontName}}) { - next NXTLINE if ($fontname =~ /$fn/i); + next NXTLINE if ($fontname =~ $fn); } } if (defined($options{FontName})) { for my $fn (@{$options{FontName}}) { - next NXTLINE if ($fontname !~ /$fn/i); + next NXTLINE if ($fontname !~ $fn); } } my @charlist = (); -- 2.39.2