[ https://issues.apache.org/jira/browse/TOMAHAWK-1032?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel#action_12545430 ]
Bogdan Sava commented on TOMAHAWK-1032: --------------------------------------- patch is working with Sun JSF RI 1.2 implementation! :) sorry for previous comment ! > examples: Dynamic number of columns doesn't work > ------------------------------------------------ > > Key: TOMAHAWK-1032 > URL: https://issues.apache.org/jira/browse/TOMAHAWK-1032 > Project: MyFaces Tomahawk > Issue Type: Bug > Components: Columns > Affects Versions: 1.1.6 > Environment: jsf ri 1.2_04-b10-p01 > Reporter: Menashe Duchovny > Attachments: patch.txt > > > crossDataTable.jsf gives:UIColumns component must be a child of a UIData > component > here is full stacktrace > --------------------------------------------- > Jun 25, 2007 12:06:52 AM org.apache.catalina.core.ApplicationDispatcher invoke > SEVERE: Servlet.service() for servlet jsp threw exception > java.lang.IllegalStateException: UIColumns component must be a child of a > UIData component > at > org.apache.myfaces.custom.crosstable.UIColumns.getParentUIData(UIColumns.java:403) > at > org.apache.myfaces.custom.crosstable.UIColumns.setDataModel(UIColumns.java:263) > at javax.faces.component.UIData.setValueBinding(UIData.java:634) > at > org.apache.myfaces.custom.crosstable.UIColumns.setValueBinding(UIColumns.java:241) > at > org.apache.myfaces.shared_tomahawk.taglib.UIComponentTagUtils.setValueProperty(UIComponentTagUtils.java:149) > at > org.apache.myfaces.shared_tomahawk.taglib.UIComponentBodyTagBase.setValueProperty(UIComponentBodyTagBase.java:168) > at > org.apache.myfaces.shared_tomahawk.taglib.UIComponentBodyTagBase.setProperties(UIComponentBodyTagBase.java:110) > at > org.apache.myfaces.shared_tomahawk.taglib.html.HtmlComponentBodyTagBase.setProperties(HtmlComponentBodyTagBase.java:74) > at > org.apache.myfaces.custom.crosstable.HtmlColumnsTag.setProperties(HtmlColumnsTag.java:107) > at > javax.faces.webapp.UIComponentTag.createComponent(UIComponentTag.java:209) > at > javax.faces.webapp.UIComponentClassicTagBase.createChild(UIComponentClassicTagBase.java:476) > at > javax.faces.webapp.UIComponentClassicTagBase.findComponent(UIComponentClassicTagBase.java:660) > at > javax.faces.webapp.UIComponentClassicTagBase.doStartTag(UIComponentClassicTagBase.java:1111) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_t_005fcolumns_005f0(crossDataTable_jsp.java:966) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_t_005fdataTable_005f0(crossDataTable_jsp.java:809) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_h_005fpanelGroup_005f0(crossDataTable_jsp.java:342) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_h_005fform_005f0(crossDataTable_jsp.java:289) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_f_005fview_005f0(crossDataTable_jsp.java:224) > at > org.apache.jsp.crossDataTable_jsp._jspService(crossDataTable_jsp.java:167) > at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) > at javax.servlet.http.HttpServlet.service(HttpServlet.java:803) > at > org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:393) > at > org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320) > at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266) > at javax.servlet.http.HttpServlet.service(HttpServlet.java:803) > at > org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) > at > org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) > at > org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:654) > at > org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:445) > at > org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:379) > at > org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:292) > at > com.sun.faces.context.ExternalContextImpl.dispatch(ExternalContextImpl.java:408) > at > com.sun.faces.application.ViewHandlerImpl.executePageToBuildView(ViewHandlerImpl.java:439) > at > com.sun.faces.application.ViewHandlerImpl.renderView(ViewHandlerImpl.java:114) > at > com.sun.faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:106) > at com.sun.faces.lifecycle.LifecycleImpl.phase(LifecycleImpl.java:251) > at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:144) > at javax.faces.webapp.FacesServlet.service(FacesServlet.java:245) > at > org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) > at > org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) > at > org.apache.myfaces.webapp.filter.ExtensionsFilter.doFilter(ExtensionsFilter.java:147) > at > org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) > at > org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) > at > org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230) > at > org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175) > at > org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128) > at > org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104) > at > org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) > at > org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:261) > at > org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844) > at > org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:581) > at > org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447) > at java.lang.Thread.run(Thread.java:619) > Jun 25, 2007 12:06:52 AM com.sun.faces.lifecycle.LifecycleImpl phase > WARNING: executePhase(RENDER_RESPONSE 6,[EMAIL PROTECTED]) threw exception > javax.faces.FacesException: org.apache.jasper.JasperException: An exception > occurred processing JSP page /crossDataTable.jsp at line 82 > 79: <h:outputText value="#{country.name}" /> > 80: </h:column> > 81: > 82: <t:columns value="#{crossDataTable.columnDataModel}" > var="column"> > 83: <f:facet name="header"> > 84: <h:panelGroup> > 85: <h:outputText value="#{column} " /> > Stacktrace: > at > com.sun.faces.context.ExternalContextImpl.dispatch(ExternalContextImpl.java:413) > at > com.sun.faces.application.ViewHandlerImpl.executePageToBuildView(ViewHandlerImpl.java:439) > at > com.sun.faces.application.ViewHandlerImpl.renderView(ViewHandlerImpl.java:114) > at > com.sun.faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:106) > at com.sun.faces.lifecycle.LifecycleImpl.phase(LifecycleImpl.java:251) > at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:144) > at javax.faces.webapp.FacesServlet.service(FacesServlet.java:245) > at > org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) > at > org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) > at > org.apache.myfaces.webapp.filter.ExtensionsFilter.doFilter(ExtensionsFilter.java:147) > at > org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) > at > org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) > at > org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230) > at > org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175) > at > org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128) > at > org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104) > at > org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) > at > org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:261) > at > org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844) > at > org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:581) > at > org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447) > at java.lang.Thread.run(Thread.java:619) > Caused by: org.apache.jasper.JasperException: An exception occurred > processing JSP page /crossDataTable.jsp at line 82 > 79: <h:outputText value="#{country.name}" /> > 80: </h:column> > 81: > 82: <t:columns value="#{crossDataTable.columnDataModel}" > var="column"> > 83: <f:facet name="header"> > 84: <h:panelGroup> > 85: <h:outputText value="#{column} " /> > Stacktrace: > at > org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:524) > at > org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:429) > at > org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320) > at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266) > at javax.servlet.http.HttpServlet.service(HttpServlet.java:803) > at > org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) > at > org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) > at > org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:654) > at > org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:445) > at > org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:379) > at > org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:292) > at > com.sun.faces.context.ExternalContextImpl.dispatch(ExternalContextImpl.java:408) > ... 21 more > Caused by: java.lang.IllegalStateException: UIColumns component must be a > child of a UIData component > at > org.apache.myfaces.custom.crosstable.UIColumns.getParentUIData(UIColumns.java:403) > at > org.apache.myfaces.custom.crosstable.UIColumns.setDataModel(UIColumns.java:263) > at javax.faces.component.UIData.setValueBinding(UIData.java:634) > at > org.apache.myfaces.custom.crosstable.UIColumns.setValueBinding(UIColumns.java:241) > at > org.apache.myfaces.shared_tomahawk.taglib.UIComponentTagUtils.setValueProperty(UIComponentTagUtils.java:149) > at > org.apache.myfaces.shared_tomahawk.taglib.UIComponentBodyTagBase.setValueProperty(UIComponentBodyTagBase.java:168) > at > org.apache.myfaces.shared_tomahawk.taglib.UIComponentBodyTagBase.setProperties(UIComponentBodyTagBase.java:110) > at > org.apache.myfaces.shared_tomahawk.taglib.html.HtmlComponentBodyTagBase.setProperties(HtmlComponentBodyTagBase.java:74) > at > org.apache.myfaces.custom.crosstable.HtmlColumnsTag.setProperties(HtmlColumnsTag.java:107) > at > javax.faces.webapp.UIComponentTag.createComponent(UIComponentTag.java:209) > at > javax.faces.webapp.UIComponentClassicTagBase.createChild(UIComponentClassicTagBase.java:476) > at > javax.faces.webapp.UIComponentClassicTagBase.findComponent(UIComponentClassicTagBase.java:660) > at > javax.faces.webapp.UIComponentClassicTagBase.doStartTag(UIComponentClassicTagBase.java:1111) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_t_005fcolumns_005f0(crossDataTable_jsp.java:966) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_t_005fdataTable_005f0(crossDataTable_jsp.java:809) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_h_005fpanelGroup_005f0(crossDataTable_jsp.java:342) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_h_005fform_005f0(crossDataTable_jsp.java:289) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_f_005fview_005f0(crossDataTable_jsp.java:224) > at > org.apache.jsp.crossDataTable_jsp._jspService(crossDataTable_jsp.java:167) > at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) > at javax.servlet.http.HttpServlet.service(HttpServlet.java:803) > at > org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:393) > ... 31 more > Jun 25, 2007 12:06:52 AM org.apache.catalina.core.StandardWrapperValve invoke > SEVERE: Servlet.service() for servlet Faces Servlet threw exception > java.lang.IllegalStateException: UIColumns component must be a child of a > UIData component > at > org.apache.myfaces.custom.crosstable.UIColumns.getParentUIData(UIColumns.java:403) > at > org.apache.myfaces.custom.crosstable.UIColumns.setDataModel(UIColumns.java:263) > at javax.faces.component.UIData.setValueBinding(UIData.java:634) > at > org.apache.myfaces.custom.crosstable.UIColumns.setValueBinding(UIColumns.java:241) > at > org.apache.myfaces.shared_tomahawk.taglib.UIComponentTagUtils.setValueProperty(UIComponentTagUtils.java:149) > at > org.apache.myfaces.shared_tomahawk.taglib.UIComponentBodyTagBase.setValueProperty(UIComponentBodyTagBase.java:168) > at > org.apache.myfaces.shared_tomahawk.taglib.UIComponentBodyTagBase.setProperties(UIComponentBodyTagBase.java:110) > at > org.apache.myfaces.shared_tomahawk.taglib.html.HtmlComponentBodyTagBase.setProperties(HtmlComponentBodyTagBase.java:74) > at > org.apache.myfaces.custom.crosstable.HtmlColumnsTag.setProperties(HtmlColumnsTag.java:107) > at > javax.faces.webapp.UIComponentTag.createComponent(UIComponentTag.java:209) > at > javax.faces.webapp.UIComponentClassicTagBase.createChild(UIComponentClassicTagBase.java:476) > at > javax.faces.webapp.UIComponentClassicTagBase.findComponent(UIComponentClassicTagBase.java:660) > at > javax.faces.webapp.UIComponentClassicTagBase.doStartTag(UIComponentClassicTagBase.java:1111) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_t_005fcolumns_005f0(crossDataTable_jsp.java:966) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_t_005fdataTable_005f0(crossDataTable_jsp.java:809) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_h_005fpanelGroup_005f0(crossDataTable_jsp.java:342) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_h_005fform_005f0(crossDataTable_jsp.java:289) > at > org.apache.jsp.crossDataTable_jsp._jspx_meth_f_005fview_005f0(crossDataTable_jsp.java:224) > at > org.apache.jsp.crossDataTable_jsp._jspService(crossDataTable_jsp.java:167) > at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) > at javax.servlet.http.HttpServlet.service(HttpServlet.java:803) > at > org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:393) > at > org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320) > at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266) > at javax.servlet.http.HttpServlet.service(HttpServlet.java:803) > at > org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) > at > org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) > at > org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:654) > at > org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:445) > at > org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:379) > at > org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:292) > at > com.sun.faces.context.ExternalContextImpl.dispatch(ExternalContextImpl.java:408) > at > com.sun.faces.application.ViewHandlerImpl.executePageToBuildView(ViewHandlerImpl.java:439) > at > com.sun.faces.application.ViewHandlerImpl.renderView(ViewHandlerImpl.java:114) > at > com.sun.faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:106) > at com.sun.faces.lifecycle.LifecycleImpl.phase(LifecycleImpl.java:251) > at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:144) > at javax.faces.webapp.FacesServlet.service(FacesServlet.java:245) > at > org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) > at > org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) > at > org.apache.myfaces.webapp.filter.ExtensionsFilter.doFilter(ExtensionsFilter.java:147) > at > org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) > at > org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) > at > org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230) > at > org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175) > at > org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128) > at > org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104) > at > org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) > at > org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:261) > at > org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844) > at > org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:581) > at > org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447) > at java.lang.Thread.run(Thread.java:619) -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online.