NAME

Smart::Match - Smart matching utilities

VERSION

version 0.003

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($matcher)

Matches a list whose elements all match $matcher.

contains($matcher)

Matches a list that contains an element matching $matcher.

sorted($matcher)

Sorts a list and matches it against $matcher.

hash()

Matches any unblessed hash.

hash_keys($matcher)

Match a list of hash keys against $matcher.

hash_values($matches)

Match a list of hash values 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.