NAME

Specio::Constraint::AnyCan - A class for constraints which require a class name or object with a set of methods

VERSION

version 0.49

SYNOPSIS

my $type = Specio::Constraint::AnyCan->new(...);
print $_, "\n" for @{ $type->methods };

DESCRIPTION

This is a specialized type constraint class for types which require a class name or object with a defined set of methods.

API

This class provides all of the same methods as Specio::Constraint::Simple, with a few differences:

Specio::Constraint::AnyCan->new( ... )

The parent parameter is ignored if it passed, as it is always set to the Defined type.

The inline_generator and constraint parameters are also ignored. This class provides its own default inline generator subroutine reference.

This class overrides the message_generator default if none is provided.

Finally, this class requires an additional parameter, methods. This must be an array reference of method names which the constraint requires. You can also pass a single string and it will be converted to an array reference internally.

$any_can->methods

Returns an array reference containing the methods this constraint requires.

ROLES

This class does the Specio::Constraint::Role::IsaType, Specio::Constraint::Role::Interface, and Specio::Role::Inlinable roles.

SUPPORT

Bugs may be submitted at https://github.com/houseabsolute/Specio/issues.

SOURCE

The source code repository for Specio can be found at https://github.com/houseabsolute/Specio.

AUTHOR

Dave Rolsky <autarch@urth.org>

COPYRIGHT AND LICENSE

This software is Copyright (c) 2012 - 2024 by Dave Rolsky.

This is free software, licensed under:

The Artistic License 2.0 (GPL Compatible)

The full text of the license can be found in the LICENSE file included with this distribution.