diff options
author | Marc Espie <espie@cvs.openbsd.org> | 2005-07-20 15:35:34 +0000 |
---|---|---|
committer | Marc Espie <espie@cvs.openbsd.org> | 2005-07-20 15:35:34 +0000 |
commit | 9801da3bee08e9c1f6715129d5a09f706fc7ff0f (patch) | |
tree | 3f06612da865fa072ae4812d5ad852c7bf31366b | |
parent | db9db15cec9e4232db305eebb209c41f667f4dcf (diff) |
support for fifo and character/block devices.
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/Ustar.pm | 80 |
1 files changed, 76 insertions, 4 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/Ustar.pm b/usr.sbin/pkg_add/OpenBSD/Ustar.pm index 6f3d1bc8c38..8224b80e6c2 100644 --- a/usr.sbin/pkg_add/OpenBSD/Ustar.pm +++ b/usr.sbin/pkg_add/OpenBSD/Ustar.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: Ustar.pm,v 1.29 2005/06/26 15:39:19 espie Exp $ +# $OpenBSD: Ustar.pm,v 1.30 2005/07/20 15:35:33 espie Exp $ # # Copyright (c) 2002-2004 Marc Espie <espie@openbsd.org> # @@ -107,6 +107,8 @@ sub next $uname =~ s/\0*$//; $gname =~ s/\0*$//; $linkname =~ s/\0*$//; + $major = oct($major); + $minor = oct($minor); $uid = oct($uid); $gid = oct($gid); $uid = $uidcache->lookup($uname, $uid); @@ -128,6 +130,8 @@ sub next gname => $gname, gid => $gid, size => $size, + major => $major, + minor => $minor, archive => $self, destdir => $self->{destdir} }; @@ -139,6 +143,12 @@ sub next bless $result, 'OpenBSD::Ustar::SoftLink'; } elsif ($type eq FILE || $type eq FILE1) { bless $result, 'OpenBSD::Ustar::File'; + } elsif ($type eq FIFO) { + bless $result, 'OpenBSD::Ustar::Fifo'; + } elsif ($type eq 'CHARDEVICE') { + bless $result, 'OpenBSD::Ustar::CharDevice'; + } elsif ($type eq 'BLOCKDEVICE') { + bless $result, 'OpenBSD::Ustar::BlockDevice'; } else { die "Unsupported type"; } @@ -178,6 +188,14 @@ sub mkheader if (!$entry->isFile()) { $size = 0; } + my ($major, $minor); + if ($entry->isDevice()) { + $major = $entry->{major}; + $minor = $entry->{minor}; + } else { + $major = 0; + $minor = 0; + } if (defined $entry->{cwd}) { my $cwd = $entry->{cwd}; $cwd.='/' unless $cwd =~ m/\/$/; @@ -217,7 +235,8 @@ sub mkheader 'ustar', '00', $entry->{uname}, $entry->{gname}, - "\0", "\0", + sprintf("%07o", $major), + sprintf("%07o", $minor), $prefix, "\0"); $cksum = sprintf("%07o", unpack("%C*", $header)); } @@ -231,8 +250,8 @@ sub prepare my $destdir = $self->{destdir}; my $realname = "$destdir/$filename"; - my ($dev, $ino, $mode, $uid, $gid, $size, $mtime) = - (lstat $realname)[0,1,2,4,5,7,9]; + my ($dev, $ino, $mode, $uid, $gid, $rdev, $size, $mtime) = + (lstat $realname)[0,1,2,4,5,6, 7,9]; my $entry = { key => "$dev/$ino", @@ -245,6 +264,8 @@ sub prepare mtime => $mtime, uname => $unamecache->lookup($uid), gname => $gnamecache->lookup($gid), + major => $rdev/256, + minor => $rdev%256, archive => $self, destdir => $self->{destdir} }; @@ -255,6 +276,12 @@ sub prepare } elsif (-l $realname) { $entry->{linkname} = readlink($realname); bless $entry, "OpenBSD::Ustar::SoftLink"; + } elsif (-p _) { + bless $entry, "OpenBSD::Ustar::Fifo"; + } elsif (-c _) { + bless $entry, "OpenBSD::Ustar::CharDevice"; + } elsif (-b _) { + bless $entry, "OpenBSD::Ustar::BlockDevice"; } elsif (-d _) { bless $entry, "OpenBSD::Ustar::Dir"; } else { @@ -364,6 +391,8 @@ sub copy sub isDir() { 0 } sub isFile() { 0 } +sub isDevice() { 0 } +sub isFifo() { 0 } sub isLink() { 0 } sub isSymLink() { 0 } sub isHardLink() { 0 } @@ -405,6 +434,7 @@ sub resolve_links if (defined $arc->{key}->{$k}) { $self->{linkname} = $arc->{key}->{$k}; } else { + print join("\n", keys(%{$arc->{key}})), "\n"; die "Can't copy link over: original for $k NOT available\n"; } } @@ -430,6 +460,48 @@ sub isSymLink() { 1 } sub type() { OpenBSD::Ustar::SOFTLINK } +package OpenBSD::Ustar::Fifo; +our @ISA=qw(OpenBSD::Ustar::Object); + +sub create +{ + my $self = shift; + $self->make_basedir($self->{name}); + require POSIX; + POSIX::mkfifo($self->{destdir}.$self->{name}, $self->{mode}) or + die "Can't create fifo $self->{name}: $!"; + $self->SUPER::set_modes(); +} + +sub isFifo() { 1 } +sub type() { OpenBSD::Ustar::FIFO } + +package OpenBSD::Ustar::BlockDevice; +our @ISA=qw(OpenBSD::Ustar::Object); + +sub create +{ + my $self = shift; + $self->make_basedir($self->{name}); + system('/sbin/mknod', 'mknod', '-m', $self->{mode}, $self->{destdir}.$self->{name}, 'b', $self->{major}, $self->{minor}); +} + +sub isDevice() { 1 } +sub type() { OpenBSD::Ustar::BLOCKDEVICE } + +package OpenBSD::Ustar::CharDevice; +our @ISA=qw(OpenBSD::Ustar::Object); + +sub create +{ + my $self = shift; + $self->make_basedir($self->{name}); + system('/sbin/mknod', 'mknod', '-m', $self->{mode}, $self->{destdir}.$self->{name}, 'b', $self->{major}, $self->{minor}); +} + +sub isDevice() { 1 } +sub type() { OpenBSD::Ustar::BLOCKDEVICE } + package OpenBSD::CompactWriter; use constant { |