diff options
author | Marc Espie <espie@cvs.openbsd.org> | 2010-06-15 08:26:40 +0000 |
---|---|---|
committer | Marc Espie <espie@cvs.openbsd.org> | 2010-06-15 08:26:40 +0000 |
commit | e9543a25f760416cd896f98c7a8e9ebb72b0f956 (patch) | |
tree | 790547109c666da81ad863b3d1f2607918730f05 /usr.sbin/pkg_add/OpenBSD/Error.pm | |
parent | dc2af675bfd1f4eb14a47aa97b59c8b92d6e5419 (diff) |
more printing changes.
move log operations into their own file, since they're used outside of
pkg_add/pkg_delete by pkg_check.
move all system stuff to State, so that printing can be localized/controlled.
Create primitives _print, _errprint, _fatal for overriding output, without
localization.
Accordingly, move a lot of code out of Error. We should also move Unlink and
Copy eventually.
Diffstat (limited to 'usr.sbin/pkg_add/OpenBSD/Error.pm')
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/Error.pm | 127 |
1 files changed, 2 insertions, 125 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/Error.pm b/usr.sbin/pkg_add/OpenBSD/Error.pm index 9d078c2c23c..edcd82ec4eb 100644 --- a/usr.sbin/pkg_add/OpenBSD/Error.pm +++ b/usr.sbin/pkg_add/OpenBSD/Error.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: Error.pm,v 1.25 2010/05/10 09:17:55 espie Exp $ +# $OpenBSD: Error.pm,v 1.26 2010/06/15 08:26:39 espie Exp $ # # Copyright (c) 2004-2010 Marc Espie <espie@openbsd.org> # @@ -63,8 +63,7 @@ __PACKAGE__->reset; package OpenBSD::Error; require Exporter; our @ISA=qw(Exporter); -our @EXPORT=qw(System VSystem Copy Unlink Fatal Warn Usage set_usage - try throw catch catchall rethrow); +our @EXPORT=qw(Copy Unlink try throw catch catchall rethrow); our ($FileName, $Line, $FullMessage); @@ -128,32 +127,6 @@ sub child_error } } -sub System -{ - my $r = system(@_); - if ($r != 0) { - print "system(", join(", ", @_), ") failed: ", child_error(), - "\n"; - } - return $r; -} - -sub VSystem -{ - my $verbose = shift; - if (!$verbose) { - &System; - } else { - print "Running ", join(' ', @_); - my $r = system(@_); - if ($r != 0) { - print "... failed: ", child_error(), "\n"; - } else { - print "\n"; - } - } -} - sub Copy { require File::Copy; @@ -177,102 +150,6 @@ sub Unlink return $r; } -sub Fatal -{ - croak @_; -} - -sub Warn -{ - print STDERR @_; -} - -sub new -{ - my $class = shift; - bless {messages=>{}, dirs_okay=>{}}, $class; -} - -sub set_pkgname -{ - my ($self, $pkgname) = @_; - $self->{pkgname} = $pkgname; - $self->{output} = $self->{messages}->{$pkgname} //= []; -} - -sub warn -{ - &OpenBSD::Error::print; -} - -sub fatal -{ - my $self = shift; - if (defined $self->{pkgname}) { - unshift @_, $self->{pkgname}, ':'; - } - croak @_; -} - -sub print -{ - my $self = shift; - push(@{$self->{output}}, join('', @_)); -} - -sub delayed_output -{ - my $self = shift; - for my $pkg (sort keys %{$self->{messages}}) { - my $msgs = $self->{messages}->{$pkg}; - if (@$msgs > 0) { - print "--- $pkg -------------------\n"; - print @$msgs; - } - } - $self->{messages} = {}; -} - -sub system -{ - my $self = shift; - if (open(my $grab, "-|", @_)) { - my $_; - while (<$grab>) { - $self->print($_); - } - if (!close $grab) { - $self->print("system(", join(", ", @_), ") failed: $! ", - child_error(), "\n"); - } - return $?; - } else { - $self->print("system(", join(", ", @_), - ") was not run: $!", child_error(), "\n"); - } -} - -my @usage_line; - -sub set_usage -{ - @usage_line = @_; -} - -sub Usage -{ - my $code = 0; - if (@_) { - print STDERR "$0: ", @_, "\n"; - $code = 1; - } - print STDERR "Usage: ", shift(@usage_line), "\n"; - for my $l (@usage_line) { - print STDERR " $l\n"; - } - exit($code); -} - sub dienow { my ($error, $handler) = @_; |