Beefy Boxes and Bandwidth Generously Provided by pair Networks
more useful options

Re: Refactor method calls or not?

by tadman (Prior)
on Jan 18, 2002 at 23:11 UTC ( #139917=note: print w/replies, xml ) Need Help??

in reply to Refactor method calls or not?

This might be crazy, but you could use a closure to generate the required subs and then load them into a hash. Something like this, perhaps:
# Define appropriate "methods" my @dispatch_methods = qw [ company financialDiary ]; # Routine to generate an anonymous sub using closure sub dispatch_add { my ($what) = @_; return sub { my ( $self, $data ) = @_; my $table = $what; my $data = $self->_generic_insert( $data, $table ); $self->{ _dbh }->commit if ! $self->{ _error }; return $data; }; } # Build the dispatch table, trying to minimize error sub new { # Usual stuff... my $self = bless ... # : $self->{dispatch} = { map { $_ => dispatch_add{$_} } @dispatch_methods }; }
Then you could call them along the lines of:
Of course, this might be completely nuts.

Don't get me wrong. AUTOLOAD is fun, too. A hybrid approach would merely interface with the internal {dispatch} structure and call the appropriate function. This way they are pre-cached, and pre-validated. If there is no defined dispatch, AUTOLOAD can warn/die/carp appropriately.

Log In?

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

How do I use this? | Other CB clients
Other Users?
Others drinking their drinks and smoking their pipes about the Monastery: (4)
As of 2021-04-23 00:25 GMT
Find Nodes?
    Voting Booth?

    No recent polls found