summaryrefslogtreecommitdiff
path: root/reentr.pl
diff options
context:
space:
mode:
authorJarkko Hietaniemi <jhi@iki.fi>2003-04-28 06:32:47 +0000
committerJarkko Hietaniemi <jhi@iki.fi>2003-04-28 06:32:47 +0000
commit0891a229ed34cb34ddb76f1813dcb76d39a174fb (patch)
tree20ad4c23e4db58d98bc0b4a4f3ff7bb7b94f520c /reentr.pl
parent15f0f28a65432bb5e8f8e84f9d63806555182655 (diff)
downloadperl-0891a229ed34cb34ddb76f1813dcb76d39a174fb.tar.gz
Detecting errors of reentrant APIs: getgrgid_r and the like
when returning an int can either return the error in the return value or in the errno. We need a new per-interp variable to store the return value instead of clobbering the errno with it. The new variable, PL_reentrant_retint, is only used within the reentrancy framework, and immediately after it's set, so there should not be similar visibility issues as for the errno. Spotted by Edward Moy. p4raw-id: //depot/perl@19357
Diffstat (limited to 'reentr.pl')
-rw-r--r--reentr.pl16
1 files changed, 12 insertions, 4 deletions
diff --git a/reentr.pl b/reentr.pl
index d9b1976563..339529fcdb 100644
--- a/reentr.pl
+++ b/reentr.pl
@@ -365,6 +365,7 @@ EOF
EOF
}
}
+ return if @F == 1;
push @define, <<EOF;
/* Any of the @F using \L$n? */
@@ -678,7 +679,7 @@ EOF
$w = ", $w" if length $v;
}
my $call = "${func}_r($v$w)";
- $call = "((errno = $call))" if $r eq 'I' && $func ne 'random';
+ $call = "((PL_reentrant_retint = $call))" if $r eq 'I' && $func ne 'random';
push @wrap, <<EOF;
# if !defined($func) && ${FUNC}_R_PROTO == REENTRANT_PROTO_$p
EOF
@@ -689,9 +690,15 @@ EOF
} else {
if ($func =~ /^get/) {
my $rv = $v ? ", $v" : "";
- push @wrap, <<EOF;
-# define $func($v) ($call$test ? $true : (errno == ERANGE ? Perl_reentrant_retry("$func"$rv) : 0))
+ if ($r eq 'I') {
+ push @wrap, <<EOF;
+# define $func($v) ($call$test ? $true : (((PL_reentrant_retint > 0 && PL_reentrant_retint == ERANGE) || (errno == ERANGE)) ? Perl_reentrant_retry("$func"$rv) : 0))
+EOF
+ } else {
+ push @wrap, <<EOF;
+# define $func($v) ($call$test ? $true : ((errno == ERANGE) ? Perl_reentrant_retry("$func"$rv) : 0))
EOF
+ }
} else {
push @wrap, <<EOF;
# define $func($v) ($call$test ? $true : 0)
@@ -722,6 +729,7 @@ typedef struct {
/* The wrappers. */
@wrap
+
#endif /* USE_REENTRANT_API */
#endif
@@ -788,7 +796,7 @@ Perl_reentrant_retry(const char *f, ...)
dTHX;
void *retptr = NULL;
#ifdef USE_REENTRANT_API
-# if defined(USE_HOSTENT_BUFFER) || defined(USE_GRENT_BUFFER) || defined(USE_NETENT_BUFFER) || defined(USE_PWENT_BUFFER) || defined(USE_PROTOENT_BUFFER) || defined(USE_SRVENT_BUFFER)
+# if defined(USE_HOSTENT_BUFFER) || defined(USE_GRENT_BUFFER) || defined(USE_NETENT_BUFFER) || defined(USE_PWENT_BUFFER) || defined(USE_PROTOENT_BUFFER) || defined(USE_SERVENT_BUFFER)
void *p0;
# endif
# if defined(USE_SERVENT_BUFFER)