X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=embed.pl;h=8a1f2a0268a1b9f41799e4278a228bd71de0aae7;hb=8fa7688f7865696bdfa78bc12d4ffb78bd1d6103;hp=6aa391ef12747e495263d40b785aba77384fdfd9;hpb=a0a44e237c19cc2b7cf3da120d308da4cb9f777e;p=p5sagit%2Fp5-mst-13.2.git diff --git a/embed.pl b/embed.pl index 6aa391e..8a1f2a0 100755 --- a/embed.pl +++ b/embed.pl @@ -22,7 +22,7 @@ sub do_not_edit ($) $file - Copyright (c) 1997-2002, Larry Wall + Copyright (c) 1997-2003, Larry Wall You may distribute under the terms of either the GNU General Public License or the Artistic License, as specified in the README file. @@ -316,7 +316,11 @@ print EM do_not_edit ("embed.h"), <<'END'; /* (Doing namespace management portably in C is really gross.) */ -#ifndef PERL_HIDE_SHORT_NAMES +/* By defining PERL_NO_SHORT_NAMES (not done by default) the short forms + * (like warn instead of Perl_warn) for the API are not defined. + * Not defining the short forms is a good thing for cleaner embedding. */ + +#ifndef PERL_NO_SHORT_NAMES /* Hide global symbols */ @@ -340,7 +344,7 @@ walk_table { $ret .= hide($func,"Perl_$func"); } } - unless ($flags =~ /A/) { + if ($ret ne '' && $flags !~ /A/) { if ($flags =~ /E/) { $ret = "#if defined(PERL_CORE) || defined(PERL_EXT)\n$ret#endif\n"; } else { @@ -428,7 +432,7 @@ print EM <<'END'; #endif /* PERL_IMPLICIT_CONTEXT */ -#endif /* #ifndef PERL_HIDE_SHORT_NAMES */ +#endif /* #ifndef PERL_NO_SHORT_NAMES */ END @@ -474,7 +478,7 @@ print EM <<'END'; an extra argument but grab the context pointer using the macro dTHX. */ -#if defined(PERL_IMPLICIT_CONTEXT) && !defined(PERL_HIDE_SHORT_NAMES) +#if defined(PERL_IMPLICIT_CONTEXT) && !defined(PERL_NO_SHORT_NAMES) # define croak Perl_croak_nocontext # define deb Perl_deb_nocontext # define die Perl_die_nocontext