summaryrefslogtreecommitdiff
path: root/perlio.c
diff options
context:
space:
mode:
authorJarkko Hietaniemi <jhi@iki.fi>2001-12-11 14:33:14 +0000
committerJarkko Hietaniemi <jhi@iki.fi>2001-12-11 14:33:14 +0000
commit6ce75a778d390cfc1b903c40f2566d0e560efcd8 (patch)
tree852095faac15bf2d497b71c3f3e0f8056eb91709 /perlio.c
parentd2492938eb072e03ead75c841f11237d3b984c72 (diff)
downloadperl-6ce75a778d390cfc1b903c40f2566d0e560efcd8.tar.gz
Try to handle platforms that have O_TEXT != O_BINARY but
which are not DOSish, BeOS being one of such platforms. Ideally this should be a Configure test, not a hardwired cpp symbol test... p4raw-id: //depot/perl@13621
Diffstat (limited to 'perlio.c')
-rw-r--r--perlio.c28
1 files changed, 14 insertions, 14 deletions
diff --git a/perlio.c b/perlio.c
index 1fab7b7aa4..9adeea7cd6 100644
--- a/perlio.c
+++ b/perlio.c
@@ -859,14 +859,12 @@ void
PerlIO_default_buffer(pTHX_ PerlIO_list_t *av)
{
PerlIO_funcs *tab = &PerlIO_perlio;
- if (O_BINARY != O_TEXT) {
- tab = &PerlIO_crlf;
- }
- else {
- if (PerlIO_stdio.Set_ptrcnt) {
- tab = &PerlIO_stdio;
- }
- }
+#ifdef PERLIO_CRLF
+ tab = &PerlIO_crlf;
+#endif
+ if (PerlIO_stdio.Set_ptrcnt)
+ tab = &PerlIO_stdio;
+#else
PerlIO_debug("Pushing %s\n", tab->name);
PerlIO_list_push(aTHX_ av, PerlIO_find_layer(aTHX_ tab->name, 0, 0),
&PL_sv_undef);
@@ -1078,7 +1076,8 @@ PerlIO_binmode(pTHX_ PerlIO *f, int iotype, int mode, const char *names)
/* Can't flush if switching encodings. */
if (!(names && memEQ(names, ":encoding(", 10))) {
PerlIO_flush(f);
- if (!names && (O_TEXT != O_BINARY && (mode & O_BINARY))) {
+#ifdef PERLIO_CRLF
+ if (!names && (mode & O_BINARY)) {
PerlIO *top = f;
while (*top) {
if (PerlIOBase(top)->tab == &PerlIO_crlf) {
@@ -1089,6 +1088,7 @@ PerlIO_binmode(pTHX_ PerlIO *f, int iotype, int mode, const char *names)
PerlIO_flush(top);
}
}
+#endif
}
return PerlIO_apply_layers(aTHX_ f, NULL, names) == 0 ? TRUE : FALSE;
}
@@ -1781,7 +1781,7 @@ PerlIO_modestr(PerlIO *f, char *buf)
*s++ = '+';
}
}
-#if O_TEXT != O_BINARY
+#ifdef PERLIO_CRLF
if (!(flags & PERLIO_F_CRLF))
*s++ = 'b';
#endif
@@ -2367,9 +2367,9 @@ PerlIOStdio_mode(const char *mode, char *tmode)
while (*mode) {
*tmode++ = *mode++;
}
- if (O_BINARY != O_TEXT) {
- *tmode++ = 'b';
- }
+#ifdef PERLIO_CRLF
+ *tmode++ = 'b';
+#endif
*tmode = '\0';
return ret;
}
@@ -2906,7 +2906,7 @@ PerlIOBuf_open(pTHX_ PerlIO_funcs *self, PerlIO_list_t *layers,
return NULL;
} else {
fd = PerlIO_fileno(f);
-#if (O_BINARY != O_TEXT) && !defined(__BEOS__)
+#ifdef PERLIO_CRLF
/*
* do something about failing setmode()? --jhi
*/