Poet::Environment -- Poet environment
# In a script... use Poet::Script qw($env); # In a module... use Poet qw($env); # $env is automatically available in Mason components # then... my $root_dir = $env->root_dir; my $path_to_script = $env->bin_path("foo/bar.pl"); my $path_to_lib = $env->lib_path("Foo/Bar.pm");
The Poet::Environment object contains information about the current environment and its directory paths.
Returns the root directory of the environment, i.e. where .poet_root is located.
Returns the root directory with a relative subpath added. e.g. if the Poet environment root is /my/env/root, then
/my/env/root
$env->conf_path("somefile.txt"); ==> returns /my/env/root/somefile.txt
Returns the specified subdirectory, which by default will be just below the root dirctory. e.g. if the Poet environment root is /my/env/root, then
$env->conf_dir ==> returns /my/env/root/conf $env->lib_dir ==> returns /my/env/root/lib
Returns the specified subdirectory with a relative subpath added. e.g. if the Poet environment root is /my/env/root, then
$env->conf_path("log4perl.conf"); ==> returns /my/env/root/conf/log4perl.conf $env->lib_path("Data/Type.pm"); ==> returns /my/env/root/lib/Data/Type.pm
Returns the full class name to use for the specified class, depending on whether there is a subclass in the environment. e.g.
$env->app_class('Cache')
will return MyApp::Cache if that module exists, and otherwise Poet::Cache. This is used internally by Poet to implement auto subclassing.
MyApp::Cache
Poet::Cache
Returns the app name, e.g. 'MyApp', found in .poet_root.
Returns the Poet::Conf object associated with the environment. Usually you'd access this by importing $conf.
$conf
A class method that returns the current (singleton) environment for the process. Usually you'd access this by importing $env.
$env
Any subdirectories other than conf_dir can be overriden in configuration. e.g.
# Override bin_dir env.bin_dir: /some/other/bin/dir
With this configuration in place,
$env->bin_dir ==> returns /some/other/bin/dir $env->bin_path("foo/bar.pl") ==> returns /some/other/bin/dir/foo/bar.pl
Poet
Jonathan Swartz <swartz@pobox.com>
This software is copyright (c) 2012 by Jonathan Swartz.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.
To install Poet, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Poet
CPAN shell
perl -MCPAN -e shell install Poet
For more information on module installation, please visit the detailed CPAN module installation guide.