11.5. Reopening a Standard Filehandle
We mentioned earlier that if you were to reopen a
filehandle
(that is, if you were to open a filehandle FRED
when you've already got an open filehandle named
FRED, say), the old one would be closed for you
automatically. And we said that you shouldn't reuse one of the
six standard filehandle names unless you intended to get that
one's special features. And we also said that the messages from
die and warn, along with
Perl's internally generated complaints, go automatically to
STDERR. If you put those three pieces of
information together, you now have an idea about how you could send
error messages to a file, rather than to
your program's standard error stream:[261]
# Send errors to my private error log
open STDERR, ">>/home/barney/.error_log"
or die "Can't open error log for append: $!";
After reopening STDERR, any error messages from
Perl will go into the new file. But what happens if the or
die part is executed -- where will
that message go, if the new file couldn't
be opened to accept the messages?
The answer is that if one of the three system
filehandles -- STDIN,
STDOUT, or STDERR -- fails
to be reopened, Perl kindly restores the original one.[262] That is, Perl closes the
original one (of those three) only when it sees that opening the new
connection is successful. Thus, this technique could be used to
redirect any (or all) of those three system filehandles from inside
your program,[263] almost
as if the program had been run with that I/O redirection from the
shell in the first place.
 |  |  | 11.4. Using Filehandles |  | 11.6. File Tests |
Copyright © 2002 O'Reilly & Associates. All rights reserved.
|