GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages
Types::TypeTiny(3) User Contributed Perl Documentation Types::TypeTiny(3)

Types::TypeTiny - type constraints used internally by Type::Tiny

This module is covered by the Type-Tiny stability policy.

Dogfooding.

This isn't a real Type::Library-based type library; that would involve too much circularity. But it exports some type constraints which, while designed for use within Type::Tiny, may be more generally useful.

  • StringLike

    Accepts strings and objects overloading stringification.

  • HashLike[`a]

    Accepts hashrefs and objects overloading hashification.

    Since Types::TypeTiny 1.012, may be parameterized with another type constraint like HashLike[Int].

  • ArrayLike[`a]

    Accepts arrayrefs and objects overloading arrayfication.

    Since Types::TypeTiny 1.012, may be parameterized with another type constraint like ArrayLike[Int].

  • CodeLike

    Accepts coderefs and objects overloading codification.

  • TypeTiny

    Accepts blessed Type::Tiny objects.

  • _ForeignTypeConstraint

    Any reference which to_TypeTiny recognizes as something that can be coerced to a Type::Tiny object.

    Yes, the underscore is included.

"to_TypeTiny($constraint)"
Promotes (or "demotes" if you prefer) a Moose::Meta::TypeConstraint object to a Type::Tiny object.

Can also handle Validation::Class objects. Type constraints built from Validation::Class objects deliberately ignore field filters when they do constraint checking (and go to great lengths to do so); using filters for coercion only. (The behaviour of "coerce" if we don't do that is just too weird!)

Can also handle any object providing "check" and "get_message" methods. (This includes Mouse::Meta::TypeConstraint objects.) If the object also provides "has_coercion" and "coerce" methods, these will be used too.

Can also handle coderefs (but not blessed coderefs or objects overloading "&{}"). Coderefs are expected to return true iff $_ passes the constraint. If $_ fails the type constraint, they may either return false, or die with a helpful error message.

These are implemented so that "Types::TypeTiny->meta->get_type($foo)" works, for rough compatibility with a real Type::Library type library.
"meta"
"type_names"
"get_type($name)"
"has_type($name)"
"coercion_names"
"get_coercion($name)"
"has_coercion($name)"

Please report any bugs to <https://github.com/tobyink/p5-type-tiny/issues>.

Type::Tiny.

Toby Inkster <tobyink@cpan.org>.

This software is copyright (c) 2013-2014, 2017-2021 by Toby Inkster.

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

THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
2021-07-31 perl v5.32.1

Search for    or go to Top of page |  Section 3 |  Main Index

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with ManDoc.