Initial Commit
This commit is contained in:
91
database/perl/vendor/lib/File/Find/Rule/Extending.pod
vendored
Normal file
91
database/perl/vendor/lib/File/Find/Rule/Extending.pod
vendored
Normal file
@@ -0,0 +1,91 @@
|
||||
=head1 NAME
|
||||
|
||||
File::Find::Rule::Extending - the mini-guide to extending File::Find::Rule
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
package File::Find::Rule::Random;
|
||||
use strict;
|
||||
|
||||
# take useful things from File::Find::Rule
|
||||
use base 'File::Find::Rule';
|
||||
|
||||
# and force our crack into the main namespace
|
||||
sub File::Find::Rule::random () {
|
||||
my $self = shift()->_force_object;
|
||||
$self->exec( sub { rand > 0.5 } );
|
||||
}
|
||||
|
||||
1;
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
File::Find::Rule went down so well with the buying public that
|
||||
everyone wanted to add extra features. With the 0.07 release this
|
||||
became a possibility, using the following conventions.
|
||||
|
||||
=head2 Declare your package
|
||||
|
||||
package File::Find::Rule::Random;
|
||||
use strict;
|
||||
|
||||
=head2 Inherit methods from File::Find::Rule
|
||||
|
||||
# take useful things from File::Find::Rule
|
||||
use base 'File::Find::Rule';
|
||||
|
||||
=head3 Force your madness into the main package
|
||||
|
||||
# and force our crack into the main namespace
|
||||
sub File::Find::Rule::random () {
|
||||
my $self = shift()->_force_object;
|
||||
$self->exec( sub { rand > 0.5 } );
|
||||
}
|
||||
|
||||
|
||||
Yes, we're being very cavalier here and defining things into the main
|
||||
File::Find::Rule namespace. This is due to lack of imaginiation on my
|
||||
part - I simply can't find a way for the functional and oo interface
|
||||
to work without doing this or some kind of inheritance, and
|
||||
inheritance stops you using two File::Find::Rule::Foo modules
|
||||
together.
|
||||
|
||||
For this reason try and pick distinct names for your extensions. If
|
||||
this becomes a problem then I may institute a semi-official registry
|
||||
of taken names.
|
||||
|
||||
=head2 Taking no arguments.
|
||||
|
||||
Note the null prototype on random. This is a cheat for the procedural
|
||||
interface to know that your sub takes no arguments, and so allows this
|
||||
to happen:
|
||||
|
||||
find( random => in => '.' );
|
||||
|
||||
If you hadn't declared C<random> with a null prototype it would have
|
||||
consumed C<in> as a parameter to it, then got all confused as it
|
||||
doesn't know about a C<'.'> rule.
|
||||
|
||||
=head1 AUTHOR
|
||||
|
||||
Richard Clamp <richardc@unixbeard.net>
|
||||
|
||||
=head1 COPYRIGHT
|
||||
|
||||
Copyright (C) 2002 Richard Clamp. All Rights Reserved.
|
||||
|
||||
This module is free software; you can redistribute it and/or modify it
|
||||
under the same terms as Perl itself.
|
||||
|
||||
=head1 SEE ALSO
|
||||
|
||||
L<File::Find::Rule>
|
||||
|
||||
L<File::Find::Rule::MMagic> was the first extension module, so maybe
|
||||
check that out.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
|
||||
|
||||
72
database/perl/vendor/lib/File/Find/Rule/Procedural.pod
vendored
Normal file
72
database/perl/vendor/lib/File/Find/Rule/Procedural.pod
vendored
Normal file
@@ -0,0 +1,72 @@
|
||||
=head1 NAME
|
||||
|
||||
File::Find::Rule::Procedural - File::Find::Rule's procedural interface
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
use File::Find::Rule;
|
||||
|
||||
# find all .pm files, procedurally
|
||||
my @files = find(file => name => '*.pm', in => \@INC);
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
In addition to the regular object-oriented interface,
|
||||
L<File::Find::Rule> provides two subroutines for you to use.
|
||||
|
||||
=over
|
||||
|
||||
=item C<find( @clauses )>
|
||||
|
||||
=item C<rule( @clauses )>
|
||||
|
||||
C<find> and C<rule> can be used to invoke any methods available to the
|
||||
OO version. C<rule> is a synonym for C<find>
|
||||
|
||||
=back
|
||||
|
||||
Passing more than one value to a clause is done with an anonymous
|
||||
array:
|
||||
|
||||
my $finder = find( name => [ '*.mp3', '*.ogg' ] );
|
||||
|
||||
C<find> and C<rule> both return a File::Find::Rule instance, unless
|
||||
one of the arguments is C<in>, in which case it returns a list of
|
||||
things that match the rule.
|
||||
|
||||
my @files = find( name => [ '*.mp3', '*.ogg' ], in => $ENV{HOME} );
|
||||
|
||||
Please note that C<in> will be the last clause evaluated, and so this
|
||||
code will search for mp3s regardless of size.
|
||||
|
||||
my @files = find( name => '*.mp3', in => $ENV{HOME}, size => '<2k' );
|
||||
^
|
||||
|
|
||||
Clause processing stopped here ------/
|
||||
|
||||
It is also possible to invert a single rule by prefixing it with C<!>
|
||||
like so:
|
||||
|
||||
# large files that aren't videos
|
||||
my @files = find( file =>
|
||||
'!name' => [ '*.avi', '*.mov' ],
|
||||
size => '>20M',
|
||||
in => $ENV{HOME} );
|
||||
|
||||
|
||||
=head1 AUTHOR
|
||||
|
||||
Richard Clamp <richardc@unixbeard.net>
|
||||
|
||||
=head1 COPYRIGHT
|
||||
|
||||
Copyright (C) 2003 Richard Clamp. All Rights Reserved.
|
||||
|
||||
This module is free software; you can redistribute it and/or modify it
|
||||
under the same terms as Perl itself.
|
||||
|
||||
=head1 SEE ALSO
|
||||
|
||||
L<File::Find::Rule>
|
||||
|
||||
=cut
|
||||
Reference in New Issue
Block a user