Beefy Boxes and Bandwidth Generously Provided by pair Networks
We don't bite newbies here... much
 
PerlMonks  

Re: Abstract class under MooseX-Declare

by grondilu (Pilgrim)
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" }


Comment on Re: Abstract class under MooseX-Declare
Download Code
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?
Username:
Password:

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://986341]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others imbibing at the Monastery: (14)
As of 2014-08-20 20:47 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    The best computer themed movie is:











    Results (124 votes), past polls