Seems reasonable to me, but I haven&#39;t been deeply involved in the PPR area of the spec, so I may be overlooking a potential downside.<br><br><div class="gmail_quote">On Tue, Jul 14, 2009 at 7:43 PM, Dan Allen <span dir="ltr">&lt;<a href="mailto:dan.j.allen@gmail.com">dan.j.allen@gmail.com</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">From the jsr-314-comments mailbox comes this message from Werner Punz concerning the partial response writer and nested eval blocks.<br>
<br>(For future reference, the moderator of the 314-comments mailbox, which is currently me, will forward approved messages using the introduction above).<div><div></div><div class="h5"><br>
<br><div class="gmail_quote">---------- Forwarded message ----------<br>From: <b class="gmail_sendername">Werner Punz</b> <span dir="ltr">&lt;<a href="mailto:werner.punz@gmail.com" target="_blank">werner.punz@gmail.com</a>&gt;</span><br>

Date: Mon, Jul 13, 2009 at 4:40 AM<br>Subject: Partial Response writer in conjunction with the component API<br>To: <a href="mailto:jsr-314-comments@jcp.org" target="_blank">jsr-314-comments@jcp.org</a><br><br><br>Hello everyone I have a comment regarding the partial response writer in conjunction with the component API.<br>

Since this is a grey area I am not quite sure if it is possible to add that behavior or not.<br><br>Following, currently the partial response is handled via a partial response writer and a special lifecycle, so far so good and very clear.<br>


But the issues arise if you want to combine it with the component api.<br><br>Here is the problem:<br><br>Usually the partial lifecycle automatically opens an update on the partial response before working on the component tree or single components to be rendered!<br>


This is needed to gain backwards compatibility and still enable ppr on legacy components, however there is an issue with this approach!<br><br>What if a component wants to render scripts explicitely or style changes. MyFaces has covered the script part so far with an optimized auto eval on the <br>


updated dom tree, but wouldnt it be nice to allow eval blocks from the component level as well, after all we have the api, and so far it only really can be utilized<br>outside of jsf in this manner!<br><br>Lets have a detailed look:<br>


<br>Component has to be rendered under a PPR context:<br>the cycle opens an update with startUpdate and the id of the root component to be updated!<br><br>The lifecycle then calls the encodeBegin on the parent component and that one traverses into its sub components.<br>


<br>What happens now is that those subcomponents use startElement etc... to render the html styles and scripts, they do not really<br>have a safe way to break out and add their own eval sections etc... although the API is in place<br>


(the only unsafe way would be to close implicitely the update section add the eval section and reopening again by <br>parsing again the ppr data from the request and try to avoid any sideeffects into the lifecycle, this way would not <br>


be broken by my proposal)<br><br>What I would recommend as default behaviour, and this can be added since it is not really specified anyway as far as I could see.<br>Allow the opening of other sections within an open section and render them after the main section is closed (stacking embedded sections<br>


and defer the rendering of them).<br><br>Example<br>startUpdate ....<br>   startEval ....<br>   endEval<br><br>...<br>endUpdate<br><br>would result in a <br>&lt;update&gt; ..<br>&lt;/update&gt;<br>&lt;eval&gt;<br>&lt;/eval&gt; <br>


<br>block<br><br><br>This behavior would give new components which then can check for being in a ppr cycle a better rendering <br>behavior by being able to control their ppr behavior directly. It also would not break compatibility to the<br>


existing implementations, and probably as well would be within the scope of the existing spec.<br><br><br>Kind regards<br><font color="#888888"><br>Werner Punz<br>Apache MyFaces<br></font></div><br>
</div></div></blockquote></div><br><br clear="all"><br>-- <br>Dan Allen<br>Senior Software Engineer, Red Hat | Author of Seam in Action<br><br><a href="http://mojavelinux.com">http://mojavelinux.com</a><br><a href="http://mojavelinux.com/seaminaction">http://mojavelinux.com/seaminaction</a><br>
<a href="http://in.relation.to/Bloggers/Dan">http://in.relation.to/Bloggers/Dan</a><br><br>NOTE: While I make a strong effort to keep up with my email on a daily<br>basis, personal or other work matters can sometimes keep me away<br>
from my email. If you contact me, but don&#39;t hear back for more than a week,<br>it is very likely that I am excessively backlogged or the message was<br>caught in the spam filters.  Please don&#39;t hesitate to resend a message if<br>
you feel that it did not reach my attention.<br>