X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=script%2Fpublic-inbox-watch;h=e07c30beaadc84c4405d394d8fa4fa0ebdc3959c;hb=be4d92e74dd0b1c8de85bc08c3c522af2d8d8656;hp=bb655929fdbf0050a5f37d4ed622eab759962114;hpb=9a38d54754c724c5f81e8dc000bd42dbeddc39a6;p=public-inbox.git diff --git a/script/public-inbox-watch b/script/public-inbox-watch index bb655929..e07c30be 100755 --- a/script/public-inbox-watch +++ b/script/public-inbox-watch @@ -1,5 +1,5 @@ #!/usr/bin/perl -w -# Copyright (C) 2016 all contributors +# Copyright (C) 2016-2018 all contributors # License: AGPL-3.0+ use strict; use warnings; @@ -8,14 +8,19 @@ use PublicInbox::Config; my ($config, $watch_md); my $reload = sub { $config = PublicInbox::Config->new; + $watch_md->quit if $watch_md; $watch_md = PublicInbox::WatchMaildir->new($config); }; $reload->(); if ($watch_md) { - my $scan = sub { $watch_md->scan if $watch_md }; + my $scan = sub { $watch_md->trigger_scan('full') if $watch_md }; $SIG{HUP} = $reload; $SIG{USR1} = $scan; $SIG{ALRM} = sub { $SIG{ALRM} = 'DEFAULT'; $scan->() }; + $SIG{QUIT} = $SIG{TERM} = $SIG{INT} = sub { + $watch_md->quit if $watch_md; + $watch_md = undef; + }; alarm(1); - $watch_md->watch; + $watch_md->watch while ($watch_md); }