i3-dmenu-desktop: don’t use smartmatch (it’s experimental)

This commit should not change functionality at all (famous last words).
This commit is contained in:
Michael Stapelberg 2014-05-15 22:52:18 +02:00
parent b69b3fc572
commit 0d50658fa7
1 changed files with 12 additions and 8 deletions

View File

@ -1,7 +1,7 @@
#!/usr/bin/env perl #!/usr/bin/env perl
# vim:ts=4:sw=4:expandtab # vim:ts=4:sw=4:expandtab
# #
# © 2012-2013 Michael Stapelberg # © 2012-2014 Michael Stapelberg
# #
# No dependencies except for perl ≥ v5.10 # No dependencies except for perl ≥ v5.10
@ -55,8 +55,12 @@ my $result = GetOptions(
die "Could not parse command line options" unless $result; die "Could not parse command line options" unless $result;
# Filter entry types and set default type(s) if none selected # Filter entry types and set default type(s) if none selected
my @valid_types = ('name', 'command', 'filename'); my $valid_types = {
@entry_types = grep { $_ ~~ @valid_types } @entry_types; name => 1,
command => 1,
filename => 1,
};
@entry_types = grep { exists($valid_types->{$_}) } @entry_types;
@entry_types = ('name', 'command') unless @entry_types; @entry_types = ('name', 'command') unless @entry_types;
# ┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓ # ┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
@ -257,7 +261,7 @@ for my $app (keys %apps) {
} }
} }
if ('name' ~~ @entry_types) { if ((scalar grep { $_ eq 'name' } @entry_types) > 0) {
if (exists($choices{$name})) { if (exists($choices{$name})) {
# There are two .desktop files which contain the same “Name” value. # There are two .desktop files which contain the same “Name” value.
# Im not sure if that is allowed to happen, but we disambiguate the # Im not sure if that is allowed to happen, but we disambiguate the
@ -273,22 +277,22 @@ for my $app (keys %apps) {
$choices{$name} = $app; $choices{$name} = $app;
} }
if ('command' ~~ @entry_types) { if ((scalar grep { $_ eq 'command' } @entry_types) > 0) {
my ($command) = split(' ', $apps{$app}->{Exec}); my ($command) = split(' ', $apps{$app}->{Exec});
# Dont add “geany” if “Geany” is already present. # Dont add “geany” if “Geany” is already present.
my @keys = map { lc } keys %choices; my @keys = map { lc } keys %choices;
next if lc(basename($command)) ~~ @keys; next if (scalar grep { $_ eq lc(basename($command)) } @keys) > 0;
$choices{basename($command)} = $app; $choices{basename($command)} = $app;
} }
if ('filename' ~~ @entry_types) { if ((scalar grep { $_ eq 'filename' } @entry_types) > 0) {
my $filename = basename($app, '.desktop'); my $filename = basename($app, '.desktop');
# Dont add “geany” if “Geany” is already present. # Dont add “geany” if “Geany” is already present.
my @keys = map { lc } keys %choices; my @keys = map { lc } keys %choices;
next if lc($filename) ~~ @keys; next if (scalar grep { $_ eq lc($filename) } @keys) > 0;
$choices{$filename} = $app; $choices{$filename} = $app;
} }