CONTENTS

NAME

MooseX::NonMoose - easy subclassing of non-Moose classes

VERSION

version 0.27

SYNOPSIS

package Term::VT102::NBased;
use Moose;
use MooseX::NonMoose;
extends 'Term::VT102';

has [qw/x_base y_base/] => (
    is      => 'ro',
    isa     => 'Int',
    default => 1,
);

around x => sub {
    my $orig = shift;
    my $self = shift;
    $self->$orig(@_) + $self->x_base - 1;
};

# ... (wrap other methods)

no Moose;
# no need to fiddle with inline_constructor here
__PACKAGE__->meta->make_immutable;

my $vt = Term::VT102::NBased->new(x_base => 0, y_base => 0);

DESCRIPTION

MooseX::NonMoose allows for easily subclassing non-Moose classes with Moose, taking care of the annoying details connected with doing this, such as setting up proper inheritance from Moose::Object and installing (and inlining, at make_immutable time) a constructor that makes sure things like BUILD methods are called. It tries to be as non-intrusive as possible - when this module is used, inheriting from non-Moose classes and inheriting from Moose classes should work identically, aside from the few caveats mentioned below. One of the goals of this module is that including it in a Moose::Exporter-based package used across an entire application should be possible, without interfering with classes that only inherit from Moose modules, or even classes that don't inherit from anything at all.

There are several ways to use this module. The most straightforward is to just use MooseX::NonMoose; in your class; this should set up everything necessary for extending non-Moose modules. MooseX::NonMoose::Meta::Role::Class and MooseX::NonMoose::Meta::Role::Constructor can also be applied to your metaclasses manually, either by passing a -traits option to your use Moose; line, or by applying them using Moose::Util::MetaRole in a Moose::Exporter-based package. MooseX::NonMoose::Meta::Role::Class is the part that provides the main functionality of this module; if you don't care about inlining, this is all you need to worry about. Applying MooseX::NonMoose::Meta::Role::Constructor as well will provide an inlined constructor when you immutabilize your class.

MooseX::NonMoose allows you to manipulate the argument list that gets passed to the superclass constructor by defining a FOREIGNBUILDARGS method. This is called with the same argument list as the BUILDARGS method, but should return a list of arguments to pass to the superclass constructor. This allows MooseX::NonMoose to support superclasses whose constructors would get confused by the extra arguments that Moose requires (for attributes, etc.)

Not all non-Moose classes use new as the name of their constructor. This module allows you to extend these classes by explicitly stating which method is the constructor, during the call to extends. The syntax looks like this:

extends 'Foo' => { -constructor_name => 'create' };

similar to how you can already pass -version in the extends call in a similar way.

BUGS/CAVEATS

Please report any bugs to GitHub Issues at https://github.com/uperl/moosex-nonmoose/issues.

SEE ALSO

SUPPORT

You can find this documentation for this module with the perldoc command.

perldoc MooseX::NonMoose

You can also look for information at:

AUTHOR

Original author: Jesse Luehrs <doy@tozt.net>

Current maintainer: Graham Ollis <plicease@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2009-2025 by Jesse Luehrs.

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