From cdf4df2126bb0fe5c33bcb77992f3877da290c17 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?John=20Ankarstr=C3=B6m?= Date: Wed, 19 May 2021 12:15:31 +0200 Subject: Improve SIGINT handling It should only be active for the main loop. --- src/pop | 39 ++++++++++++++++++++++++--------------- 1 file changed, 24 insertions(+), 15 deletions(-) (limited to 'src/pop') diff --git a/src/pop b/src/pop index 826a975..3134c14 100755 --- a/src/pop +++ b/src/pop @@ -10,10 +10,6 @@ use POSIX; use Term::ReadKey; use Sys::Hostname; -# Handle SIGINT -my $sigint = 0; -$SIG{INT} = sub { $sigint = 1 }; - # Flush STDERR select STDERR; $|++; select STDOUT; @@ -41,20 +37,36 @@ open $mbox, '>>', $ARGV[0] or die "Could not open $ARGV[0]: $!"; open $index, '>>', $ARGV[1] or die "Could not open $ARGV[1]: $!"; # Get POP3 server, username and password -print 'Enter password: '; -ReadMode 'noecho'; -chomp(my $password = ReadLine(0)); -print "\n"; -ReadMode 0; +my $server = 'pop3.mailbox.org'; +my $ssl = 1; +my $timeout = 5; +my $username = 'john@ankarstrom.se'; +my $password; + +if (not $password) { + print 'Enter password: '; + ReadMode 'noecho'; + chomp($password = ReadLine(0)); + print "\n"; + ReadMode 0; +} # Connect to POP3 server -my $pop = Net::POP3->new('pop3.mailbox.org', SSL => 1, Timeout => 5); -$pop->login('john@ankarstrom.se', $password) or die "$!"; +my $pop = Net::POP3->new($server, SSL => $ssl, Timeout => $timeout) + or die "Could not connect to POP3 server $server: $!\n"; +$pop->login($username, $password) or die "Could not log into server\n"; # Retrieve ids and uids of all messages my @ids = sort { $a <=> $b } keys %{$pop->list}; my %uids = %{$pop->uidl}; +# Handle SIGINT +my $sigint = 0; +$SIG{INT} = sub { + print STDERR "\nSafely ending retrieval...\n"; + $sigint = 1; +}; + # Append new messages to mbox and index files chomp(my $date = asctime(localtime(time))); my $offset = 0; @@ -119,10 +131,7 @@ Offset: $offset INDEX - if ($sigint) { - print STDERR "\n"; - exit 130; - } + exit 130 if $sigint; # Set offset for next message $offset += $content_length + 1; -- cgit v1.2.3