<html><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">I think I agree with Jim's assessment regarding resource-only evaluation. &nbsp;If we restrict to just that one type of EL expression, caching becomes much easier.<div><br></div><div>+1</div><div><br></div><div>With regard to relative paths, though, if you're using prefix-mapping, won't relative paths work? &nbsp;I've not tested it, but it seems like they ought to:</div><div><br></div><div>/myApp/faces/path/to/some/resource.css</div><div><br></div><div>which imports ./other/resource.css</div><div><br></div><div>That might work, but does require prefix mapping, which, for some odd reason, I never use. :)</div><div><br><div><div>On Oct 2, 2009, at 5:47 PM, Lincoln Baxter, III wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"> <div> <blockquote type="CITE"> <pre>It's been pointed out to me that in cases of the resource being in the
classpath, then the Resource EL *is* in fact the only way to get those 
files.  relative paths won't cut it.
</pre> </blockquote> <br> I suppose this would nullify my agreement with you, Jim ;)<br> <br> <pre>ACTION: Please vote +1 or -1 on OPTION ELEvaluatedInCSSOnly
back to +1 again

</pre> --Lincoln<br> <br> <br> On Fri, 2009-10-02 at 15:29 -0700, Jim Driscoll wrote: <blockquote type="CITE"> <pre>OK, I need to make a retraction:

It's been pointed out to me that in cases of the resource being in the 
classpath, then the Resource EL *is* in fact the only way to get those 
files.  relative paths won't cut it.

That's a pretty serious reason to have EL evaluation on CSS.  I 
apologize about the misunderstanding on my part.

So, that means that I need to change my vote:

I'd still like to have only resource EL evaluated.

But, regardless, EL needs to be evaluated, and it's probably common 
enough that it needs to be evaluated that having the default be for all 
CSS files is not unreasonable.

So,

ACTION: Please vote +1 or -1 on OPTION ELEvaluatedInCSSOnly

+1

Jim


On 10/2/09 2:39 PM, Jim Driscoll wrote:
&gt; Since EL evaluation in CSS will continue to have all the problems that I
&gt; mentioned earlier for JavaScript (performance and caching), and since
&gt; CSS files are fully capable of loading other resources through relative
&gt; paths, I'd like to voice mild opposition to the idea.
&gt;
&gt; ACTION: Please vote +1 or -1 on OPTION ELEvaluatedInCSSOnly
&gt;
&gt; -1
&gt;
&gt;
&gt; I'd instead prefer that we either:
&gt;
&gt; 1) Don't evaluate anything in any resource until we sort out the best
&gt; way to handle the performance and caching implications
&gt;
&gt; or, as a fallback
&gt;
&gt; 2) We evaluate only resource EL in CSS, with a context param that has to
&gt; be enabled for it to work (i.e., off by default - since it will decrease
&gt; performance and only need to be used in occasional cases). I'd
&gt; especially not like to rely on "magic strings" in the file name for this
&gt; - there's bound to be a better way implemented in 2.1, and I'd prefer
&gt; not to tie us to a brittle mechanism going forward.
&gt;
&gt; But as I said - my opposition to this is only mild - it's certainly not
&gt; the problem here that it would be in JavaScript - but once we allow it,
&gt; we can't "unallow" it when a better method comes along.
&gt;
&gt; Jim
&gt;
&gt; On 10/2/09 1:23 PM, Ed Burns wrote:
&gt;&gt; First, let me say I think we need to quickly make a statement in the
&gt;&gt; ChangeLog about this because not having this feature, at least in CSS
&gt;&gt; resources, is a big shortcoming for Resource loading. Note that Mojarra
&gt;&gt; currently does have this in *all* resources and I requested Ryan to make
&gt;&gt; it for just CSS CSS resources to provide a solution for Ted Goddard's
&gt;&gt; immediate problem regarding the prototype JavaScript library.
&gt;&gt;
&gt;&gt; EB&gt; OPTION DefaultToOptOut
&gt;&gt;
&gt;&gt; EB&gt; With this option, we modify Resource.getInputstream() to state
&gt;&gt; that EL
&gt;&gt; EB&gt; evaluation in Resource files is disabled by default. For
&gt;&gt; simplicity, I
&gt;&gt; EB&gt; suggest the user convey their intention at a per-application
&gt;&gt; granularity
&gt;&gt; EB&gt; using a context-param.
&gt;&gt;
&gt;&gt; This was the most popular option, but no-one was in favor of the context
&gt;&gt; param; everyone that voted wanted a finer grain solution.
&gt;&gt;
&gt;&gt; AS&gt; As Jim's email described, the caching behavior is intimately
&gt;&gt; related to
&gt;&gt; AS&gt; the question of how to handle EL evaluation in resources. I don't
&gt;&gt; think
&gt;&gt; AS&gt; that these two discussions really are separate matters.
&gt;&gt;
&gt;&gt; Yes, I see your point that they are related. However, we chose to say
&gt;&gt; nothing about cache headers and resources in 2.0. Therefore, I think
&gt;&gt; what we say about cache headers and resources should wait for the next
&gt;&gt; JCP release of JSF.
&gt;&gt;
&gt;&gt; On the other hand, as I said above, I think the absence of a way for
&gt;&gt; resources to refer to other resources is a missing feature. I intended
&gt;&gt; to specify it in Resource.getInputStream(), but I failed to do so
&gt;&gt; through an error on my part. Therefore, I'm going to place another
&gt;&gt; option on the table for inclusion in the ChangeLog.
&gt;&gt;
&gt;&gt; OPTION ELEvaluatedInCSSOnly
&gt;&gt;
&gt;&gt; With this option, we modify Resource.getInputStream() to state that EL
&gt;&gt; evaluation in CSS files is enabled by default. We will state that care
&gt;&gt; must be taken by the user to ensure that the EL expression always
&gt;&gt; evaluates to the same thing across multiple requests. We will state
&gt;&gt; that the user may decorate the ResourceHandler to get more flexibility.
&gt;&gt;
&gt;&gt; ACTION: Please vote +1 or -1 on OPTION ELEvaluatedInCSSOnly
&gt;&gt;
&gt;&gt; Thanks,
&gt;&gt;
&gt;&gt; Ed
&gt;&gt;
</pre> </blockquote> <table cellspacing="0" cellpadding="0" width="100%"> <tbody><tr> <td> --<br> <b>Lincoln Baxter, III</b><br> Co-Founder of <a href="http://ocpsoft.com">OcpSoft</a><br> <br> Creator of:<br> <a href="http://ocpsoft.com/prettyfaces">PrettyFaces</a>: URL rewriting for JSF<br> <a href="http://ocpsoft.com/prettytime">PrettyTime</a>: Java elapsed timestamp formatting<br> <br> <br> </td> </tr> </tbody></table> </div> </blockquote></div><br><div apple-content-edited="true"> <span class="Apple-style-span" style="border-collapse: separate; color: rgb(0, 0, 0); font-family: Helvetica; font-size: medium; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; "><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><span class="Apple-style-span" style="border-collapse: separate; color: rgb(0, 0, 0); font-family: Helvetica; font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; "><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><div><span class="Apple-style-span" style="font-size: medium; "><span class="Apple-style-span" style="font-size: 14px; "><div>Jason Lee, SCJP</div><div>President, Oklahoma City Java Users Group</div><div>Senior Java Developer, Sun Microsystems</div><div><a href="http://blogs.steeplesoft.com">http://blogs.steeplesoft.com</a></div></span></span></div></div></div></div></div></div></span></div></span> </div><br></div></body></html>