summaryrefslogtreecommitdiff
path: root/regen/mg_vtable.pl
diff options
context:
space:
mode:
authorNicholas Clark <nick@ccl4.org>2011-05-15 16:33:02 +0100
committerNicholas Clark <nick@ccl4.org>2011-06-11 10:40:00 +0200
commit23cfd2fcc891e2298c078e093010af5bdb902cc6 (patch)
tree6bef879b1327a93bb53e0ca3d4d8718870ba7834 /regen/mg_vtable.pl
parent52f4950575a77c74948f90dd3e24ac66b684eb4a (diff)
downloadperl-23cfd2fcc891e2298c078e093010af5bdb902cc6.tar.gz
Sort magic and magic vtable names in files generated by mg_vtable.pl
Magic is sorted case insensitively, with upper case before lower case. vtable names are all lowercase letters.
Diffstat (limited to 'regen/mg_vtable.pl')
-rw-r--r--regen/mg_vtable.pl25
1 files changed, 17 insertions, 8 deletions
diff --git a/regen/mg_vtable.pl b/regen/mg_vtable.pl
index dc3fb78331..3d242116a9 100644
--- a/regen/mg_vtable.pl
+++ b/regen/mg_vtable.pl
@@ -18,7 +18,7 @@ BEGIN {
require 'regen/regen_lib.pl';
}
-my @mg =
+my %mg =
(
sv => { char => '\0', vtable => 'sv', readonly_acceptable => 1,
desc => 'Special scalar variable' },
@@ -105,7 +105,7 @@ my @mg =
);
# These have a subtly different "namespace" from the magic types.
-my @sig =
+my %sig =
(
'sv' => {get => 'get', set => 'set', len => 'len'},
'env' => {set => 'set_all_env', clear => 'clear_all_env'},
@@ -156,7 +156,7 @@ print $vt <<'EOH';
EOH
my $longest = 0;
-foreach (grep {!ref $_} @mg) {
+foreach (keys %mg) {
$longest = length $_ if length $_ > $longest;
}
@@ -172,8 +172,16 @@ foreach (grep {!ref $_} @mg) {
{
my $longest_p1 = $longest + 1;
- while (my ($name, $data) = splice @mg, 0, 2) {
- my $i = ord eval qq{"$data->{char}"};
+ my %mg_order;
+ while (my ($name, $data) = each %mg) {
+ my $byte = eval qq{"$data->{char}"};
+ $data->{byte} = $byte;
+ $mg_order{(uc $byte) . $byte} = $name;
+ }
+ foreach (sort keys %mg_order) {
+ my $name = $mg_order{$_};
+ my $data = $mg{$name};
+ my $i = ord $data->{byte};
unless ($data->{unknown_to_sv_magic}) {
my $value = $data->{vtable}
? "want_vtbl_$data->{vtable}" : 'magic_vtable_max';
@@ -199,8 +207,8 @@ foreach (grep {!ref $_} @mg) {
}
}
+my @names = sort keys %sig;
{
- my @names = grep {!ref $_} @sig;
my $want = join ",\n ", (map {"want_vtbl_$_"} @names), 'magic_vtable_max';
my $names = join qq{",\n "}, @names;
@@ -246,7 +254,8 @@ EOH
my @vtable_names;
my @aliases;
-while (my ($name, $data) = splice @sig, 0, 2) {
+while (my $name = shift @names) {
+ my $data = $sig{$name};
push @vtable_names, $name;
my @funcs = map {
$data->{$_} ? "Perl_magic_$data->{$_}" : 0;
@@ -256,7 +265,7 @@ while (my ($name, $data) = splice @sig, 0, 2) {
my $funcs = join ", ", @funcs;
# Because we can't have a , after the last {...}
- my $comma = @sig ? ',' : '';
+ my $comma = @names ? ',' : '';
print $vt "$data->{cond}\n" if $data->{cond};
print $vt " { $funcs }$comma\n";