Beefy Boxes and Bandwidth Generously Provided by pair Networks
Pathologically Eclectic Rubbish Lister

Re^6: A DWIM too far?

by BrowserUk (Patriarch)
on Jun 18, 2004 at 05:26 UTC ( #367866=note: print w/replies, xml ) Need Help??

in reply to Re^5: A DWIM too far?
in thread A DWIM too far?

It doesn't seem like such a fundamental difference to me.

Then you either haven't taken the time to think before commiting to that opinion, or you simply haven't bothered to consider the possibility that a unix behaviour could possibly be flawed.

Modifying the wrong hash element in an inhereted object can cause data loss.

Modifying the wrong hash element is entirely within the control of my application.

Overwriting or deleting a file created by a different application (or vice versa) is not.

Changing a global sub (such as you do here) can cause serious problems if not done with care.

I didn't "do it". I simply reminded someone else how Perl would let them do it, should they choose to.

And besides, all the behaviors of an operating system are controlled entirely within the auspices of one computer.

And if the files resides on a network drive or NFS mounted filesystem?

The difference I see is not fundamental, it is one of likelihood. The chances of problems caused by permissive behavior are less at the application level than the operating system level, but they are still there.

What makes the difference fundemental is that I can code my application to test for and avoid modifying the wrong hash element.

To safely rename a file requires that the OS detect and inform me about potential collisions, as any test I code into my application opens a race condition on a multi-tasking system.

My OS does this at the system API level. The thing that took me by surprise was that the Perl implementation chose to override this.

Examine what is said, not who speaks.
"Efficiency is intelligent laziness." -David Dunham
"Think for yourself!" - Abigail
"Memory, processor, disk in that order on the hardware side. Algorithm, algoritm, algorithm on the code side." - tachyon

Log In?

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://367866]
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others contemplating the Monastery: (2)
As of 2022-05-29 08:55 GMT
Find Nodes?
    Voting Booth?
    Do you prefer to work remotely?

    Results (101 votes). Check out past polls.