diff options
author | Daniel Friesel <derf@derf.homelinux.org> | 2009-06-18 18:24:31 +0200 |
---|---|---|
committer | Daniel Friesel <derf@derf.homelinux.org> | 2009-06-18 18:24:31 +0200 |
commit | a16ca4cce9fa06ef37ff56ffee69b320fe071829 (patch) | |
tree | 40cc8f52a55518821081b68f078ae11e9f201c07 /bin | |
parent | 49bd7c14448a3dea7067da9b52ddddee4c8ab927 (diff) |
checklinks: Use msglevel instead of $quiet
Diffstat (limited to 'bin')
-rwxr-xr-x | bin/checklinks | 25 |
1 files changed, 13 insertions, 12 deletions
diff --git a/bin/checklinks b/bin/checklinks index 80b5d00..8e478b3 100755 --- a/bin/checklinks +++ b/bin/checklinks @@ -8,7 +8,7 @@ use Term::ANSIColor; my $base = $ENV{HOME}; my ($type, $src, $dst); -my $quiet = 0; +my $msglevel = 0; my $remove = 0; my %substitute; my $linkfile; @@ -22,7 +22,7 @@ if (-f '.links') { } GetOptions( - 'q|quiet' => \$quiet, + 'q|quiet' => sub {$msglevel = 1}, 'r|remove' => \$remove, 'p|parameter=s' => \%substitute, ); @@ -61,21 +61,21 @@ sub check_symlink { mkdirs($src); if (not -l "$base/$src" and not -e "$base/$src") { symlink($dst, "$base/$src"); - print_format('created', $src, $dst, 'cyan'); + print_format('created', $src, $dst, 'cyan', 1); } elsif (-l "$base/$src" and readlink("$base/$src") eq $dst) { - print_format('ok', $src, $dst, 'green') unless $quiet; + print_format('ok', $src, $dst, 'green', 0); } elsif (-l "$base/$src" and readlink("$base/$src") eq "$base/$dst") { - print_format('absolute', $src, $dst, 'yellow') unless $quiet; + print_format('absolute', $src, $dst, 'yellow', 0); } elsif (not -l "$base/$src" and -e "$base/$src") { - print colored ("$base/$src: File exists but is not a symlink. Not updating.\n", 'bold red'); + print_format('EXISTS', $src, $dst, 'bold red', 2); } elsif (-l "$base/$src") { unlink("$base/$src"); symlink($dst, "$base/$src"); - print_format('fixed', $src, $dst, 'cyan'); + print_format('fixed', $src, $dst, 'cyan', 1); } } @@ -85,19 +85,19 @@ sub check_hardlink { mkdirs($src); if (not -e "$base/$dst") { - print_format('no dst!!', $src, $dst, 'red bold'); + print_format('no dest', $src, $dst, 'red bold', 2); } elsif (not -f "$base/$src") { link("$base/$dst", "$base/$src") or warn($!); - print_format('created', $src, $dst, 'cyan'); + print_format('created', $src, $dst, 'cyan', 1); } elsif ((stat("$base/$src"))[1] != (stat("$base/$dst"))[1]) { unlink("$base/$src"); link("$base/$dst", "$base/$src") or warn($!); - print_format('updated', $src, $dst, 'cyan'); + print_format('updated', $src, $dst, 'cyan', 1); } elsif ((stat("$base/$src"))[1] == (stat("$base/$dst"))[1]) { - print_format('ok', $src, $dst, 'green') unless $quiet; + print_format('ok', $src, $dst, 'green', 0); } } @@ -117,8 +117,9 @@ sub mkdirs { } sub print_format { - my ($message, $src, $dst, $color) = @_; + my ($message, $src, $dst, $color, $level) = @_; + return if ($level < $msglevel); if (defined($color)) { printf(colored('%-9s', $color), $message); } else { |