[jsr-314-open-mirror] [jsr-314-open] [2.1 Spec Review] Transient State [Was: Fix UIData state saving model]

Andy Schwartz andy.schwartz at oracle.com
Thu Oct 21 12:27:46 EDT 2010


Hey Martin -

On 10/20/10 1:18 PM, Martin Marinschek wrote:
> Hi Andy,
>
> I agree with the points:
>
> - get/putTransient should be on UIComponent, or TransientStateHelper
> needs to be exposed
> - no Serializable keys are necessary
>   

Great.

> But - I am not sure about removing the TransientStateHelper
> contract... It doesn't need to extend from StateHelper,

Yep.

>  that is true -
> but won't the code look funny if state-saved property handling looks
> different from transient property handling?
>   

Perhaps.  Though if we have get/putTransient() and 
save/restoreTransientState() imlementations on UIComponent itself - ie. 
if all UIComponents implicitly support transient state, it isn't clear 
to me how much value is added by additionally providing 
TransientStateHelper, and come to think of it, even 
TransientStateHolder.  We don't have any code that currently tests 
for/casts to TransientStateHolder.  Do we expect that some classes other 
than UIComponent will participate in transient state saving in the future?

In any case, I have attached two Mojarra patches that demonstrate 
possible solutions to the issues that we have been discussing:

The first patch does the following:

- Serializable -> Object for keys
- TransientStateHelper no longer extends StateHelper
- UIComponent.getTransientStateHelper() methods are public
- The 1-arg versions of getTransientStateHelper() and getTransient() are 
now final (convenience methods)
- While I was in the code, I optimized the save/restoreTransientState() 
methods to avoid unnecessary instantiation of the ComponentStateHelper

The second patch takes a different approach:

- Serializable -> Object for keys
- TransientStateHelper and TransientStateHolder are no longer used (and 
can/should be removed)
- UIComponent.getTransientStateHelper() methods have been removed
- get/putTransient() methods are now exposed on UIComponent
- The 1-arg version of getTransient() is now final (convenience method)

The second approach seems conceptually simpler to me - no need to 
introduce the TransientStateHelper/TransientStateHolder 
concepts/contracts.  I don't see much loss of functionality with this 
approach.  Yes, without TransientStateHolder, only UIComponents can 
participate in transient state saving, but at the moment I don't see the 
use case for non-UIComponent-centric transient state saving.  If this 
use case comes up in the future, we could easily re-introduce 
TransientStateHolder.

I think I prefer the second approach, but the most important thing is 
that we get some solution in before 2.1 goes final.

Thoughts?

Andy

> best regards,
>
> Martin
>
>   

-------------- next part --------------
An embedded and charset-unspecified text was scrubbed...
Name: transient-state.patch
Url: http://lists.jboss.org/pipermail/jsr-314-open-mirror/attachments/20101021/eb8493cf/attachment.pl 
-------------- next part --------------
An embedded and charset-unspecified text was scrubbed...
Name: transient-state-take2.patch
Url: http://lists.jboss.org/pipermail/jsr-314-open-mirror/attachments/20101021/eb8493cf/attachment-0001.pl 


More information about the jsr-314-open-mirror mailing list