in reply to Another way to avoid File::Find
First, the HUP signal might not be delivered one-to-one. Since the "notify the process that HUP has been received" is just a one-bit value in the process table, if the process doesn't get woken up quickly enough, two HUPs will be delivered as only one hit.
Second, if you kill the child process before reading the names, you might not actually get to read the names, because that will all depend on buffering and flushing and such.
Thus, I suggest you merely use an ordinary loop, and when you've read the Nth name, just close the handle. On the next write, the child will die anyway. If you really want to optimize that, read in the loop, and then kill the child when you've already read the name.
Or, just write the loop using File::Find (no child process), because I bet that will be within striking distance of using the child anyway, and you can get precisely the semantics you want.
-- Randal L. Schwartz, Perl hacker
Be sure to read my standard disclaimer if this is a reply.
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^2: Another way to avoid File::Find
by graff (Chancellor) on Nov 18, 2006 at 20:01 UTC | |
by MidLifeXis (Monsignor) on Nov 20, 2006 at 18:41 UTC |