Object hashes with a limitation on the type of values
does Associative
The QuantHash
role provides the basic functionality shared by the Setty, Baggy and Mixy roles. These provide object hashes whose values are limited in some way.
QuantHashes
are what set operators use internally.
method hash()
Coerces the QuantHash
object to a Hash (by stringifying the objects for the keys) with the values of the hash limited to the same limitation as QuantHash
, and returns that.
method Hash()
Coerces the QuantHash
object to a Hash (by stringifying the objects for the keys) without any limitations on the values, and returns that.
method of()
Returns the type of value a value of this QuantHash
may have. This is typically Bool for Setty, UInt for Baggy or Real for Mixy roles.
method keyof()
Returns the type of value a key of this subclass of QuantHash
may have. This is typically Mu, which is also the default for punned QuantHashes.
method Capture()
Returns the object as a Capture
by previously coercing it to a Hash
.
multi method list(QuantHash:)
Returns a list of Pair objects of all keys and values in the QuantHash.
method Setty(--> Setty)
Coerce the QuantHash
object to the equivalent object that uses the Setty role. Note that for Mixy type coercion items with negative values will be skipped.
my is Bag = one => 1, two => 2;say .Setty; # OUTPUT: «Set(one two)»my is Mix = one => 1, minus => -1;say .Setty; # OUTPUT: «Set(one)»
method Baggy(--> Baggy)
Coerce the QuantHash
object to the equivalent object that uses the Baggy role. Note that for Mixy type coercion items with negative values will be skipped.
my is Set = <one two>;say .Baggy; # OUTPUT: «Bag(one two)»my is Mix = one => 1, minus => -1;say .Baggy; # OUTPUT: «Bag(one)»
method Mixy(--> Mixy)
Coerce the QuantHash
object to the equivalent object that uses the Mixy role.
my is Set = <one two>;say .Mixy; # OUTPUT: «Mix(one two)»my is Bag = one => 1, two => 2;say .Mixy; # OUTPUT: «Mix(one two(2))»