print OUT while <DATA>;
close OUT;
__END__
-/* $Id: FCGI.XL,v 1.6 2001/09/20 12:00:24 skimo Exp $ */
+/* $Id: FCGI.XL,v 1.10 2003/06/22 00:24:11 robs Exp $ */
#include "EXTERN.h"
#include "perl.h"
#define dTHX
#endif
+#ifndef INT2PTR
+#define INT2PTR(a,b) ((a) (b))
+#endif
+
#ifdef USE_SFIO
typedef struct
{
sfdcdelfcgi(sfdisc(IoOFP(request->io[1]), SF_POPDISC));
sfdcdelfcgi(sfdisc(IoOFP(request->io[2]), SF_POPDISC));
#else
+# ifdef USE_PERLIO
+ sv_unmagic((SV *)GvIOp(request->gv[0]), 'q');
+ sv_unmagic((SV *)GvIOp(request->gv[1]), 'q');
+ sv_unmagic((SV *)GvIOp(request->gv[2]), 'q');
+# else
sv_unmagic((SV *)request->gv[0], 'q');
sv_unmagic((SV *)request->gv[1], 'q');
sv_unmagic((SV *)request->gv[2], 'q');
+# endif
#endif
request->bound = FALSE;
}
sfdisc(IoOFP(request->io[1]), sfdcnewfcgi(request->requestPtr->out));
sfdisc(IoOFP(request->io[2]), sfdcnewfcgi(request->requestPtr->err));
#else
+# ifdef USE_PERLIO
+ /* For tied filehandles, we apply tiedscalar magic to the IO
+ slot of the GP rather than the GV itself. */
+
+ if (!GvIOp(request->gv[1]))
+ GvIOp(request->gv[1]) = newIO();
+ if (!GvIOp(request->gv[2]))
+ GvIOp(request->gv[2]) = newIO();
+ if (!GvIOp(request->gv[0]))
+ GvIOp(request->gv[0]) = newIO();
+
+ sv_magic((SV *)GvIOp(request->gv[1]), request->svout, 'q', Nullch, 0);
+ sv_magic((SV *)GvIOp(request->gv[2]), request->sverr, 'q', Nullch, 0);
+ sv_magic((SV *)GvIOp(request->gv[0]), request->svin, 'q', Nullch, 0);
+# else
sv_magic((SV *)request->gv[1], request->svout, 'q', Nullch, 0);
sv_magic((SV *)request->gv[2], request->sverr, 'q', Nullch, 0);
sv_magic((SV *)request->gv[0], request->svin, 'q', Nullch, 0);
+# endif
#endif
request->bound = TRUE;
}
PROTOTYPE: $
CODE:
- if (request->accepted && request->bound)
- FCGI_UndoBinding(request);
+ if (request->accepted && request->bound) {
+ FCGI_UndoBinding(request);
+ FCGX_Detach(request->requestPtr);
+ }
void
Attach(request)
PROTOTYPE: $
CODE:
- if (request->accepted && !request->bound)
- FCGI_Bind(request);
+ if (request->accepted && !request->bound) {
+ FCGI_Bind(request);
+ FCGX_Attach(request->requestPtr);
+ }
void
LastCall(request)
#ifndef USE_SFIO
-void
+SV *
PRINT(stream, ...)
FCGI::Stream stream;
PREINIT:
- int n;
+ int n;
+ STRLEN len;
+ register char *str;
+ bool ok = TRUE;
CODE:
- for (n = 1; n < items; ++n) {
- STRLEN len;
- register char *tmps = (char *)SvPV(ST(n),len);
- FCGX_PutStr(tmps, len, stream);
- }
- if (SvTRUEx(perl_get_sv("|", FALSE)))
- FCGX_FFlush(stream);
+ for (n = 1; ok && n < items; ++n) {
+#ifdef DO_UTF8
+ if (DO_UTF8(ST(n)) && !sv_utf8_downgrade(ST(n), 1))
+ croak("Wide character in FCGI::Stream::PRINT");
+#endif
+ str = (char *)SvPV(ST(n),len);
+ if (FCGX_PutStr(str, len, stream) < 0)
+ ok = FALSE;
+ }
+
+ if (ok && SvTRUEx(perl_get_sv("|", FALSE)) && FCGX_FFlush(stream) < 0)
+ ok = FALSE;
+
+ RETVAL = ok ? &PL_sv_yes : &PL_sv_undef;
int
WRITE(stream, bufsv, len, ...)
CODE:
offset = (items == 4) ? (int)SvIV(ST(3)) : 0;
+#ifdef DO_UTF8
+ if (DO_UTF8(bufsv) && !sv_utf8_downgrade(bufsv, 1))
+ croak("Wide character in FCGI::Stream::WRITE");
+#endif
buf = SvPV(bufsv, blen);
if (offset < 0) offset += blen;
if (len > blen - offset)
ST(0) = &PL_sv_undef;
else {
ST(0) = sv_newmortal();
- sv_setpvf(ST(0), "%c", n);
+ sv_setiv(ST(0), n);
}
int
CODE:
offset = (items == 4) ? (int)SvIV(ST(3)) : 0;
+#ifdef DO_UTF8
+ if (DO_UTF8(bufsv) && !sv_utf8_downgrade(bufsv, 1))
+ croak("Wide character in FCGI::Stream::READ");
+#endif
if (! SvOK(bufsv))
sv_setpvn(bufsv, "", 0);
buf = SvGROW(bufsv, len+offset+1);