NAME

FP::PureHash

SYNOPSIS

use FP::PureHash;
use FP::Show; use FP::Predicates;

my $h = purehash hi => 123, there => "World";
my $h2 = $h->set("hi", "again");
is $h->ref("there"), "World";
is $$h{there}, "World";
is show($h), "purehash('hi' => 123, 'there' => 'World')";
is show($h2), "purehash('hi' => 'again', 'there' => 'World')";
is is_pure($h2), 1;

like( (eval { purehash hi => 1, hi => 1, there => 2 } || $@),
      qr/^duplicate key: 'hi' at/ );
like( (eval { $$h{there_} || 1} || $@),
      # the detailed exception message may change!
      qr/^Attempt to access disallowed key 'there_' in a restricted hash/ );

DESCRIPTION

Hash tables, currently based simply on Perl's internal hashes. They are immutable, and restricted which means that accessing non-existing keys yields an exception.

TODO

- performant functional updates (currently the `set` method simply copies the whole table)

- more methods, move/adapt set functionality from FP::Hash and FP::HashSet

- a maybe_ref that returns FP::Failure or FP::Maybe ?

- non-string keys?

SEE ALSO

Implements: FP::Abstract::Map.

NOTE

This is alpha software! Read the status section in the package README or on the website.