X-Git-Url: https://perl5.git.perl.org/perl5.git/blobdiff_plain/8261f8eb698db59828f3e3dd7a1ee82976ab259e..9abc3fabb7a778345c5a27cb8e6bfc4a934b4ca0:/overload.pl diff --git a/overload.pl b/overload.pl index 9def29f..d4ba9a7 100644 --- a/overload.pl +++ b/overload.pl @@ -1,9 +1,18 @@ #!/usr/bin/perl -w - # -# Generate overload.h +# Regenerate (overwriting only if changed): +# +# overload.h +# overload.c +# lib/overload/numbers.pm +# +# from information stored in the DATA section of this file. +# # This allows the order of overloading constants to be changed. -# +# +# Accepts the standard regen_lib -q and -v args. +# +# This script is normally invoked from regen.pl. BEGIN { # Get function prototypes @@ -12,6 +21,8 @@ BEGIN { use strict; +use File::Spec::Functions qw(catdir catfile);; + my (@enums, @names); while () { next if /^#/; @@ -21,11 +32,48 @@ while () { push @names, $name; } -safer_unlink ('overload.h', 'overload.c'); -die "overload.h: $!" unless open(C, ">overload.c"); -binmode C; -die "overload.h: $!" unless open(H, ">overload.h"); -binmode H; +safer_unlink (catfile(qw(lib overload numbers.pm))); +my $c = safer_open("overload.c-new"); +my $h = safer_open("overload.h-new"); +mkdir("lib/overload") unless -d catdir(qw(lib overload)); +my $p = safer_open(catfile(qw(lib overload numbers.pm))); + + +select $p; + +{ +local $" = "\n "; +print <<"EOF"; +# -*- buffer-read-only: t -*- +# +# lib/overload/numbers.pm +# +# Copyright (C) 2008 by Larry Wall and others +# +# You may distribute under the terms of either the GNU General Public +# License or the Artistic License, as specified in the README file. +# +# !!!!!!! DO NOT EDIT THIS FILE !!!!!!! +# This file is built by overload.pl +# + +package overload::numbers; + +our \@names = qw# + @names +#; + +our \@enums = qw# + @enums +#; + +{ my \$i = 0; our %names = map { \$_ => \$i++ } \@names } + +{ my \$i = 0; our %enums = map { \$_ => \$i++ } \@enums } + +EOF +} + sub print_header { my $file = shift; @@ -46,10 +94,10 @@ sub print_header { EOF } -select C; +select $c; print_header('overload.c'); -select H; +select $h; print_header('overload.h'); print <<'EOF'; @@ -67,27 +115,43 @@ print <<'EOF'; EOF -print C <<'EOF'; +print $c <<'EOF'; #define AMG_id2name(id) (PL_AMG_names[id]+1) +#define AMG_id2namelen(id) (PL_AMG_namelens[id]-1) + +static const U8 PL_AMG_namelens[NofAMmeth] = { +EOF -char * const PL_AMG_names[NofAMmeth] = { +my $last = pop @names; + +print $c " $_,\n" foreach map { length $_ } @names; + +my $lastlen = length $last; +print $c <<"EOT"; + $lastlen +}; + +static const char * const PL_AMG_names[NofAMmeth] = { /* Names kept in the symbol table. fallback => "()", the rest has "(" prepended. The only other place in perl which knows about this convention is AMG_id2name (used for debugging output and 'nomethod' only), the only other place which has it hardwired is overload.pm. */ -EOF +EOT -my $last = pop @names; -print C " \"$_\",\n" foreach map { s/(["\\"])/\\$1/g; $_ } @names; +print $c " \"$_\",\n" foreach map { s/(["\\"])/\\$1/g; $_ } @names; -print C <<"EOT"; +print $c <<"EOT"; "$last" }; EOT -close H or die $!; +safer_close($h); +safer_close($c); +safer_close($p); +rename_if_different("overload.c-new", "overload.c"); +rename_if_different("overload.h-new","overload.h"); __DATA__ # Fallback should be the first @@ -164,5 +228,7 @@ repeat_ass (x= concat (. concat_ass (.= smart (~~ +ftest (-X +regexp (qr # Note: Perl_Gv_AMupdate() assumes that DESTROY is the last entry DESTROY DESTROY