Beefy Boxes and Bandwidth Generously Provided by pair Networks vroom
good chemistry is complicated,
and a little bit messy -LW
 
PerlMonks  

Re: Appropriate amount of abstraction

by nothingmuch (Priest)
on Nov 17, 2004 at 04:32 UTC ( [id://408345]=note: print w/replies, xml ) Need Help??

This is an archived low-energy page for bots and other anonmyous visitors. Please sign up if you are a human and want to interact.


in reply to Appropriate amount of abstraction

I'd just like to add that in my experience, maintaining overly abstract code is easier than maintaining overly linear code.

Recently I've had to fudge Maypole, Class::DBI and friends around quite extensively to get my job done.

Some of the stuff I did to Class::DBI include objects which bless themselves at retrieve/create time based on an implicit class field, objects which pretend they've been deleted using a lifespan table, which contains (has_many) the times in which the row existed. The classes override delete, search, retrieve and so forth, and allow you to create "view handles" into the past, to query the database as it was at ... The list goes on.

All of that has been very easy to do because Class::DBI is very heavily abstracted, both by design and by implementation. Sure learning curve is a bit higher, and you have to juggle more thoughts at once till you're intimate with a bit of code, but the amount of time you spend changing the abstracting core is traded off to time spent extending it, which is a much easier task, IMHO.

Good post, ++!

-nuffin
zz zZ Z Z #!perl

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://408345]
help
Sections?
Information?
Find Nodes?
Leftovers?
    Notices?
    hippoepoptai's answer Re: how do I set a cookie and redirect was blessed by hippo!
    erzuuliAnonymous Monks are no longer allowed to use Super Search, due to an excessive use of this resource by robots.