In Str§
See primary documentation in context for routine uniparse.
sub uniparse(Str:D $names --> Str:D) method uniparse(Str:D $names: --> Str:D)
Takes string with comma-separated Unicode names of characters and returns a string composed of those characters. Will fail
if any of the characters' names are empty or not recognized. Whitespace around character names is ignored.
say "I {uniparse 'TWO HEARTS'} Raku"; # OUTPUT: «I 💕 Raku» 'TWO HEARTS, BUTTERFLY'.uniparse.say; # OUTPUT: «💕🦋»
See uniname and uninames for routines that work in the opposite direction with a single codepoint and multiple codepoints respectively.
Note that unlike \c[...]
construct available in string interpolation, uniparse
does not accept decimal numerical values. Use chr routine to convert those:
say "\c[1337]"; # OUTPUT: «Թ» say '1337'.chr; # OUTPUT: «Թ»
Note: before being standardized in 2017.12, this routine was known under its working name of parse-names. This denomination will be removed in the 6.e version.
In Cool§
See primary documentation in context for method uniparse.
method uniparse(Cool:D: --> Str:D)
Available as of the 2021.04 release of the Rakudo compiler.
Coerces the invocant to a Str
and then calls the uniparse on that. This mostly only makes sense for Match
objects.