NAME
Match::Smart - Smart matching utilities
VERSION
version 0.001
SYNOPSIS
given ($foo) {
say 'We've got a positive number' when positive;
say 'We've got an array' when array;
say 'We've got a non-empty string' when string_length(positive);
}
DESCRIPTION
This module provides a number of helper functions for smartmatching. Some are simple functions that directly match the left hand side, such as
$foo ~~ positive
$bar ~~ array
Others are higher-order matchers that take one or more matchers as an argument, such as
$foo ~~ string_length(positive)
$bar ~~ any(array, hash)
Do note that ordinary values are matchers too, so
$baz ~~ any(1,2,3)
will also do what you mean.
FUNCTIONS
always()
This always matches.
never()
This never matches.
any(@matchers)
This matches if the left hand side matches any of @matchers
.
all(@matchers)
This matches if the left hand side matches all of @matchers
.
none(@matchers)
This matches if the left hand side matches none of @matchers
.
one(@matchers)
This matches if the left hand side matches exactly one of @matchers
.
true()
This matches if the left hand side is true.
false()
This matches if the left hand side is false.
number()
This matches if the left hand side is a number.
integer()
This matches if the left hand side is an integer.
even()
This matches if the left hand side is even.
odd()
This matches if the left hand side is odd.
more_than($cutoff)
Matches if the left hand side is more than $cutoff
.
at_least($cutoff)
Matches if the left hand side is at least $cutoff
.
less_than($cutoff)
Matches if the left hand side is less than $cutoff
.
at_most($cutoff)
Matches if the left hand side is at most $cutoff
.
positive()
This is a synonym for more_than(0)
.
negative()
This is a synonym for less_than(0)
.
range($bottom, $top)
A synonym for all(at_least($bottom, at_most($top))
.
numwise($number)
Matches the left hand side numerically with $number if that makes sense, returns false otherwise.
string()
Matches any string, that is any defined value that's that's not a reference without string overloading.
stringwise($string)
Matches the left hand side lexographically with $string if that makes sense, returns false otherwise.
string_length($matcher)
Matches the string's length
object()
Matches any object (that is, a blessed reference).
instance_of($class)
Matches any instance of class $class
.
ref_type($type)
Matches any unblessed reference of type $type.
array()
Matches any unblessed array.
array_length($matcher)
Matches any unblessed array whose length matches $matcher
.
tuple(@entries)
Matches a list whose elements match @entries
one by one.
head(@elements)
Matches a list whose head elements match @entries
one by one.
sequence($matches)
Matches a list whose elements all match $matcher
.
hash()
Matches any unblessed hash.
hash_keys($matcher)
Match a sorted list of hash keys against $matcher.
match { ... }
Create a new matching function. It will be run with the left-hand side in $_
.
delegate { ... } $matcher
Run the block, and then match the return value against $matcher
.
AUTHOR
Leon Timmermans <leont@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2011 by Leon Timmermans.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.