At the moment, I’m writing these arrays by hand.
For example, the Miscellaneous Mathematical Symbols-A block has an entry in hash like this:
my %symbols = (
...
miscellaneous_mathematical_symbols_a => [(0x27C0..0x27CA), 0x27CC,
(0x27D0..0x27EF)],
...
)
The simpler, ‘continuous’ array
miscellaneous_mathematical_symbols_a => [0x27C0..0x27EF]
doesn’t work because Unicode blocks have holes in them. For example, there’s nothing at 0x27CB. Take a look at the code chart [PDF].
Writing these arrays by hand is tedious, error-prone and a bit fun. And I get the feeling that someone has already tackled this in Perl!
Perhaps you want Unicode::UCD? Use its
charblockroutine to get the range of any named block. If you want to get those names, you can usecharblocks.This module is really just an interface to the Unicode databases that come with Perl already, so if you have to do something fancier, you can look at the lib/5.x.y/unicore/UnicodeData.txt or the various other files in that same directory to get what you need.
Here’s what I came up with to create your
%symbols. I go through all the blocks (although in this sample I skip that ones without “Math” in their name. I get the starting and ending code points and check which ones are assigned. From that, I create a custom property that I can use to check if a character is in the range and assigned.If I were going to do this a lot, I’d use the same thing to create a Perl source file that has the custom properties already defined so I can just use them right away in any of my work. None of the data should change until you update your Unicode data.
That gives me output suitable for a Perl library: