summaryrefslogtreecommitdiff
path: root/perlsdio.h
diff options
context:
space:
mode:
authorCraig A. Berry <craigberry@mac.com>2015-01-29 22:06:44 -0600
committerCraig A. Berry <craigberry@mac.com>2015-01-29 22:06:44 -0600
commit04ce8649990a4784cc3ad0b83a45ccf6a005b1be (patch)
treef5671545c2f6438e75f7729b22b76bde43c6e5b0 /perlsdio.h
parente6ad046acdf21cf68937902df307a767e93a3340 (diff)
downloadperl-04ce8649990a4784cc3ad0b83a45ccf6a005b1be.tar.gz
Externalize decc$ungetc prototype.
Otherwise the VMS C++ compiler mangles it and we get a link failure. And while we're there we can eliminate some PerlIO workarounds for problems in long-defunct versions of the CRTL.
Diffstat (limited to 'perlsdio.h')
-rw-r--r--perlsdio.h33
1 files changed, 9 insertions, 24 deletions
diff --git a/perlsdio.h b/perlsdio.h
index 29e817617a..7dcd394110 100644
--- a/perlsdio.h
+++ b/perlsdio.h
@@ -36,45 +36,30 @@
#define PerlIO_close(f) PerlSIO_fclose(f)
#define PerlIO_puts(f,s) PerlSIO_fputs(s,f)
#define PerlIO_putc(f,c) PerlSIO_fputc(c,f)
-#if defined(VMS)
-# if defined(__DECC)
+#if defined(__VMS)
/* Unusual definition of ungetc() here to accommodate fast_sv_gets()'
* belief that it can mix getc/ungetc with reads from stdio buffer */
+START_EXTERN_C
int decc$ungetc(int __c, FILE *__stream);
+END_EXTERN_C
# define PerlIO_ungetc(f,c) ((c) == EOF ? EOF : \
((*(f) && !((*(f))->_flag & _IONBF) && \
((*(f))->_ptr > (*(f))->_base)) ? \
((*(f))->_cnt++, *(--(*(f))->_ptr) = (c)) : decc$ungetc(c,f)))
-# else
-# define PerlIO_ungetc(f,c) ungetc(c,f)
-# endif
- /* Work around bug in DECCRTL/AXP (DECC v5.x) and some versions of old
- * VAXCRTL which causes read from a pipe after EOF has been returned
- * once to hang.
- */
-# define PerlIO_getc(f) \
- (feof(f) ? EOF : getc(f))
-# define PerlIO_read(f,buf,count) \
- (feof(f) ? 0 : (SSize_t)fread(buf,1,count,f))
-# define PerlIO_tell(f) ftell(f)
#else
-# define PerlIO_getc(f) PerlSIO_fgetc(f)
-# define PerlIO_ungetc(f,c) PerlSIO_ungetc(c,f)
-# define PerlIO_read(f,buf,count) (SSize_t)PerlSIO_fread(buf,1,count,f)
-# define PerlIO_tell(f) PerlSIO_ftell(f)
+# define PerlIO_ungetc(f,c) ungetc(c,f)
#endif
+#define PerlIO_getc(f) PerlSIO_fgetc(f)
+#define PerlIO_ungetc(f,c) PerlSIO_ungetc(c,f)
+#define PerlIO_read(f,buf,count) (SSize_t)PerlSIO_fread(buf,1,count,f)
+#define PerlIO_tell(f) PerlSIO_ftell(f)
#define PerlIO_eof(f) PerlSIO_feof(f)
#define PerlIO_getname(f,b) fgetname(f,b)
#define PerlIO_error(f) PerlSIO_ferror(f)
#define PerlIO_fileno(f) PerlSIO_fileno(f)
#define PerlIO_clearerr(f) PerlSIO_clearerr(f)
#define PerlIO_flush(f) PerlSIO_fflush(f)
-#if defined(VMS) && !defined(__DECC)
-/* Old VAXC RTL doesn't reset EOF on seek; Perl folk seem to expect this */
-#define PerlIO_seek(f,o,w) (((f) && (*f) && ((*f)->_flag &= ~_IOEOF)),fseek(f,o,w))
-#else
-# define PerlIO_seek(f,o,w) PerlSIO_fseek(f,o,w)
-#endif
+#define PerlIO_seek(f,o,w) PerlSIO_fseek(f,o,w)
#define PerlIO_rewind(f) PerlSIO_rewind(f)
#define PerlIO_tmpfile() PerlSIO_tmpfile()