2010/2/4 Andy Schwartz <span dir="ltr">&lt;<a href="mailto:andy.schwartz@oracle.com">andy.schwartz@oracle.com</a>&gt;</span><br><div class="gmail_quote"><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
David, Cay -<br>
<br>
I can&#39;t remember what our resolution was on this issue. (Fingers cross that the archives will be back in working order soon.) My concern was that #{cc.parent} should not be given any special/non-obvious meaning. #{cc} resolves to the composite component instance, which is a UIComponent. Dereferencing the &quot;parent&quot; property on a UIComponent, whether accessed via #{cc.parent}, &quot;#{component.parent} or any other expression that resolves to a UIComponent, should do the obvious/consistent thing and actually call UIComponent.getParent(). We shouldn&#39;t introduce non-obvious behavior by replacing the meaning of the &quot;parent&quot; property to mean something different from what it normally means.<br>
</blockquote><div><br>I agree. It&#39;s confusing to redefine &quot;parent&quot; for composites.<br> <br></div><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">

So, my take is that #{cc.parent} should &quot;work&quot;, but should return the result of UIComponent.getParent() rather than UIComponent.getCompositeComponentParent(). If there are use cases where we do need to jump up all the way to the nearest ancestor composite component, I am fine with surfacing this, but would prefer to do so via a property other than &quot;parent&quot; - eg. #{cc.compositeParent}.<br>
</blockquote><div><br>Yes, agreed.<br> <br></div><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
<br>
Of course, this might all be a moot point, since as David mentioned, section 5.6.2.2 currently specifies:<br>
<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
If base is non-null, is an instance of UIComponent, is a composite component, and property is non-null and is equal to the string “parent”, call the static method UIComponent.getCompositeComponentParent() passing base as the argument, returning the result.<br>

</blockquote>
<br>
Personally I would like to remove this sentence from the spec.<br></blockquote><div><br>I would like to leave it, but just change UIComponent.getCompositeComponentParent() to UIComponent.getParent().<br><br></div><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">

<br>
David, Cay -<br>
<br>
Do you guys have use cases where EL access to the ancestor composite component (as opposed to the immediate parent component) is required? I would guess that the need to reach out to an ancestor from a composite would be rare, but that accessing the immediate parent would be more common than accessing the nearest ancestor composite. As such, the fact that our currently specified behavior for #{cc.parent} prevents composite component authors from accessing the actual parent seems like a spec bug, or, at least, a design flaw to me.<br>
</blockquote><div><br>I can&#39;t think of a use case, and I think it&#39;s perfectly acceptable to use UIComponent.getParent() instead of UIComponentgetCompositeComponentParent().<br> <br></div><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">

Thoughts?<br></blockquote><div><br>I agree that it&#39;s either a spec bug, implementation bug, or design flaw. One way or another, we should come up with a final resolution.<br><br><br>david<br></div><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">

<br>
Andy<br>
<br>
David Geary wrote:<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;"><div class="im">
Does anyone know whether cc.parent is supposed to work for composite components? Section 5.6.2.2 of the spec combined with the javadocs for UIComponent.getCompositeComponentParent() seems to indicate that it should. So it&#39;s either a spec or implementation bug. Either way, it should be fixed.<br>

<br>
It used to work with Mojarra 2.0, but it no longer works with Mojara 2.0.2.<br>
<br>
<br>
david<br>
<br></div>
2010/2/2 David Geary &lt;<a href="mailto:clarity.training@gmail.com" target="_blank">clarity.training@gmail.com</a> &lt;mailto:<a href="mailto:clarity.training@gmail.com" target="_blank">clarity.training@gmail.com</a>&gt;&gt;<div class="im">
<br>
<br>
<br>
<br>
    2010/1/29 Cay Horstmann &lt;<a href="mailto:cay@horstmann.com" target="_blank">cay@horstmann.com</a><br></div>
    &lt;mailto:<a href="mailto:cay@horstmann.com" target="_blank">cay@horstmann.com</a>&gt;&gt;<div><div></div><div class="h5"><br>
<br>
        I can&#39;t get cc.parent to work, and I stared at it for long<br>
        enough that I am pretty convinced that it is a bug.<br>
        (<a href="https://javaserverfaces.dev.java.net/issues/show_bug.cgi?id=1529" target="_blank">https://javaserverfaces.dev.java.net/issues/show_bug.cgi?id=1529</a>)<br>
<br>
        What I am wondering in this forum is whether cc.parent is<br>
        actually intended to be supported. There was some use case in<br>
        the olden days, when cc was dynamically scoped, but around<br>
        September 15, Andy Schwarz convinced you all that it should be<br>
        statically scoped. For all I know, that took away the raison<br>
        d&#39;être for cc.parent.<br>
<br>
        Or is there another use case? I only found one other example,<br>
        David Geary&#39;s developerWorks article<br>
        (<a href="http://www.ibm.com/developerworks/java/library/j-jsf2fu2/index.html" target="_blank">http://www.ibm.com/developerworks/java/library/j-jsf2fu2/index.html</a>).<br>
        He has a map component inside a place component that retrieves<br>
        the location from the parent. I am not even sure that&#39;s good<br>
        practice. It doesn&#39;t make the map component reusable, but<br>
        instead couples it with the parent.<br>
<br>
<br>
    It&#39;s true that the example may be a little contrived, but that<br>
    does not mean there are no use cases for tightly coupling nested<br>
    components to parent components, just as there are plenty of use<br>
    cases in OO in general for tight coupling, even though in general,<br>
    loose coupling is typically preferred. So IMO, cc.parent makes<br>
    perfect sense.<br>
<br>
<br>
    david<br>
<br>
<br>
        Thanks,<br>
<br>
        Cay<br>
<br>
        -- <br>
        Cay S. Horstmann | <a href="http://horstmann.com" target="_blank">http://horstmann.com</a> |<br></div></div>
        mailto:<a href="mailto:cay@horstmann.com" target="_blank">cay@horstmann.com</a> &lt;mailto:<a href="mailto:cay@horstmann.com" target="_blank">cay@horstmann.com</a>&gt;<br>
<br>
<br>
<br>
</blockquote>
<br>
</blockquote></div><br>