[
https://issues.apache.org/jira/browse/TAPESTRY-2157?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12569174#action_12569174
]
Daniel Caldeweyher commented on TAPESTRY-2157:
----------------------------------------------
If i understand correctly OGNL has undergone significant changes and no longer
just evaluates the expression on demand but generates byte code and enhanced
the pageclass during the first loading of the page. If my understanding is
correct, then the problem might be its intregration into tapestry with ognl
possibly generate byte code for a reference to the actual page object instead
of the getPage() method of the component. This would explain the error message
"$Page2_15 cannot be cast to $Page1_14"
Daniel
> ClassCastException in ExpressionBinding.setObject
> -------------------------------------------------
>
> Key: TAPESTRY-2157
> URL: https://issues.apache.org/jira/browse/TAPESTRY-2157
> Project: Tapestry
> Issue Type: Bug
> Components: Framework
> Affects Versions: 4.1.5
> Environment: Win XP, Tomcat 5.5
> Reporter: Paul Stanton
> Assignee: Jesse Kuhnert
> Priority: Critical
> Attachments: Problem.war
>
>
> I've been using this page structure for quite some time and it seems after
> upgrading to 4.1.5 from 4.1.1 something has regressed. It appears my
> BorderTab component is caching the page or page class when it shouldn't?
> essentially, i have a border component which wraps the bodyContent in a
> generic Form component. Inside this form (yet still inside the Border) i have
> some BorderTab components, each with a LinkSubmit component. Clicking these
> links navigates through the tabs, submitting their forms (empty in the
> example).
> Please run the attached example war file, it includes everything.
> 1. click tab 1, tab 2, tab 3 etc - eventually the ClassCastException will be
> shown.
> note: clicking tab 1 recursively without clicking the other tabs does not
> cause the exception
> Exception message:
> Unable to update OGNL expression '<parsed OGNL expression>' of [EMAIL
> PROTECTED]/$Border.$BorderTab_1] to Page3: $Page2_15 cannot be cast to
> $Page1_14
> stack trace:
> $ASTChain_118168cf864.set($ASTChain_118168cf864.java)
> org.apache.tapestry.services.impl.ExpressionEvaluatorImpl.write(ExpressionEvaluatorImpl.java:179)
>
> $ExpressionEvaluator_118168cf818.write($ExpressionEvaluator_118168cf818.java)
> org.apache.tapestry.binding.ExpressionBinding.setObject(ExpressionBinding.java:224)
>
> $LinkSubmit_9.setSelected($LinkSubmit_9.java)
> org.apache.tapestry.form.AbstractSubmit.handleClick(AbstractSubmit.java:69)
> org.apache.tapestry.form.AbstractSubmit.rewindFormComponent(AbstractSubmit.java:63)
>
> org.apache.tapestry.form.AbstractFormComponent.renderComponent(AbstractFormComponent.java:90)
>
> org.apache.tapestry.AbstractComponent.render(AbstractComponent.java:724)
> org.apache.tapestry.services.impl.DefaultResponseBuilder.render(DefaultResponseBuilder.java:187)
>
> org.apache.tapestry.AbstractComponent.renderBody(AbstractComponent.java:538)
> org.apache.tapestry.components.ElseBean.renderComponent(ElseBean.java:47)
> org.apache.tapestry.AbstractComponent.render(AbstractComponent.java:724)
> org.apache.tapestry.services.impl.DefaultResponseBuilder.render(DefaultResponseBuilder.java:187)
>
> org.apache.tapestry.BaseComponent.renderComponent(BaseComponent.java:107)
> org.apache.tapestry.AbstractComponent.render(AbstractComponent.java:724)
> org.apache.tapestry.services.impl.DefaultResponseBuilder.render(DefaultResponseBuilder.java:187)
>
> org.apache.tapestry.AbstractComponent.renderBody(AbstractComponent.java:538)
> org.apache.tapestry.components.IfBean.renderComponent(IfBean.java:94)
> org.apache.tapestry.AbstractComponent.render(AbstractComponent.java:724)
> org.apache.tapestry.services.impl.DefaultResponseBuilder.render(DefaultResponseBuilder.java:187)
>
> org.apache.tapestry.AbstractComponent.renderBody(AbstractComponent.java:538)
> org.apache.tapestry.form.FormSupportImpl.rewind(FormSupportImpl.java:624)
> org.apache.tapestry.form.Form.renderComponent(Form.java:196)
> org.apache.tapestry.AbstractComponent.render(AbstractComponent.java:724)
> org.apache.tapestry.services.impl.DefaultResponseBuilder.render(DefaultResponseBuilder.java:187)
>
> org.apache.tapestry.form.Form.rewind(Form.java:269)
> org.apache.tapestry.engine.RequestCycle.rewindForm(RequestCycle.java:469)
> org.apache.tapestry.form.Form.trigger(Form.java:280)
> org.apache.tapestry.engine.DirectService.triggerComponent(DirectService.java:166)
>
> org.apache.tapestry.engine.DirectService.service(DirectService.java:142)
> $IEngineService_118168cf76b.service($IEngineService_118168cf76b.java)
> org.apache.tapestry.services.impl.EngineServiceOuterProxy.service(EngineServiceOuterProxy.java:72)
>
> org.apache.tapestry.engine.AbstractEngine.service(AbstractEngine.java:241)
> org.apache.tapestry.services.impl.InvokeEngineTerminator.service(InvokeEngineTerminator.java:54)
>
> $WebRequestServicer_118168cf742.service($WebRequestServicer_118168cf742.java)
> $WebRequestServicer_118168cf73e.service($WebRequestServicer_118168cf73e.java)
> org.apache.tapestry.services.impl.WebRequestServicerPipelineBridge.service(WebRequestServicerPipelineBridge.java:61)
>
> $ServletRequestServicer_118168cf724.service($ServletRequestServicer_118168cf724.java)
>
> org.apache.tapestry.request.DecodedRequestInjector.service(DecodedRequestInjector.java:55)
>
> $ServletRequestServicerFilter_118168cf720.service($ServletRequestServicerFilter_118168cf720.java)
>
> $ServletRequestServicer_118168cf726.service($ServletRequestServicer_118168cf726.java)
>
> org.apache.tapestry.multipart.MultipartDecoderFilter.service(MultipartDecoderFilter.java:52)
>
> $ServletRequestServicerFilter_118168cf71e.service($ServletRequestServicerFilter_118168cf71e.java)
>
> $ServletRequestServicer_118168cf726.service($ServletRequestServicer_118168cf726.java)
>
> org.apache.tapestry.services.impl.SetupRequestEncoding.service(SetupRequestEncoding.java:53)
>
> $ServletRequestServicerFilter_118168cf722.service($ServletRequestServicerFilter_118168cf722.java)
>
> $ServletRequestServicer_118168cf726.service($ServletRequestServicer_118168cf726.java)
>
> $ServletRequestServicer_118168cf718.service($ServletRequestServicer_118168cf718.java)
>
> org.apache.tapestry.ApplicationServlet.doService(ApplicationServlet.java:126)
> org.apache.tapestry.ApplicationServlet.doPost(ApplicationServlet.java:171)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
--
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.
---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]