package railo.runtime.tag; import java.io.IOException; import railo.runtime.PageContextImpl; import railo.runtime.exp.PageException; import railo.runtime.ext.tag.TagImpl; import railo.runtime.op.Caster; /** * Flushes currently available data to the client. * * * **/ public final class Flush extends TagImpl { /** Flush the output each time at least the specified number of bytes become available. HTML ** headers, and any data that is already available when you make this call, are not included in ** the count. */ private double interval=-1; @Override public void release() { super.release(); interval=-1; } /** set the value interval * Flush the output each time at least the specified number of bytes become available. HTML * headers, and any data that is already available when you make this call, are not included in * the count. * @param interval value to set **/ public void setInterval(double interval) { this.interval=interval; } @Override public int doStartTag() throws PageException { try { if(interval==-1)((PageContextImpl)pageContext).getRootOut().flush(); else ((PageContextImpl)pageContext).getRootOut().setBufferConfig((int)interval,true); } catch (IOException e) { throw Caster.toPageException(e); } return SKIP_BODY; } @Override public int doEndTag() { return EVAL_PAGE; } }