X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FUtils.pm;h=76f07335354bd92abb97f9b5bfb576f71fa0f708;hb=17b3d80076b6acb25d56ed83b0ed7134ed4fb343;hp=13c2a0255964a4e217cbbb4e3fe5fa24690d6971;hpb=11c270bdda5402dc39e2ca54dfd65af42dedbe3c;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Utils.pm b/lib/Catalyst/Utils.pm index 13c2a02..76f0733 100644 --- a/lib/Catalyst/Utils.pm +++ b/lib/Catalyst/Utils.pm @@ -9,6 +9,10 @@ use URI; use Carp qw/croak/; use Cwd; +use String::RewritePrefix; + +use namespace::clean; + =head1 NAME Catalyst::Utils - The Catalyst Utils @@ -19,6 +23,8 @@ See L. =head1 DESCRIPTION +Catalyst Utilities. + =head1 METHODS =head2 appprefix($class) @@ -334,6 +340,66 @@ sub env_value { return; } +=head2 term_width + +Try to guess terminal width to use with formatting of debug output + +All you need to get this work, is: + +1) Install Term::Size::Any, or + +2) Export $COLUMNS from your shell. + +(Warning to bash users: 'echo $COLUMNS' may be showing you the bash +variable, not $ENV{COLUMNS}. 'export COLUMNS=$COLUMNS' and you should see +that 'env' now lists COLUMNS.) + +As last resort, default value of 80 chars will be used. + +=cut + +my $_term_width; + +sub term_width { + return $_term_width if $_term_width; + + my $width = eval ' + use Term::Size::Any; + my ($columns, $rows) = Term::Size::Any::chars; + return $columns; + '; + + if ($@) { + $width = $ENV{COLUMNS} + if exists($ENV{COLUMNS}) + && $ENV{COLUMNS} =~ m/^\d+$/; + } + + $width = 80 unless ($width && $width >= 80); + return $_term_width = $width; +} + + +=head2 resolve_namespace + +Method which adds the namespace for plugins and actions. + + __PACKAGE__->setup(qw(MyPlugin)); + + # will load Catalyst::Plugin::MyPlugin + +=cut + + +sub resolve_namespace { + my $namespace = shift; + my @classes = @_; + return String::RewritePrefix->rewrite( + { '' => $namespace.'::', '+' => '' }, @classes, + ); +} + + =head1 AUTHORS Catalyst Contributors, see Catalyst.pm