atom feed9 messages in org.apache.shale.issues[jira] Created: (SHALE-371) prerender...
FromSent OnAttachments
Stan Zapryanov (JIRA)Dec 21, 2006 4:02 pm 
Stan Zapryanov (JIRA)Dec 21, 2006 4:22 pm 
Stan Zapryanov (JIRA)Dec 21, 2006 4:34 pm 
Craig McClanahan (JIRA)Dec 21, 2006 6:39 pm 
Craig McClanahan (JIRA)Dec 21, 2006 6:41 pm 
Craig McClanahan (JIRA)Dec 21, 2006 9:25 pm 
Stan Zapryanov (JIRA)Dec 22, 2006 11:33 pm 
Craig McClanahan (JIRA)Dec 23, 2006 11:52 am 
Craig McClanahan (JIRA)Dec 23, 2006 12:59 pm 
Subject:[jira] Created: (SHALE-371) prerender() executes for ViewController not rendered when navigating to page/bean not implementing ViewController
From:Stan Zapryanov (JIRA) (ji@apache.org)
Date:Dec 21, 2006 4:02:34 pm
List:org.apache.shale.issues

prerender() executes for ViewController not rendered when navigating to
page/bean not implementing ViewController
-----------------------------------------------------------------------------------------------------------------

Key: SHALE-371 URL: http://issues.apache.org/struts/browse/SHALE-371 Project: Shale Issue Type: Bug Components: View Affects Versions: 1.0.4-SNAPSHOT Environment: Windows XP Pro, Tomcat 5.5, JDK 1.5.0_04, MyFaces Reporter: Stan Zapryanov

Not sure if this is a bug but it looks like it.

When navigating to a view (JSF) not implementing the ViewHandler framework from
a ViewController t(JSF/bean) that does, currently the prerender() method gets
executed on the viewcontroller that you are leaving (that won't get rendered).

My guess is that currently the old FacesConstants.VIEW_NAME_RENDERED entry
remains in the request map even though you are not rendering that viewconroller,
and that triggers the execution of prerender().

Here is a suggested fix (that I have NOT tested) and I woudn't know if it may
brake other stuff..

In the setupViewController() method of the ViewViewHandler class:

vc = vr.resolveVariable(context, viewName); if (vc == null) { if (log.isDebugEnabled()) { log.debug(messages.getMessage("view.noViewController", new Object[] { viewId, viewName })); // ----PROPOSED FIX (not tested) ---- context.getExternalContext().getRequestMap()
.remove(FacesConstants.VIEW_NAME_RENDERED); //------END OF FIX------- } return; }

Hope all makes sense and was helpful.

Cheers!