# This file documents the revision history for Perl extension Catalyst.
- Fix for perl 5.8. RT#61122
+ - Remove use of MooseX::Types as MooseX::Types is broken on perl5.8
+ RT#77100 & RT#81121
5.90018 - 2012-10-23 20:55:00
- Changed code in test suite so it no longer trips up on recent changes to
requires 'Moose' => '1.03';
requires 'MooseX::MethodAttributes::Inheritable' => '0.24';
requires 'MooseX::Role::WithOverloading' => '0.09';
-requires 'MooseX::Types::LoadableClass' => '0.003';
requires 'Carp';
requires 'Class::C3::Adopt::NEXT' => '0.07';
requires 'CGI::Simple::Cookie' => '1.109';
requires 'Text::Balanced'; # core in 5.8.x but mentioned for completeness
requires 'MRO::Compat';
requires 'MooseX::Getopt' => '0.30';
-requires 'MooseX::Types';
-requires 'MooseX::Types::Common::Numeric';
requires 'String::RewritePrefix' => '0.004'; # Catalyst::Utils::resolve_namespace
requires 'Plack' => '0.9991'; # IIS6+7 fix middleware
requires 'Plack::Middleware::ReverseProxy' => '0.04';
package Catalyst::Script::Create;
use Moose;
-use MooseX::Types::Moose qw/Bool Str/;
use namespace::autoclean;
with 'Catalyst::ScriptRole';
has force => (
traits => [qw(Getopt)],
cmd_aliases => 'nonew',
- isa => Bool,
+ isa => 'Bool',
is => 'ro',
documentation => 'Force new scripts',
);
has debug => (
traits => [qw(Getopt)],
cmd_aliases => 'd',
- isa => Bool,
+ isa => 'Bool',
is => 'ro',
documentation => 'Force debug mode',
);
has mechanize => (
traits => [qw(Getopt)],
cmd_aliases => 'mech',
- isa => Bool,
+ isa => 'Bool',
is => 'ro',
documentation => 'use WWW::Mechanize',
);
has helper_class => (
- isa => Str,
+ isa => 'Str',
is => 'ro',
builder => '_build_helper_class',
);
package Catalyst::Script::FastCGI;
use Moose;
-use MooseX::Types::Moose qw/Str Bool Int/;
use Data::OptList;
use namespace::autoclean;
has listen => (
traits => [qw(Getopt)],
cmd_aliases => 'l',
- isa => Str,
+ isa => 'Str',
is => 'ro',
documentation => 'Specify a listening port/socket',
);
has pidfile => (
traits => [qw(Getopt)],
cmd_aliases => [qw/pid p/],
- isa => Str,
+ isa => 'Str',
is => 'ro',
documentation => 'Specify a pidfile',
);
has daemon => (
traits => [qw(Getopt)],
- isa => Bool,
+ isa => 'Bool',
is => 'ro',
cmd_aliases => [qw/d detach/], # Eww, detach is here as we fucked it up.. Deliberately not documented
documentation => 'Daemonize (go into the background)',
has manager => (
traits => [qw(Getopt)],
- isa => Str,
+ isa => 'Str',
is => 'ro',
cmd_aliases => 'M',
documentation => 'Use a different FastCGI process manager class',
has keeperr => (
traits => [qw(Getopt)],
cmd_aliases => 'e',
- isa => Bool,
+ isa => 'Bool',
is => 'ro',
documentation => 'Log STDERR',
);
has nproc => (
traits => [qw(Getopt)],
cmd_aliases => 'n',
- isa => Int,
+ isa => 'Int',
is => 'ro',
documentation => 'Specify a number of child processes',
);
has proc_title => (
traits => [qw(Getopt)],
- isa => Str,
+ isa => 'Str',
is => 'ro',
lazy => 1,
builder => '_build_proc_title',
package Catalyst::Script::Server;
use Moose;
-use MooseX::Types::Common::Numeric qw/PositiveInt/;
-use MooseX::Types::Moose qw/ArrayRef Str Bool Int RegexpRef/;
use Catalyst::Utils;
use Try::Tiny;
use namespace::autoclean;
has debug => (
traits => [qw(Getopt)],
cmd_aliases => 'd',
- isa => Bool,
+ isa => 'Bool',
is => 'ro',
documentation => q{Force debug mode},
);
has host => (
traits => [qw(Getopt)],
cmd_aliases => 'h',
- isa => Str,
+ isa => 'Str',
is => 'ro',
# N.B. undef (the default) means we bind on all interfaces on the host.
documentation => 'Specify a hostname or IP on this host for the server to bind to',
has fork => (
traits => [qw(Getopt)],
cmd_aliases => 'f',
- isa => Bool,
+ isa => 'Bool',
is => 'ro',
default => 0,
documentation => 'Fork the server to be able to serve multiple requests at once',
has port => (
traits => [qw(Getopt)],
cmd_aliases => 'p',
- isa => PositiveInt,
+ isa => 'Int',
is => 'ro',
default => sub {
Catalyst::Utils::env_value(shift->application_name, 'port') || 3000
subtype 'Catalyst::Script::Server::Types::Pidfile',
as 'MooseX::Daemonize::Pid::File';
-coerce 'Catalyst::Script::Server::Types::Pidfile', from Str, via {
+coerce 'Catalyst::Script::Server::Types::Pidfile', from 'Str', via {
try { Class::MOP::load_class("MooseX::Daemonize::Pid::File") }
catch {
warn("Could not load MooseX::Daemonize::Pid::File, needed for --pid option\n");
has keepalive => (
traits => [qw(Getopt)],
cmd_aliases => 'k',
- isa => Bool,
+ isa => 'Bool',
is => 'ro',
default => 0,
documentation => 'Support keepalive',
has background => (
traits => [qw(Getopt)],
cmd_aliases => 'bg',
- isa => Bool,
+ isa => 'Bool',
is => 'ro',
default => 0,
documentation => 'Run in the background',
has restart => (
traits => [qw(Getopt)],
cmd_aliases => 'r',
- isa => Bool,
+ isa => 'Bool',
is => 'ro',
default => sub {
Catalyst::Utils::env_value(shift->application_name, 'reload') || 0;
has restart_directory => (
traits => [qw(Getopt)],
cmd_aliases => [ 'rdir', 'restartdirectory' ],
- isa => ArrayRef[Str],
+ isa => 'ArrayRef[Str]',
is => 'ro',
documentation => 'Restarter directory to watch',
predicate => '_has_restart_directory',
has restart_delay => (
traits => [qw(Getopt)],
cmd_aliases => 'rd',
- isa => Int,
+ isa => 'Int',
is => 'ro',
documentation => 'Set a restart delay',
predicate => '_has_restart_delay',
{
use Moose::Util::TypeConstraints;
- my $tc = subtype 'Catalyst::Script::Server::Types::RegexpRef', as RegexpRef;
- coerce $tc, from Str, via { qr/$_/ };
+ my $tc = subtype 'Catalyst::Script::Server::Types::RegexpRef', as 'RegexpRef';
+ coerce $tc, from 'Str', via { qr/$_/ };
MooseX::Getopt::OptionTypeMap->add_option_type_to_map($tc => '=s');
has follow_symlinks => (
traits => [qw(Getopt)],
cmd_aliases => 'sym',
- isa => Bool,
+ isa => 'Bool',
is => 'ro',
default => 0,
documentation => 'Follow symbolic links',
has restarter_class => (
is => 'ro',
- isa => Str,
+ isa => 'Str',
lazy => 1,
default => sub {
my $self = shift;
package Catalyst::ScriptRole;
use Moose::Role;
-use MooseX::Types::Moose qw/Str Bool/;
use Pod::Usage;
use MooseX::Getopt;
use Catalyst::EngineLoader;
-use MooseX::Types::LoadableClass qw/LoadableClass/;
+use Moose::Util::TypeConstraints;
+use Catalyst::Utils qw/ ensure_class_loaded /;
use namespace::autoclean;
+subtype 'Catalyst::ScriptRole::LoadableClass',
+ as 'ClassName';
+coerce 'Catalyst::ScriptRole::LoadableClass',
+ from 'Str',
+ via { ensure_class_loaded($_); 1 };
+
with 'MooseX::Getopt' => {
-excludes => [qw/
_getopt_spec_warnings
has application_name => (
traits => ['NoGetopt'],
- isa => Str,
+ isa => 'Str',
is => 'ro',
required => 1,
);
has loader_class => (
- isa => LoadableClass,
+ isa => 'Catalyst::ScriptRole::LoadableClass',
is => 'ro',
coerce => 1,
default => 'Catalyst::EngineLoader',