diff options
author | Karl Williamson <khw@cpan.org> | 2014-04-28 17:26:56 -0600 |
---|---|---|
committer | Karl Williamson <khw@cpan.org> | 2014-05-31 10:27:27 -0600 |
commit | ad88cddbc3a6f8949cf701b2b2170b5b774f6500 (patch) | |
tree | 077e5d92019bb9fcc0f630efe63dfdf046b55120 /regen | |
parent | 64d34faf68a92ef367fc8a7c637d1762552df737 (diff) | |
download | perl-ad88cddbc3a6f8949cf701b2b2170b5b774f6500.tar.gz |
regen/unicode_constants.pl: Update to use EBCDIC utilities
This causes the generated unicode_constants.h to be valid on all
supported platforms
Diffstat (limited to 'regen')
-rw-r--r-- | regen/unicode_constants.pl | 27 |
1 files changed, 19 insertions, 8 deletions
diff --git a/regen/unicode_constants.pl b/regen/unicode_constants.pl index 8d68563540..68be8e5daf 100644 --- a/regen/unicode_constants.pl +++ b/regen/unicode_constants.pl @@ -2,10 +2,11 @@ use v5.16.0; use strict; use warnings; require 'regen/regen_lib.pl'; +require 'regen/charset_translations.pl'; use charnames qw(:loose); my $out_fh = open_new('unicode_constants.h', '>', - {style => '*', by => $0, + {style => '*', by => $0, from => "Unicode data"}); print $out_fh <<END; @@ -56,7 +57,14 @@ END # of UTF-8, and to generate proper EBCDIC as well as ASCII without manually # having to figure things out. -while ( <DATA> ) { +my @data = <DATA>; + +foreach my $charset (get_supported_code_pages()) { + print $out_fh "\n" . get_conditional_compile_line_start($charset); + + my @a2n = get_a2n($charset); + +for ( @data ) { chomp; # Convert any '#' comments to /* ... */; empty lines and comments are @@ -96,15 +104,17 @@ while ( <DATA> ) { die "Unknown code point '$name_or_cp' at line $.: $_\n" unless $undef_ok; $name = ""; } - $cp = utf8::unicode_to_native($U_cp); } else { $name = $name_or_cp; - $cp = charnames::vianame($name =~ s/_/ /gr); - $U_cp = utf8::native_to_unicode($cp); die "Unknown name '$name' at line $.: $_\n" unless defined $name; + $U_cp = charnames::vianame($name =~ s/_/ /gr); } + $cp = ($U_cp < 256) + ? $a2n[$U_cp] + : $U_cp; + $name = $desired_name if $name eq "" && $desired_name; $name =~ s/[- ]/_/g; # The macro name can have no blanks nor dashes @@ -116,8 +126,7 @@ while ( <DATA> ) { $str = sprintf "0x%02X", $cp; # Is a numeric constant } else { - $str = join "", map { sprintf "\\x%02X", $_ } - unpack("U0C*", pack("U", $cp)); + $str = join "", map { sprintf "\\x%02X", ord $_ } split //, cp_2_utfbytes($U_cp, $charset); $suffix = '_UTF8'; if (! defined $flag || $flag =~ /^ string (_skip_if_undef)? $/x) { @@ -136,7 +145,9 @@ while ( <DATA> ) { die "Unknown flag at line $.: $_\n"; } } - printf $out_fh "#define %s%s %s /* U+%04X */\n", $name, $suffix, $str, $U_cp; + printf $out_fh "# define %s%s %s /* U+%04X */\n", $name, $suffix, $str, $U_cp; +} + print $out_fh "\n" . get_conditional_compile_line_end(); } print $out_fh "\n#endif /* H_UNICODE_CONSTANTS */\n"; |