in reply to Re: Extending a class (updated x2)
in thread Extending a class

In sub Bar, you're calling $g->Foo, where $g is the return value of $self->group. Looking at the code of SVG::Element, that's a new SVG::Element. SVG::Element doesn't have a sub Foo, which is why the call fails.

Yes! I was aware of that. But I was expecting that, since $self was a MyPackage object, its progeny would be the same species...

Anyway the SVG::Element::Foo trick seems to work, thank you all very much for your responses!

Replies are listed 'Best First'.
Re^3: Extending a class (corrected)
by Athanasius (Archbishop) on Apr 14, 2016 at 08:00 UTC

    Hello betacentauri,

    But I was expecting that, since $self was a MyPackage object, its progeny would be the same species...

    Yes, they would be. So within your sub Bar, $self is an instance of class MyPackage; and since MyPackage ISA SVG, $self ISA SVG too.

    But don’t be fooled by the names: as far as Perl is concerned, SVG and SVG::Element are separate and unrelated classes! When Perl sees use SVG; (or use parent 'SVG';), it looks for a module named SVG.pm in the directories contained in the global variable @INC. But when it sees use SVG::Element;, it looks in @INC for a directory named SVG, and then within that directory for a module named Element.pm. And that’s it! Apart from their namespaces, the two modules are independent of each other. See perlmod#Packages.

    Of course, these classes are related conceptually (i.e., in the programmer’s mind), which is why their author included them both in the SVG distribution (which also contains classes SVG::DOM, SVG::Extension, and SVG::XML); but Perl itself knows nothing of this relationship.

    Update: The above is true in the general case. But in this specific case, it turns out that the module SVG.pm actually begins as follows:

    package SVG; use strict; use warnings; use SVG::XML; use parent qw(SVG::Element SVG::Extension);

    — so an object of class SVG ISA SVG::Element as well. Thanks to haukex for the heads-up.

    Hope that helps,

    Athanasius <°(((><contra mundum Iustus alius egestas vitae, eros Piratica,

Re^3: Extending a class (updated)
by haukex (Archbishop) on Apr 13, 2016 at 22:54 UTC

    Hi betacentauri,

    I was expecting that, since $self was a MyPackage object, its progeny would be the same species...

    my $tag = new SVG::Element( $name, %attrs ); is hardcoded in SVG::Element::tag() (called directly from SVG::Element::group()), so it doesn't depend on $self, it's always calling SVG::Element::new(). It could certainly be argued that SVG::Element could be coded differently to enable the kind of subclassing you want to do!

    Regards,
    -- Hauke D