1Specio::Constraint::ObjUescetrCaCno(n3t)ributed Perl DocSupmeecnitoa:t:iCoonnstraint::ObjectCan(3)
2
3
4
6 Specio::Constraint::ObjectCan - A class for constraints which require
7 an object with a set of methods
8
10 version 0.48
11
13 my $type = Specio::Constraint::ObjectCan->new(...);
14 print $_, "\n" for @{ $type->methods };
15
17 This is a specialized type constraint class for types which require an
18 object with a defined set of methods.
19
21 This class provides all of the same methods as
22 Specio::Constraint::Simple, with a few differences:
23
24 Specio::Constraint::ObjectCan->new( ... )
25 The "parent" parameter is ignored if it passed, as it is always set to
26 the "Object" type.
27
28 The "inline_generator" and "constraint" parameters are also ignored.
29 This class provides its own default inline generator subroutine
30 reference.
31
32 This class overrides the "message_generator" default if none is
33 provided.
34
35 Finally, this class requires an additional parameter, "methods". This
36 must be an array reference of method names which the constraint
37 requires. You can also pass a single string and it will be converted to
38 an array reference internally.
39
40 $object_can->methods
41 Returns an array reference containing the methods this constraint
42 requires.
43
45 This class does the Specio::Constraint::Role::CanType,
46 Specio::Constraint::Role::Interface, and Specio::Role::Inlinable roles.
47
49 Bugs may be submitted at
50 <https://github.com/houseabsolute/Specio/issues>.
51
53 The source code repository for Specio can be found at
54 <https://github.com/houseabsolute/Specio>.
55
57 Dave Rolsky <autarch@urth.org>
58
60 This software is Copyright (c) 2012 - 2022 by Dave Rolsky.
61
62 This is free software, licensed under:
63
64 The Artistic License 2.0 (GPL Compatible)
65
66 The full text of the license can be found in the LICENSE file included
67 with this distribution.
68
69
70
71perl v5.36.0 2023-01-20 Specio::Constraint::ObjectCan(3)