summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNicholas Clark <nick@ccl4.org>2013-12-09 09:15:10 +0100
committerNicholas Clark <nick@ccl4.org>2013-12-27 12:27:28 +0100
commitb122cba11755f8bed9555c4070f718e5321f3c79 (patch)
tree7f17f598fe7b762e38c9f2bb9d0ba6732533b523
parentd183113e9d20c519bfcbd56d436133db3e6a9ec1 (diff)
downloadperl-b122cba11755f8bed9555c4070f718e5321f3c79.tar.gz
Fix sfio breakage caused by the fix for RT #78494.
Commit 2e0cfa16dea85dd3 (Feb 2011) fixed RT #78494, but inadvertently broke non-PerlIO configurations. -Uuseperlio was restored in March 2011 with commit b6ae43b72863e12d, but this change is needed to restore the sfio build. This is the last fix needed to get blead building with -Dusesfio, after 10 years of breakage. However, many many tests still fail (and one hangs). Note, specifically this is only tested with sfio97. Perl is making a couple of cheating assumptions which break with sfio2005, and I've not attempted to fix Perl's naughtiness to get it to build with current sfio. (Nor has anyone else in the past 8 years, it would seem. Or even reported a problem.)
-rw-r--r--util.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/util.c b/util.c
index af7cdadcb3..26a002abe7 100644
--- a/util.c
+++ b/util.c
@@ -26,7 +26,7 @@
#include "perl.h"
#include "reentr.h"
-#ifdef USE_PERLIO
+#if defined(USE_PERLIO) && !defined(USE_SFIO)
#include "perliol.h" /* For PerlIOUnix_refcnt */
#endif
@@ -2728,7 +2728,7 @@ Perl_my_pclose(pTHX_ PerlIO *ptr)
SvREFCNT_dec(*svp);
*svp = NULL;
-#ifdef USE_PERLIO
+#if defined(USE_PERLIO) && !defined(USE_SFIO)
/* Find out whether the refcount is low enough for us to wait for the
child proc without blocking. */
should_wait = PerlIOUnix_refcnt(fd) == 1 && pid > 0;