in reply to what is the purpose of Tie::File

This node falls below the community's threshold of quality. You may see it by logging in.

Replies are listed 'Best First'.
Re^2: what is the purpose of Tie::File
by Lotus1 (Vicar) on Nov 11, 2012 at 23:02 UTC
    • Using perl -l gives you autochomp which Tie::File has built in. From your other nodes I see you use this frequently to add a newline when you print.
    • $^W = 1; and then use Warnings; a few lines later?
    • Using autodie means the script stops after the unlink line even if there is a file to delete. Why not just die if -e $file; ?
    • Does $| = 1; have any effect on Tie::File? With the option memory => 0 it is already not cacheing anything.

    I don't understand the point of this code. Tying to a file that doesn't exist, adding a line, then deleting the newly created file doesn't seem useful.

        What doesn't make sense to me is how a node that has so many obvious code problems can muster up a positive node reputation.


        Dave

Re^2: what is the purpose of Tie::File
by Anonymous Monk on Nov 11, 2012 at 09:11 UTC

    Having a glitch of some kind---code is coming:). Here:

    How delightfully refreshing, here's mine

    P.S.

    It now runs great!

    #!/usr/bin/perl -l -- # really ensures warnings BEGIN { $^W = 1; } BEGIN { ${^WARNING_BITS} = 0; } BEGIN { $^H |= 0x00000002 |0x00000200 |0x00000400; } BEGIN { $/ = "\n"; $\ = "\n"; } BEGIN { BEGIN { use Carp::Always; use Carp qw/ confess /; sub unlink { my $goners ; while(@_){ my $file = shift; unlink $file or confess "Can't unlink('$file'): $!"; $goners++; } return $goners; } } } local $SIG{__DIE__} = sub { confess "Uncaught exception: @_" unless $^S; }; use strict; use warnings; use autodie; use Tie::File; my $file = "file.txt"; 1 while unlink $file; my $o = tie my @lines, 'Tie::Tile', $file, memory => 0; for (@lines) { $lines[42] = "something else is here now"; print $lines[42]; #line 42 is now "something else is here now". } END { END { END{ END { undef $o; untie @lines; 1 while unlink $file; #really clears and empties everything. } } } } __END__

    The output is twice as much