App-Info
view release on metacpan or search on metacpan
lib/App/Info/Lib/OSSPUUID.pm view on Meta::CPAN
shared subroutines. However, any one event should be triggered no more than
once. For example, although the info event "Executing `uuid-config --version`"
is documented for the methods C<name()> C<version()>, C<major_version()>,
C<minor_version()>, and C<patch_version()>, rest assured that it will only be
triggered once, by whichever of those four methods is called first.
=cut
use strict;
use App::Info::Util;
use App::Info::Lib;
use File::Spec::Functions 'catfile';
use vars qw(@ISA $VERSION);
@ISA = qw(App::Info::Lib);
$VERSION = '0.57';
use constant WIN32 => $^O eq 'MSWin32';
my $u = App::Info::Util->new;
##############################################################################
=head1 INTERFACE
=head2 Constructor
=head3 new
my $expat = App::Info::Lib::OSSPUUID->new(@params);
Returns an App::Info::Lib::OSSPUUID object. See L<App::Info|App::Info> for a
complete description of argument parameters.
When called, C<new()> searches all of the paths returned by the
C<search_lib_dirs()> method for one of the files returned by the
C<search_lib_names()> method. If any of is found, then the OSSP UUID library
is assumed to be installed. Otherwise, most of the object methods will return
C<undef>.
B<Events:>
=over 4
=item info
Looking for uuid-config
=item confirm
Path to uuid-config?
=item unknown
Path to uuid-config?
=back
=cut
sub new {
# Construct the object.
my $self = shift->SUPER::new(@_);
# Find uuid-config.
$self->info("Looking for uuid-config");
my @paths = $self->search_bin_dirs;
my @exes = $self->search_exe_names;
if (my $cfg = $u->first_cat_exe(\@exes, @paths)) {
# We found it. Confirm.
$self->{uuid_config} = $self->confirm(
key => 'path to uuid-config',
prompt => "Path to uuid-config?",
value => $cfg,
callback => sub { -x },
error => 'Not an executable'
);
} else {
# Handle an unknown value.
$self->{uuid_config} = $self->unknown(
key => 'path to uuid-config',
prompt => "Path to uuid-config?",
callback => sub { -x },
error => 'Not an executable'
);
}
# Set up search defaults.
if (exists $self->{search_uuid_names}) {
$self->{search_uuid_names} = [$self->{search_uuid_names}]
unless ref $self->{search_uuid_names} eq 'ARRAY';
} else {
$self->{search_uuid_names} = [];
}
return $self;
}
# We'll use this code reference as a common way of collecting data.
my $get_data = sub {
return unless $_[0]->{uuid_config};
$_[0]->info(qq{Executing `"$_[0]->{uuid_config}" $_[1]`});
my $info = `"$_[0]->{uuid_config}" $_[1]`;
chomp $info;
return $info;
};
##############################################################################
=head2 Class Method
=head3 key_name
my $key_name = App::Info::Lib::OSSPUUID->key_name;
Returns the unique key name that describes this class. The value returned is
the string "OSSP UUID".
=cut
lib/App/Info/Lib/OSSPUUID.pm view on Meta::CPAN
=item info
Loading OSSP::uuid
=back
=cut
sub perl_module {
my $self = shift;
$self->info('Loading OSSP::uuuid');
$self->{perl_module} ||= do {
eval 'use OSSP::uuid';
$INC{catfile qw(OSSP uuid.pm)};
};
return $self->{perl_module};
}
##############################################################################
=head3 home_url
my $home_url = $uuid->home_url;
Returns the OSSP UUID home page URL.
=cut
sub home_url { 'http://www.ossp.org/pkg/lib/uuid/' }
##############################################################################
=head3 download_url
my $download_url = $uuid->download_url;
Returns the OSSP UUID download URL.
=cut
sub download_url { 'http://www.ossp.org/pkg/lib/uuid/' }
##############################################################################
=head3 search_exe_names
my @search_exe_names = $app->search_exe_names;
Returns a list of possible names for F<uuid-config> executable. By default, only
F<uuid-config> is returned (or F<uuid-config.exe> on Win32).
Note that this method is not used to search for the OSSP UUID server
executable, only F<uuid-config>.
=cut
sub search_exe_names {
my $self = shift;
my $exe = 'uuid-config';
$exe .= '.exe' if WIN32;
return ($self->SUPER::search_exe_names, $exe);
}
##############################################################################
=head3 search_bin_dirs
my @search_bin_dirs = $app->search_bin_dirs;
Returns a list of possible directories in which to search an executable. Used
by the C<new()> constructor to find an executable to execute and collect
application info. The found directory will also be returned by the C<bin_dir>
method.
The list of directories by default consists of the path as defined by
C<< File::Spec->path >>, as well as the following directories:
=over 4
=item /usr/local/bin
=item /usr/local/sbin
=item /usr/bin
=item /usr/sbin
=item /bin
=item C:\Program Files\uid\bin
=back
=cut
sub search_bin_dirs {
return shift->SUPER::search_bin_dirs,
$u->path,
qw(/usr/local/bin
/usr/local/sbin
/usr/bin
/usr/sbin
/bin),
'C:\Program Files\uid\bin';
}
##############################################################################
=head2 Other Executable Methods
These methods function just like the C<executable()> method, except that they
return different executables. OSSP UUID comes with a fair number of them; we
provide these methods to provide a path to a subset of them. Each method, when
called, checks for an executable in the directory returned by C<bin_dir()>.
The name of the executable must be one of the names returned by the
corresponding C<search_*_names> method.
The available executable methods are:
=over
=item uuid
=item uuid_config
=back
And the corresponding search names methods are:
=over
=item search_postgres_names
=item search_createdb_names
=back
B<Events:>
=over 4
=item info
Looking for executable
=item confirm
Path to executable?
=item unknown
Path to executable?
=back
=cut
( run in 2.069 seconds using v1.01-cache-2.11-cpan-98e64b0badf )