X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FTie%2FHandle.pm;h=33b22210f9b767e59848cbd9d3295875f922f8ce;hb=eb31b78e700ea0345396e27142faff79fd75f356;hp=42d0834ed8af5cc3c2c3df063e2230795208ceb3;hpb=7e6d00f88633359fc96f8d1e8d7c3aa419c0d976;p=p5sagit%2Fp5-mst-13.2.git diff --git a/lib/Tie/Handle.pm b/lib/Tie/Handle.pm index 42d0834..33b2221 100644 --- a/lib/Tie/Handle.pm +++ b/lib/Tie/Handle.pm @@ -1,7 +1,7 @@ package Tie::Handle; -use 5.005_64; -our $VERSION = '1.0'; +use 5.006_001; +our $VERSION = '4.1'; =head1 NAME @@ -12,7 +12,7 @@ Tie::Handle, Tie::StdHandle - base class definitions for tied handles package NewHandle; require Tie::Handle; - @ISA = (Tie::Handle); + @ISA = qw(Tie::Handle); sub READ { ... } # Provide a needed method sub TIEHANDLE { ... } # Overrides inherited method @@ -33,7 +33,7 @@ For developers wishing to write their own tied-handle classes, the methods are summarized below. The L section not only documents these, but has sample code as well: -=over +=over 4 =item TIEHANDLE classname, LIST @@ -105,6 +105,15 @@ destruction of an instance. The L section contains an example of tying handles. +=head1 COMPATIBILITY + +This version of Tie::Handle is neither related to nor compatible with +the Tie::Handle (3.0) module available on CPAN. It was due to an +accident that two modules with the same name appeared. The namespace +clash has been cleared in favor of this module that comes with the +perl core in September 2000 and accordingly the version number has +been bumped up to 4.0. + =cut use Carp; @@ -183,10 +192,10 @@ sub WRITE { sub CLOSE { my $pkg = ref $_[0]; croak "$pkg doesn't define a CLOSE method"; -} +} package Tie::StdHandle; -our @ISA = 'Tie::Handle'; +our @ISA = 'Tie::Handle'; use Carp; sub TIEHANDLE @@ -196,7 +205,7 @@ sub TIEHANDLE bless $fh,$class; $fh->OPEN(@_) if (@_); return $fh; -} +} sub EOF { eof($_[0]) } sub TELL { tell($_[0]) } @@ -206,9 +215,9 @@ sub CLOSE { close($_[0]) } sub BINMODE { binmode($_[0]) } sub OPEN -{ +{ $_[0]->CLOSE if defined($_[0]->FILENO); - open($_[0],$_[1]); + @_ == 2 ? open($_[0], $_[1]) : open($_[0], $_[1], $_[2]); } sub READ { read($_[0],$_[1],$_[2]) } @@ -216,7 +225,7 @@ sub READLINE { my $fh = $_[0]; <$fh> } sub GETC { getc($_[0]) } sub WRITE -{ +{ my $fh = $_[0]; print $fh substr($_[1],0,$_[2]) }