http://qs321.pair.com?node_id=1201471


in reply to "no warnings 'uninitialized'" failing

Thank you for the replies.

I'm not sure I realized that "no warnings" wouldn't affect warnings emitted by XML::Simple. I think I knew this in the back of my head, but I added that at some point and it must have worked--perhaps accidentally, combined with some other change--so I never considered it.

I also don't know why the warnings re-started recently.

In any case, I'm absolutely sure that $data itself was defined.

However, after a bunch more testing, I realized that I was getting these warnings for any undefined values in the data. And then I realized that the error was that SuppressEmpty => 0 was a mistake--it's supposed to be SuppressEmpty => undef (or the empty string). When I made this change, the warnings went away, and I got my desired empty XML in the output.

I have no idea why it (seemed to) work at one point and then go back to not working. However, it's clear that the SuppressEmpty setting was the right way to fix it.

Thanks again.

Replies are listed 'Best First'.
Re^2: "no warnings 'uninitialized'" failing
by LanX (Saint) on Oct 16, 2017 at 21:23 UTC
    Hmm, it looks weird that a boolean switch should accept 1 but not 0. (???)

    So I took a look into the documentation. ...

    Turns out that  SuppressEmpty is not a real flag, but that "" and undef are used to define how empty elements are represented or ignored in a case of a true value.

    And the docs explicitly talk about "suppressing the generation of warnings" in XMLout().

    I find the naming and concept too error prone.

    Something like  RepresentEmpty => "off" | "" | undef might have been a better choice.

    And I'm understanding even better now, why this module is discouraged, even in its own POD.

    Cheers Rolf
    (addicted to the Perl Programming Language and ☆☆☆☆ :)
    Je suis Charlie!