diff options
author | Karl Williamson <khw@khw-desktop.(none)> | 2010-05-04 21:43:56 -0600 |
---|---|---|
committer | Steffen Mueller <smueller@cpan.org> | 2010-05-30 17:10:06 +0200 |
commit | 9ef2b94f54586a775e4e47eebd8bbd9e08ce5fdd (patch) | |
tree | 2864fdea6f1e2d20717471e23ac2a0144c5e750b | |
parent | 28093d0e3328797fc0783f9d909d7931ba57bd59 (diff) | |
download | perl-9ef2b94f54586a775e4e47eebd8bbd9e08ce5fdd.tar.gz |
Add mktables option for development use
The -output_names option was added. It will cause the generated file
tables to not have ranges, and each line will have the character name.
This makes it easier to compare what characters are in given tables,
from version to version, or to compare the differences between
properties.
-rw-r--r-- | lib/unicore/mktables | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/lib/unicore/mktables b/lib/unicore/mktables index 7dfff8c348..ebf8309d8d 100644 --- a/lib/unicore/mktables +++ b/lib/unicore/mktables @@ -610,6 +610,10 @@ my $glob_list = 0; # ? Should we try to include unknown .txt files # in the input. my $output_range_counts = 1; # ? Should we include the number of code points # in ranges in the output +my $output_names = 0; # ? Should character names be in the output +my @viacode; # Contains the 1 million character names, if + # $output_names is true + # Verbosity levels; 0 is quiet my $NORMAL_VERBOSITY = 1; my $PROGRESS = 2; @@ -665,6 +669,9 @@ while (@ARGV) { elsif ($arg eq '-c') { $output_range_counts = ! $output_range_counts } + elsif ($arg eq '-output_names') { + $output_names = 1; + } else { my $with_c = 'with'; $with_c .= 'out' if $output_range_counts; # Complements the state @@ -689,6 +696,9 @@ usage: $0 [-c|-p|-q|-v|-w] [-C dir] [-L filelist] [ -P pod_dir ] -maketest : Make test script 'TestProp.pl' in current (or -C directory), overrides -T -makelist : Rewrite the file list $file_list based on current setup + -output_names : Output each character's name in the table files; useful for + doing what-ifs, looking at diffs; is slow, memory intensive, + resulting tables are usable but very large. -check A B : Executes $0 only if A and B are the same END } @@ -4199,6 +4209,7 @@ sub trace { return main::trace(@_); } $status{$addr} = delete $args{'Status'} || $NORMAL; $status_info{$addr} = delete $args{'_Status_Info'} || ""; $range_size_1{$addr} = delete $args{'Range_Size_1'} || 0; + $range_size_1{$addr} = 1 if $output_names; # Make sure 1 name per line my $description = delete $args{'Description'}; my $externally_ok = delete $args{'Externally_Ok'}; @@ -4670,6 +4681,15 @@ sub trace { return main::trace(@_); } if ($start == $end || $range_size_1) { for my $i ($start .. $end) { push @OUT, sprintf "%04X\t\t%s\n", $i, $value; + if ($output_names) { + if (! defined $viacode[$i]) { + $viacode[$i] = + Property::property_ref('Perl_Charnames') + ->value_of($i) + || ""; + } + $OUT[-1] =~ s/\n/\t# $viacode[$i]\n/; + } } } else { |