in reply to Re: Improved CGI Design
in thread Improved CGI Design

That is another way of implimenting the dispatch table however that really doesn't help me in thie situation. I need to have one of the hash entries be "deeper" then the rest. Your example is basicly what I already have - a table that works if all entries have the same depth. Although it does help simplify the IF/THEN/ELSE that is remaing.

Cheers,
-Dogma

Replies are listed 'Best First'.
Re: Re: Re: Improved CGI Design
by George_Sherston (Vicar) on Apr 10, 2002 at 11:33 UTC
    Yes, I see. I suppose the logic of my approach is to add another level *throughout* the hash. Then it does get quite big, though it also remains logical and regular in a slightly obsessive-compulsive way. Untested:
    sub get_branch_function { my $query = shift; my $action = $query->param('action') ? $query->param('action') : +'default'; my $update = $query->param('update') ? 'update' : 'default'; my $confirm = $query->param('confirm') ? 'confirm' : 'default'; my $commit = $query->param('commit') ? 'commit' : 'default'; my %dispatch = ( add => { update => { confirm => { commit => \&commit_dialog, default => \&add_dialog, }, default => { commit => \&add_dialog, default => \&add_dialog, }, }, default => { confirm => { commit => \&commit_dialog, default => \&add_dialog, }, default => { commit => \&add_dialog, default => \&add_dialog, }, }, }, remove => { update => { confirm => { commit => \&commit_dialog, default => \&confirm_dialog, }, default => { commit => \&choose_dialog, default => \&choose_dialog, }, }, default => { confirm => { commit => \&commit_dialog, default => \&confirm_dialog, }, default => { commit => \&choose_dialog, default => \&choose_dialog, }, }, }, modify => { update => { confirm => { commit => \&commit_dialog, default => \&confirm_dialog, }, default => { commit => \&choose_dialog, default => \&choose_dialog, }, }, default => { confirm => { commit => \&choose_dialog, default => \&choose_dialog, }, default => { commit => \&choose_dialog, default => \&choose_dialog, }, }, }, default => { update => { confirm => { commit => \&action_dialog, default => \&action_dialog, }, default => { commit => \&action_dialog, default => \&action_dialog, }, }, default => { confirm => { commit => \&action_dialog, default => \&action_dialog, }, default => { commit => \&action_dialog, default => \&action_dialog, }, }, }, ); return $dispatch{ $action }{ $update }{ $confirm }{ $commit }; }


    § George Sherston