2 =head1 CXGN::Tools::Param
4 Export OK functions to build URL and Form parameter strings
8 C. Carpita <csc32@cornell.edu>
13 package CXGN
::Tools
::Param
;
16 use base qw
/Exporter/;
19 our @EXPORT_OK = qw
/ hash2param hash2hiddenpost /
25 Given a hash reference, build an argument string
27 Args: A common hash ref with parameters, and optional
28 second hash ref with modified parameters
29 Ret: URL param string, starting w/ "&arg1=val1..."
30 Ex: my $argstring = hash2param($std_arghashref, { hide => 1, arg2 => "scooter", formica => "kitsch" });
31 print $argstring; # prints '&otherargs=stuff...&hide=1&arg2=scooter&formica=kitsch'
33 Useful when you maintain settings in a hash and need to modify
34 different arguments and build several different URL's with GET
41 my $modifyref = shift;
42 return unless ref($hashref) eq "HASH";
47 while(my($k, $v) = each %$modifyref){
52 while(my($k, $v) = each %hash){
53 next unless $k && defined $v;
59 =head2 hash2hiddenpost()
61 Works like hash2param, except it returns several lines of <input type="hidden ..>
62 tags instead of a URL string. Takes a third argument, an array reference of
63 fields to exclude, since another form element may be providing the argument.
69 my $modifyref = shift;
70 my $exclude_array = shift;
71 return unless ref($hashref) eq "HASH";
74 if(ref($modifyref) eq "HASH"){
75 while(my($k, $v) = each %$modifyref){
80 if(ref($exclude_array) eq "ARRAY"){
81 delete $hash{$_} foreach(@
$exclude_array);
85 while(my($k, $v) = each %hash){
88 $string .= qq{\n<input type
="hidden" name
="$k" value
="$v" />};