package App::envfile;

use strict;
use warnings;
use 5.008_001;
our $VERSION = '0.01';

sub new {
   my $class = shift;
   bless {}, $class;
}

sub run {
   my ($self, $envfile, @args) = @_;
   $self->usage unless defined $envfile;
   $self->load_envfile($envfile);
   exec(@args);
}

sub load_envfile {
   my ($self, $file) = @_;
   $self->usage unless -f $file;
   open my $fh, '<', $file or die "$file: $!\n";
   while (defined (my $line = readline $fh)) {
       chomp $line;
       next if index($line, '#') == 0;
       next if $line =~ /^\s*$/;
       my ($key, $value) = $self->_split_line($line);
       $ENV{$key} = $value;
   }
   close $fh;
}

sub _split_line {
   my ($self, $line) = @_;
   my ($key, $value) = map { my $str = $_; $str =~ s/^\s+|\s+$//g; $str } split '=', $line, 2;
   return $key, $value;
}

sub usage {
   my $self = shift;
print << 'USAGE';
Usage: evnfile file commands

USAGE
   exit 1;
}

1;
__END__

=encoding utf-8

=for stopwords

=head1 NAME

App::envfile - runs another program with environment modified according to envfile

=head1 SYNOPSIS

 $ cat > foo.env
 FOO=bar
 HOGE=fuga
 $ envfile foo.env perl -le 'print "$ENV{FOO}, $ENV{HOGE}"'
 bar, fuga

like

 $ env FOO=bar HOGE=fuga perl -le 'print "$ENV{FOO}, $ENV{HOGE}"'

=head1 DESCRIPTION

App::envfile is sets environment from file.

envfile inspired djb's envdir program.

=head1 METHODS

=over

=item C<< new() >>

Create App::envfile instance.

 my $envf = App::envfile->new();

=item C<< run($envfile, @commands) >>

Runs another program.

 $envf->run($envfile, @commands);

=item C<< load_envfile($envfile) >>

Sets %ENV from file.

 $envf->load_envfile($envfile);

Supported file format are:

 KEY=VALUE
 KEY2=VALUE
 ...

=item C<< usage() >>

Show usage.

 $envf->usage();

=back

=head1 AUTHOR

xaicron E<lt>[email protected]<gt>

=head1 COPYRIGHT

Copyright 2011 - xaicron

=head1 LICENSE

This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.

=head1 SEE ALSO

=cut