1Specio::Library::BuiltiUnsse(r3)Contributed Perl DocumenStpaetciioon::Library::Builtins(3)
2
3
4
6 Specio::Library::Builtins - Implements type constraint objects for
7 Perl's built-in types
8
10 version 0.47
11
13 This library provides a set of types parallel to those provided by
14 Moose.
15
16 The types are in the following hierarchy
17
18 Item
19 Bool
20 Maybe (of `a)
21 Undef
22 Defined
23 Value
24 Str
25 Num
26 Int
27 ClassName
28 Ref
29 ScalarRef (of `a)
30 ArrayRef (of `a)
31 HashRef (of `a)
32 CodeRef
33 RegexpRef
34 GlobRef
35 FileHandle
36 Object
37
38 Item
39 Accepts any value
40
41 Bool
42 Accepts a non-reference that is "undef", an empty string, 0, or 1. It
43 also accepts any object which overloads boolification.
44
45 Maybe (of `a)
46 A parameterizable type which accepts "undef" or the type "`a". If not
47 parameterized this type will accept any value.
48
49 Undef
50 Only accepts "undef".
51
52 Value
53 Accepts any non-reference value.
54
55 Str
56 Accepts any non-reference value or an object which overloads
57 stringification.
58
59 Num
60 Accepts nearly the same values as "Scalar::Util::looks_like_number",
61 but does not accept numbers with leading or trailing spaces,
62 infinities, or NaN. Also accepts an object which overloads
63 numification.
64
65 Int
66 Accepts any integer value, or an object which overloads numification
67 and numifies to an integer.
68
69 ClassName
70 Accepts any value which passes "Str" where the string is a loaded
71 package.
72
73 Ref
74 Accepts any reference.
75
76 ScalarRef (of `a)
77 Accepts a scalar reference or an object which overloads scalar
78 dereferencing. If parameterized, the dereferenced value must be of
79 type "`a".
80
81 ArrayRef (of `a)
82 Accepts a array reference or an object which overloads array
83 dereferencing. If parameterized, the values in the arrayref must be of
84 type "`a".
85
86 HashRef (of `a)
87 Accepts a hash reference or an object which overloads hash
88 dereferencing. If parameterized, the values in the hashref must be of
89 type "`a".
90
91 CodeRef
92 Accepts a code (sub) reference or an object which overloads code
93 dereferencing.
94
95 RegexpRef
96 Accepts a regex object created by "qr//" or an object which overloads
97 regex interpolation.
98
99 GlobRef
100 Accepts a glob reference or an object which overloads glob
101 dereferencing.
102
103 FileHandle
104 Accepts a glob reference which is an open file handle, any "IO::Handle"
105 Object or subclass, or an object which overloads glob dereferencing and
106 returns a glob reference which is an open file handle.
107
108 Object
109 Accepts any blessed object.
110
112 Bugs may be submitted at
113 <https://github.com/houseabsolute/Specio/issues>.
114
115 I am also usually active on IRC as 'autarch' on "irc://irc.perl.org".
116
118 The source code repository for Specio can be found at
119 <https://github.com/houseabsolute/Specio>.
120
122 Dave Rolsky <autarch@urth.org>
123
125 This software is Copyright (c) 2012 - 2021 by Dave Rolsky.
126
127 This is free software, licensed under:
128
129 The Artistic License 2.0 (GPL Compatible)
130
131 The full text of the license can be found in the LICENSE file included
132 with this distribution.
133
134
135
136perl v5.34.0 2022-01-21 Specio::Library::Builtins(3)