Beefy Boxes and Bandwidth Generously Provided by pair Networks
"be consistent"

Re: Abstract class under MooseX-Declare

by grondilu (Friar)
on Aug 08, 2012 at 18:56 UTC ( #986341=note: print w/replies, xml ) Need Help??

in reply to Abstract class under MooseX-Declare

I'm no expert but since no one already answered this I'll give it a try.

It seems to me that the problem you might encounter is that your protection will work fine for AbstractClass, but not for any abstract child of AstractClass. If you keep this in mind, it should work.

About a better way to do it, I don't know but I'm not sure it is a good idea to redefine "BUILD" for this kind of thing. What about just putting your exception in the constructor?

sub new { die "attempt to instanciate an abstract class" }

Replies are listed 'Best First'.
Re^2: Abstract class under MooseX-Declare
by greengaroo (Hermit) on Aug 09, 2012 at 21:15 UTC

    First, thank you very much for your input, I really appreciate it.

    Let me answer your second statement first, about putting the exception in the constructor instead of the BUILD method. According to Moose best practices: Overriding new is a very bad practice. Instead, you should use a BUILD or BUILDARGS methods to do the same thing. When you override new, Moose can no longer inline a constructor when your class is immutabilized. So this is basically why I don't use it in the constructor.

    Now, why I use the BUILD method is because in Moose, the BUILD methods are called in order from the parent to the child, and not the other way around like normal methods. So instantiating the Abstract Class itself would trigger the call of its own BUILD method first, throwing an exception right away without executing more code.

    So, for an Abstract Class child of the first one, I would probably have to put an exact copy of the BUILD method I used in my example to prevent this child class from being instantiated too. Its BUILD method would be called in second place, just after its parent's.

    -- Take my advice. I don't use it anyway.

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://986341]
and all is quiet...

How do I use this? | Other CB clients
Other Users?
Others browsing the Monastery: (7)
As of 2017-05-29 06:44 GMT
Find Nodes?
    Voting Booth?