in reply to Re^2: Printing an object when you only have the refaddr string for it
in thread [SOLVED] Printing an object when you only have the refaddr string for it

... I will only ever need to access it immediately while it's still in scope ...

The phrase "... it will error out with a message ..." in the OP suggests that an exception has already been thrown, suggesting in turn that the scope of the object has been exited and the object itself marked for garbage collection. Does the thrown exception carry a copy of the object reference, thereby defeating GC, in addition to a mere stringization thereof? That seems to me to be the only hope you would have of reliably going back to the object in question with the object of dumping it in some useful way.


Give a man a fish:  <%-{-{-{-<

  • Comment on Re^3: Printing an object when you only have the refaddr string for it
  • Download Code

Replies are listed 'Best First'.
Re^4: Printing an object when you only have the refaddr string for it
by delias_ (Acolyte) on Nov 05, 2015 at 20:57 UTC
    That is correct, there is an array reference it carries with the object. nested under $obj-{error}->[ arrayref here with more array refs under it ] while the function $obj->error provides the stringification at $obj->{error}->{message} Verified it's still in scope using Data::TreeDumper which shows the address.

      But if you have a fresh, live, wriggling copy of the object reference in your hand, where's the problem? Why go to any trouble trying to convert a stringized address back into a live pointer/reference? Just drill down into the nested object reference to the point at which the problem appears (Ok, this might be a bit tricky, but even so...) and then Data::Dumper it from there on down.


      Give a man a fish:  <%-{-{-{-<

        Haha yeah so that's just it. The trick is that the data structure is massive and I don't know exactly what it's complaining about every time because the array it's pointing to is 15 arrays deep with multiple objects at that same level. and so there would be multiple objects there containing a "color" value, but I don't know which one because all I have is the refaddr to identify it.
        LOOKING FOR ARRAY(0x7fa9bc68be78) . . . | | | | | | | | | | | | | | | |- 3 [ +A220] ARRAY(0x7fa9bc68be78)

        The work around is to iterate over each individual one and keep track of the item name as "curName" for example, but it's a lot of code cluttering the subroutines doing actual work and not something I can just segregate into the sub that handles error output in my application.