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

Martin Marinschek mmarinschek at apache.org
Fri Oct 22 07:02:47 EDT 2010


Hi Andy,

maybe I am missing something here, but isn't the normal use-case for
this a new component which adds a transient attribute?

something like: calculatedWeight. This should of course be exposed via
the API of the component - so there should be a:

Double getCalculatedWeight();
void setCalculatedWeight(Double weight);

And my point was that the implementation of these stateless getters
and setters should look similar to the stateful version.

What I would do:

Double getCalculatedWeight() {
  return (Double) getTransientStateHelper().get(PropertyKeys.weight, false);
}
void setCalculatedWeight(Double weight) {
  getTransientStateHelper().put(PropertyKeys.weight, weight);
}

Could TransientStateHelper not be an alternative implementation of the
StateHelper interface?

best regards,

Martin

On 10/21/10, Andy Schwartz <andy.schwartz at oracle.com> wrote:
> 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
>>
>>
>
>


-- 

http://www.irian.at

Your JSF powerhouse -
JSF Consulting, Development and
Courses in English and German

Professional Support for Apache MyFaces


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