author | Michael Krelin <hacker@klever.net> | 2005-03-07 21:04:49 (UTC) |
---|---|---|
committer | Michael Krelin <hacker@klever.net> | 2005-03-07 21:04:49 (UTC) |
commit | b0e2dda829db4560e2c0ed7556803124a396b89f (patch) (side-by-side diff) | |
tree | 0f0ef795bd175ea997941b75ef2ed5a3210b267e /include | |
parent | dd855cb44cb06cf630e4fe9aba09fa2e43a63aed (diff) | |
download | sitecing-b0e2dda829db4560e2c0ed7556803124a396b89f.zip sitecing-b0e2dda829db4560e2c0ed7556803124a396b89f.tar.gz sitecing-b0e2dda829db4560e2c0ed7556803124a396b89f.tar.bz2 |
prebuffering of output is controllable now.
-rw-r--r-- | include/sitecing/sitecing_interface_cgi.h | 29 |
1 files changed, 25 insertions, 4 deletions
diff --git a/include/sitecing/sitecing_interface_cgi.h b/include/sitecing/sitecing_interface_cgi.h index cab947c..da538d6 100644 --- a/include/sitecing/sitecing_interface_cgi.h +++ b/include/sitecing/sitecing_interface_cgi.h @@ -36,7 +36,15 @@ namespace sitecing { /** * Here is where we prebuffer output. */ - ostringstream prebuffer; + stringbuf prebuffer; + /** + * Output stream, initially going to prebuffer. + */ + ostream outs; + /** + * Have headers been sent yet? + */ + bool headers_flushed; /** * Pointer to the sitespace object. */ @@ -48,13 +56,26 @@ namespace sitecing { sitecing_interface_cgi(sitespace *s); /** - * @todo TODO: wish I could remember -- document me. + * Set up interface for the (possibly, new) cgi gateway object, + * reset headers, empty buffer, etc. */ void prepare(kingate::cgi_gateway *cg); /** - * @todo TODO: wish I could remember -- document me. + * Flush output stream. + */ + void flush(bool keep_buffering=false); + /** + * Send headers to the output stream, if we haven't yet. + */ + void flush_headers(); + /** + * Are we buffering now? + */ + bool is_buffering(); + /** + * Control output buffering. */ - void flush(); + void set_buffering(bool do_buffer); }; } |