[hunchentoot-devel] How to properly write directly to output stream?

Edi Weitz edi at agharta.de
Tue Mar 30 13:03:55 UTC 2010


I don't fully understand what you are trying to achieve when you are
saying that you have to wait until the handler returns.  That is
something you have to do anyway.

As for the chunk size, note that this might also be governed by a) the
underlying stream provided by your Lisp implementation and b) the
client.

Edi.


On Fri, Mar 26, 2010 at 12:53 PM, Vsevolod Dyomkin <vseloved at gmail.com> wrote:
> Hi,
> I'm developing a new web-application, based on Hunchentoot 1.1, my previous
> ones were based on pre-1.0 version.  Since there was a switch to
> binary-streams, the following approach to HTML generation directly to the
> input stream from CL-WHO, which I'd used previously had to be modified from
> (let ((out (send-headers)))
>    (with-html-output (*who-stream* out)
>       ;; ...
> to
> (let ((out (flex:make-flexi-stream (send-headers)
>                          :external-format
> *hunchentoot-default-external-format*
>                          :element-type 'character)))
>    (with-html-output (*who-stream* out)
>       ;; ...
> Still it doesn't perform the same as before, because, as far as I
> understand, of the new handling of chunking. It seems to me, that the chunk
> size is set to 8K in Chunga and in my case that's very inconvenient: I'd
> like to serve the page in many small portions, as the time of their
> "arrival" is quite unpredictable.
> That is why I've tried to turn off chunking or set lower chunk sizes (1K,
> for example) via both the public API (acceptor-output-chunking-p) and by
> manipulating the Hunchentoot internals, but failed to achieve anything.
> Either only the headers are sent and the connection is closed, or I need to
> wait until the handler returns.
> I would be grateful, if someone, who better understands the internal
> mechanisms of that, gave me an explanation and some advice.
> Thanks in advance,
> Vsevolod Dyomkin
> _______________________________________________
> tbnl-devel site list
> tbnl-devel at common-lisp.net
> http://common-lisp.net/mailman/listinfo/tbnl-devel
>




More information about the Tbnl-devel mailing list