From 287a962e687f7bb371dc3759b32ea8df45f0ba62 Mon Sep 17 00:00:00 2001 From: Jan Dubois Date: Mon, 27 Apr 2009 16:03:38 -0700 Subject: Fix -p function and Fcntl::S_IFIFO constant under Microsoft VC compiler Create S_IFIFO macro as an alias for _S_IFIFO if only the latter is being defined by the standard headers (e.g. Microsoft Visual C++). This is necessary to get the C<-p> function working, and also to define the Fcntl::S_IFIFO constant. See also http://bugs.activestate.com/show_bug.cgi?id=82665 Cheers, -Jan From 6386a37b103723e3c473119b95dd0b8edc59a1ed Mon Sep 17 00:00:00 2001 From: Jan Dubois Date: Mon, 27 Apr 2009 15:44:23 -0700 Subject: [PATCH] Create S_IFIFO macro as an alias for _S_IFIFO if only the latter is being defined by the standard headers (e.g. Microsoft Visual C++). This is necessary to get the C<-p> function working, and also to define the Fcntl::S_IFIFO constant. See also http://bugs.activestate.com/show_bug.cgi?id=82665 Signed-off-by: H.Merijn Brand --- perl.h | 7 +++++++ 1 file changed, 7 insertions(+) (limited to 'perl.h') diff --git a/perl.h b/perl.h index fb834f9f92..0e52ebca6b 100644 --- a/perl.h +++ b/perl.h @@ -1143,6 +1143,13 @@ EXTERN_C int usleep(unsigned int); # include #endif +/* Microsoft VC's sys/stat.h defines all S_Ixxx macros except S_IFIFO. + This definition should ideally go into win32/win32.h, but S_IFIFO is + used later here in perl.h before win32/win32.h is being included. */ +#if !defined(S_IFIFO) && defined(_S_IFIFO) +# define S_IFIFO _S_IFIFO +#endif + /* The stat macros for Amdahl UTS, Unisoft System V/88 (and derivatives like UTekV) are broken, sometimes giving false positives. Undefine them here and let the code below set them to proper values. -- cgit v1.2.1