App-ClusterSSH
view release on metacpan or search on metacpan
lib/App/ClusterSSH/Base.pm view on Meta::CPAN
while ( defined( $line = <$fh> ) ) {
next
if ( $line =~ /^\s*$/ || $line =~ /^#/ )
; # ignore blank lines & commented lines
$line =~ s/\s*#.*//; # remove comments from remaining lines
$line =~ s/\s*$//; # remove trailing whitespace
# look for continuation lines
chomp $line;
if ( $line =~ s/\\\s*$// ) {
$line .= <$fh>;
redo unless eof($fh);
}
next unless $line =~ $regexp;
my ( $key, $value ) = ( $1, $2 );
if ( defined $key && defined $value ) {
if ( $results{$key} ) {
$results{$key} .= ' ' . $value;
}
else {
$results{$key} = $value;
}
$self->debug( 3, "$key=$value" );
$self->debug( 7, "entry now reads: $key=$results{$key}" );
}
}
close($fh)
or croak(
App::ClusterSSH::Exception::LoadFile->throw(
error => "Could not close $args{filename} after reading: $!"
),
);
return %results;
}
sub parent {
my ($self) = @_;
return $self->{parent};
}
1;
=pod
=head1 NAME
App::ClusterSSH::Base - Base object provding utility functions
=head1 SYNOPSIS
use base qw/ App::ClusterSSH::Base /;
# in object new method
sub new {
( $class, $arg_ref ) = @_;
my $self = $class->SUPER::new($arg_ref);
return $self;
}
=head1 DESCRIPTION
Base object to provide some utility functions on objects - should not be
used directly
=head1 METHODS
These extra methods are provided on the object
=over 4
=item $obj = App::ClusterSSH::Base->new({ arg => val, });
Creates object. In higher debug levels the args are printed out.
=item $obj->id
Return the unique id of the object for use in subclasses, such as
$info_for{ $self->id } = $info
=item $obj->debug_level();
Returns current debug level
=item $obj->set_debug_level( n )
Set debug level to 'n' for all child objects.
=item $obj->debug($level, @text)
Output @text on STDOUT if $level is the same or lower that debug_level
=item $obj->set_lang
Set the Locale::Maketext language. Defaults to 'en'. Expects the
App::ClusterSSH/L10N/{lang}.pm module to exist and contain all relevant
translations, else defaults to English.
=item $obj->loc('text to translate [_1]')
Using the App::ClusterSSH/L10N/{lang}.pm module convert the given text to
appropriate language. See L<App::ClusterSSH::L10N> for more details. Essentially
a wrapper to maketext in Locale::Maketext
=item $obj->stdout_output(@);
Output text on STDOUT.
=item $ovj->parent;
Reutrned the object that is the parent of this one, if it was set when the
object was created
=item $obj->exit;
Stub to allow program to exit neatly from wherever in the code
( run in 0.481 second using v1.01-cache-2.11-cpan-0bb4e1dffa6 )