1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00

Bug 788: Define n_a variables if the POPpx macro of Perl needs them.

The configure script checks whether it is possible to compile a use of
POPpx without an n_a variable; if not, the source code then defines
those variables.  This is slower than including Perl's patchlevel.h
and comparing the version numbers to 5.8.8 but I expect this to be
more reliable as well.
This commit is contained in:
Kalle Olavi Niemitalo 2006-12-09 20:26:06 +02:00 committed by Kalle Olavi Niemitalo
parent e815e07179
commit 432969a3a9
2 changed files with 24 additions and 1 deletions

View File

@ -783,6 +783,21 @@ if test "$enable_perl" = "yes"; then
cf_result=yes, cf_result=no) cf_result=yes, cf_result=no)
fi fi
if test "$cf_result"; then AC_MSG_RESULT($cf_result); fi
AC_MSG_CHECKING([whether POPpx works without an n_a variable])
AC_TRY_COMPILE([
#include <EXTERN.h>
#include <perl.h>
extern PerlInterpreter *my_perl;
],
[dSP; (void) POPpx;],
[AC_MSG_RESULT([yes])
AC_DEFINE([CONFIG_PERL_POPPX_WITHOUT_N_A], [1],
[Define if using Perl 5.8.8 or later, where the "POPpx" macro
no longer needs an "n_a" variable like it did in 5.8.7])],
[AC_MSG_RESULT([no])])
if test "$cf_result" != "yes"; then if test "$cf_result" != "yes"; then
EL_RESTORE_FLAGS EL_RESTORE_FLAGS
else else
@ -793,7 +808,6 @@ else
AC_SUBST(PERL_CFLAGS) AC_SUBST(PERL_CFLAGS)
fi fi
if test "$cf_result"; then AC_MSG_RESULT($cf_result); fi
dnl =================================================================== dnl ===================================================================
dnl Check for Python dnl Check for Python
dnl =================================================================== dnl ===================================================================

View File

@ -44,6 +44,9 @@ do_script_hook_goto_url(struct session *ses, unsigned char **url)
if (SvTRUE(ERRSV)) count = 0; /* FIXME: error message ? */ if (SvTRUE(ERRSV)) count = 0; /* FIXME: error message ? */
SPAGAIN; SPAGAIN;
if (count == 1) { if (count == 1) {
#ifndef CONFIG_PERL_POPPX_WITHOUT_N_A
STRLEN n_a; /* Used by POPpx macro. */
#endif
unsigned char *new_url = POPpx; unsigned char *new_url = POPpx;
if (new_url) { if (new_url) {
@ -89,6 +92,9 @@ do_script_hook_follow_url(unsigned char **url)
if (SvTRUE(ERRSV)) count = 0; /* FIXME: error message ? */ if (SvTRUE(ERRSV)) count = 0; /* FIXME: error message ? */
SPAGAIN; SPAGAIN;
if (count == 1) { if (count == 1) {
#ifndef CONFIG_PERL_POPPX_WITHOUT_N_A
STRLEN n_a; /* Used by POPpx macro. */
#endif
unsigned char *new_url = POPpx; unsigned char *new_url = POPpx;
if (new_url) { if (new_url) {
@ -185,6 +191,9 @@ do_script_hook_get_proxy(unsigned char **new_proxy_url, unsigned char *url)
(void) POPs; (void) POPs;
mem_free_set(new_proxy_url, NULL); mem_free_set(new_proxy_url, NULL);
} else { } else {
#ifndef CONFIG_PERL_POPPX_WITHOUT_N_A
STRLEN n_a; /* Used by POPpx macro. */
#endif
unsigned char *new_url = POPpx; unsigned char *new_url = POPpx;
mem_free_set(new_proxy_url, stracpy(new_url)); mem_free_set(new_proxy_url, stracpy(new_url));