please dont rip this site

Perl Subroutines


sub name ] [ (prototype) ] [ : attributes ] [ {statements;} ]

sub name [ (prototype) ]
Forward declaration. The actual subroutine will be defined later but this allows us to refer to it now. The prototype is optional.

sub [ name ] {statements;}
Normal subroutine definition. Any number of scalar arameters can be passed to the subroutine and will show up in @_. Note that name IS optional. A function can return a sub or a sub can be passed as a parameter. e.g. return sub { $_ += 1; };  

sub name (prototype) {statements;}
The prototype string helps to specify what this subroutine needs to recieve in the way of parameters.

\$
single scalar parameter
\@
single list
\%
single hash
*
bareword, constant, scalar expression, typeglob, or a reference to a typeglob. The value will be available to the subroutine either as a simple scalar, or (in the latter two cases) as a reference to the typeglob. If you wish to always convert such arguments to a typeglob reference, use Symbol::qualify_to_ref()
&
requires an anonymous subroutine, which, if passed as the first argument, does not require the sub keyword or a subsequent comma. eg ( {statements;} )
$
converts the parameter to scalar context
@
provides all the remaining parameters as a list
%
provides all the remaining parameters as a hash
; (semicolon)
separates mandatory arguments from optional arguments. It is redundant before @ or %

Parameters are passed to the subroutine as scalars in @_ and returned as list, scalar, or void.

The return value of a subroutine is the value of the last expression evaluated. More explicitly, a return statement may be used to exit the subroutine, optionally specifying the returned value

The interesting thing about & is that you can generate new syntax with it, provided it's in the initial position:

    sub try (&@) {
	my($try,$catch) = @_;
	eval { &$try };
	if ($@) {
	    local $_ = $@;
	    &$catch;
	}
    }
    sub catch (&) { $_[0] }

    try {
	die "phooey";
    } catch {
	/phooey/ and print "unphooey\n";
    };  
 
 


That prints "unphooey". 


file: /techref/language/perl/sub.htm, 2KB, , updated: 2004/2/11 17:02, local time: 2008/8/20 23:13,
TOP NEW HELP FIND: 
38.103.63.61:LOG IN
©2008 PLEASE DON'T RIP! DO: LINK / DIGG! / MAKE!

 ©2008 These pages are served without commercial sponsorship. (No popup ads, etc...).Bandwidth abuse increases hosting cost forcing sponsorship or shutdown. This server aggressively defends against automated copying for any reason including offline viewing, duplication, etc... Please respect this requirement and DO NOT RIP THIS SITE. Questions?
Please DO link to this page! Digg it!
<A HREF="http://techref.massmind.org/techref/language/perl/sub.htm"> Perl Subroutines</A>

After you find an appropriate page, you are invited to your to this massmind site! (posts will be reviewed) Just type in the box and press the Post button. (HTML welcomed!): A tutorial is available Members can login to post directly, become page editors, and be credited for their posts.


Link? Put it here: 
if you want a response, please enter your email address: 
Did you find what you needed?

 

Welcome to massmind.org!

  'What can I do?' - SiCKO

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  .