Harmful perhaps, but personally _always_ run my code with 'warnings' on. I've more recently, considered using 'strict' to be the way to go too.
My reasoning is quite simple. It forces me to right 'good' code and not just rely on perl to let me be lazy.
It has also, on occasion, showed me place where I was doing very silly things.
Chasing a warning that makes no sense can be irritating, but then again, so can chasing a bug which makes even less sense....
(My personal favourite was creating a pointer, instead of an array in C. The code would run fine for the first iteration, however, subsequent iterations would _always_ crash. It took me ages to spot why...)
--
It's not pessimism if there is a worse option, it's not paranoia when they are and it's not cynicism when you're right.
In which case, I stand corrected. (And FWIW I agree).
-- It's not pessimism if there is a worse option, it's not paranoia when they are and it's not cynicism when you're right.