summaryrefslogtreecommitdiff
path: root/ext/IO/IO.xs
diff options
context:
space:
mode:
authorGurusamy Sarathy <gsar@cpan.org>1998-11-28 16:46:43 +0000
committerGurusamy Sarathy <gsar@cpan.org>1998-11-28 16:46:43 +0000
commita1ea39dc8940632216c22b20b6b3596817204581 (patch)
treed3bda3e5de18eb04d9a06dff06311c67012f5ca5 /ext/IO/IO.xs
parentcf7fe8a27ac6ee8776974a7c83e80425f2ec0ff8 (diff)
downloadperl-a1ea39dc8940632216c22b20b6b3596817204581.tar.gz
IO.xs tweaks; avoid coredump in io_xs.t; remove newCONSTSUB();
ANSI prototypes p4raw-id: //depot/perl@2355
Diffstat (limited to 'ext/IO/IO.xs')
-rw-r--r--ext/IO/IO.xs64
1 files changed, 9 insertions, 55 deletions
diff --git a/ext/IO/IO.xs b/ext/IO/IO.xs
index a434d08ea3..1d0e3567db 100644
--- a/ext/IO/IO.xs
+++ b/ext/IO/IO.xs
@@ -47,67 +47,19 @@ typedef FILE * OutputStream;
#endif
static int
-not_here(s)
-char *s;
+not_here(char *s)
{
croak("%s not implemented on this architecture", s);
return -1;
}
-#ifndef newCONSTSUB
-/*
- * Define an XSUB that returns a constant scalar. The resulting structure is
- * identical to that created by the parser when it parses code like :
- *
- * sub xyz () { 123 }
- *
- * This allows the constants from the XSUB to be inlined.
- *
- * !!! THIS SHOULD BE ADDED INTO THE CORE CODE !!!!
- *
- */
-
-static void
-newCONSTSUB(stash,name,sv)
- HV *stash;
- char *name;
- SV *sv;
-{
-#ifdef dTHR
- dTHR;
-#endif
- U32 oldhints = hints;
- HV *old_cop_stash = curcop->cop_stash;
- HV *old_curstash = curstash;
- line_t oldline = curcop->cop_line;
- curcop->cop_line = copline;
-
- hints &= ~HINT_BLOCK_SCOPE;
- if(stash)
- curstash = curcop->cop_stash = stash;
-
- newSUB(
- MY_start_subparse(FALSE, 0),
- newSVOP(OP_CONST, 0, newSVpv(name,0)),
- newSVOP(OP_CONST, 0, &sv_no), /* SvPV(&sv_no) == "" -- GMB */
- newSTATEOP(0, Nullch, newSVOP(OP_CONST, 0, sv))
- );
-
- hints = oldhints;
- curcop->cop_stash = old_cop_stash;
- curstash = old_curstash;
- curcop->cop_line = oldline;
-}
-#endif
#ifndef PerlIO
#define PerlIO_fileno(f) fileno(f)
#endif
static int
-io_blocking(f,block)
-InputStream f;
-int block;
+io_blocking(InputStream f, int block)
{
int RETVAL;
if(!f) {
@@ -205,7 +157,7 @@ fgetpos(handle)
ST(0) = sv_2mortal(newSVpv((char*)&pos, sizeof(Fpos_t)));
}
else {
- ST(0) = &sv_undef;
+ ST(0) = &PL_sv_undef;
errno = EINVAL;
}
@@ -214,11 +166,13 @@ fsetpos(handle, pos)
InputStream handle
SV * pos
CODE:
- if (handle)
+ char *p;
+ STRLEN len;
+ if (handle && (p = SvPV(pos,len)) && len == sizeof(Fpos_t))
#ifdef PerlIO
- RETVAL = PerlIO_setpos(handle, (Fpos_t*)SvPVX(pos));
+ RETVAL = PerlIO_setpos(handle, (Fpos_t*)p);
#else
- RETVAL = fsetpos(handle, (Fpos_t*)SvPVX(pos));
+ RETVAL = fsetpos(handle, (Fpos_t*)p);
#endif
else {
RETVAL = -1;
@@ -249,7 +203,7 @@ new_tmpfile(packname = "IO::File")
SvREFCNT_dec(gv); /* undo increment in newRV() */
}
else {
- ST(0) = &sv_undef;
+ ST(0) = &PL_sv_undef;
SvREFCNT_dec(gv);
}