X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FUtils.pm;h=5fae3076c2f43a8f7ecd80da542f0f6b74d59e14;hb=8ace712d58c78c04d404eb445de83547d9510f39;hp=9f602f6acfba61e52750b4638646644aa13e77f6;hpb=38c68f3d599ba1dfb29e9429467edf877356b3c4;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Utils.pm b/lib/Catalyst/Utils.pm index 9f602f6..5fae307 100644 --- a/lib/Catalyst/Utils.pm +++ b/lib/Catalyst/Utils.pm @@ -394,6 +394,7 @@ this =cut my $_term_width; +my $_use_term_size_any; sub term_width { my $force_reset = shift; @@ -402,29 +403,36 @@ sub term_width { return $_term_width if $_term_width; + if (!defined $_use_term_size_any) { + eval { + require Term::Size::Any; + Term::Size::Any->import(); + $_use_term_size_any = 1; + 1; + } or do { + if ( $@ =~ m[Can't locate Term/Size/Any\.pm] ) { + warn "Term::Size::Any is not installed, can't autodetect terminal column width\n"; + } + else { + warn "There was an error trying to detect your terminal size: $@\n"; + } + $_use_term_size_any = 0; + }; + } + my $width; - eval ' - use Term::Size::Any; - ($width) = Term::Size::Any::chars; - 1; - ' or do { - if($@ =~m[Can't locate Term/Size/Any.pm]) { - warn "Term::Size::Any is not installed, can't autodetect terminal column width\n"; - } else { - warn "There was an error trying to detect your terminal size: $@\n"; - } - }; - unless ($width) { - warn 'Trouble trying to detect your terminal size, looking at $ENV{COLUMNS}'."\n"; - $width = $ENV{COLUMNS} - if exists($ENV{COLUMNS}) - && $ENV{COLUMNS} =~ m/^\d+$/; + if ($_use_term_size_any) { + ($width) = Term::Size::Any::chars(); + } + + if (!$width && $ENV{COLUMNS} && $ENV{COLUMNS} =~ /\A\d+\z/) { + $width = $ENV{COLUMNS}; + } + if (!$width || $width < 80) { + $width = 80; } - do { - warn "Cannot determine desired terminal width, using default of 80 columns\n"; - $width = 80 } unless ($width && $width >= 80); return $_term_width = $width; } @@ -572,7 +580,7 @@ sub inject_component { croak "Unable to build component package for \"$component_package\": $@"; Moose::Util::apply_all_roles($component_package, @{$given{traits}}) if $given{traits}; (my $file = "$component_package.pm") =~ s{::}{/}g; - $INC{$file} ||= 1; + $INC{$file} ||= 1; } my $_setup_component = sub {