From: Alexander Wirt Date: Mon, 13 Jun 2011 09:07:25 +0000 (+0200) Subject: Code cleanup and use less as pager X-Git-Tag: v0.5.2~3 X-Git-Url: http://git.grml.org/?p=grml-tips.git;a=commitdiff_plain;h=2ab2a3b950a3e00a552658d20d4026a05977f8aa Code cleanup and use less as pager --- diff --git a/grml-tips b/grml-tips index fc9fd39..161bc9d 100755 --- a/grml-tips +++ b/grml-tips @@ -10,6 +10,7 @@ use strict; use Pod::Usage; +use feature 'say'; use Term::ReadKey; use Time::HiRes; use LWP::UserAgent; @@ -79,33 +80,37 @@ if ($pattern eq '') { } my @tips; -my $fh; -if (! open ($fh, '<', "$grml_tips")) { - print "Error: $grml_tips not found.\nExiting."; +if (! open (my $fh, '<', "$grml_tips")) { + say STDERR "Error: File \"$grml_tips\" not found."; + say STDERR "Exiting."; exit -1; -} +} else { + my $tip = ''; -my $tip = ''; -my $tip_flag = 0; - -while (my $line = <$fh>) { - if ($line !~ /^-- $/) { - $tip .= $line; - } else { - if ( "$tip" =~ /$pattern/mi ) { - $tip .= $line; - print "$tip"; - $tip = ''; - $tip_flag = 1; - } else { - $tip = ''; + while (my $line = <$fh>) { + if ($line !~ /^-- $/) { + $tip .= $line; + } else { + if ( $tip =~ /$pattern/mi ) { + $tip .= $line; + push @tips, $tip; + $tip = ''; + } else { + $tip = ''; + } + } } - } + close($fh); } -close($fh); -if (!$tip_flag) { - print "Sorry, could not find a tip for '$pattern'. :-(\n\n", +if (@tips) { + if (! open (my $fh, '|-', 'less -FRX') ) { + say @tips; + } else { + say $fh @tips; + } +}else { + say "Sorry, could not find a tip for '$pattern'. :-(\n\n", "Do you want to submit the keyword '$pattern' to grml's keyword database?\n", "The grml team will write tips for the most requested and useful keywords.\n", "To use and contribute to this feature you'll need a working networking connection.\n", @@ -145,12 +150,12 @@ if (!$tip_flag) { if ($res->is_success) { my $content = $res->decoded_content; if ($content =~ /Submission received/) { - print "Keyword '$pattern' has been submitted to grml's keyword database.\nThanks.\n"; + say "Keyword '$pattern' has been submitted to grml's keyword database.\nThanks."; } else { - print "Your pattern could not be submitted.\n", + say "Your pattern could not be submitted.\n", "Please file a bug against grml-tips at ", "http://bts.grml.org/\n", - "Thanks!\n"; + "Thanks!"; } } else { print "Could not submitt '$pattern': " . $res->status_line . "\n";