org.eclipse.core.databinding
Class UpdateSetStrategy
java.lang.Object
org.eclipse.core.databinding.UpdateSetStrategy
-
public class UpdateSetStrategy
- extends
Object
Customizes a
Binding
between two
observable sets
. The following behaviors can be customized via the strategy:
- Conversion
- Automatic processing
Conversion:
When elements are added they can be
converted
to the
destination element type.
Automatic processing:
The processing to perform when the source observable changes. This behavior
is configured via policies provided on construction of the strategy (e.g.
POLICY_NEVER
,
POLICY_ON_REQUEST
,
POLICY_UPDATE
).
-
Since:
- 1.1
-
See Also:
-
DataBindingContext.bindSet(IObservableSet, IObservableSet, UpdateSetStrategy, UpdateSetStrategy)
,
IConverter
Field Summary
|
protected
IConverter
|
converter
|
static int
|
POLICY_NEVER
Policy constant denoting that the source observable's state should not be
tracked and that the destination observable's state should never be
updated. |
static int
|
POLICY_ON_REQUEST
Policy constant denoting that the source observable's state should not be
tracked, but that conversion and updating the destination observable's
state should be performed when explicitly requested. |
static int
|
POLICY_UPDATE
Policy constant denoting that the source observable's state should be
tracked, and that conversion and updating the destination observable's
state should be performed automatically on every change of the source
observable state. |
protected boolean
|
provideDefaults
|
Constructor Summary
|
UpdateSetStrategy
()
Creates a new update list strategy for automatically updating the
destination observable list whenever the source observable list changes. |
UpdateSetStrategy
(boolean provideDefaults,
int updatePolicy)
Creates a new update list strategy with a configurable update policy. |
UpdateSetStrategy
(int updatePolicy)
Creates a new update list strategy with a configurable update policy. |
Methods inherited from class java.lang.
Object
|
clone,
equals,
finalize,
getClass,
hashCode,
notify,
notifyAll,
toString,
wait,
wait,
wait
|
POLICY_NEVER
public static final int POLICY_NEVER
- Policy constant denoting that the source observable's state should not be
tracked and that the destination observable's state should never be
updated.
POLICY_ON_REQUEST
public static final int POLICY_ON_REQUEST
- Policy constant denoting that the source observable's state should not be
tracked, but that conversion and updating the destination observable's
state should be performed when explicitly requested.
POLICY_UPDATE
public static final int POLICY_UPDATE
- Policy constant denoting that the source observable's state should be
tracked, and that conversion and updating the destination observable's
state should be performed automatically on every change of the source
observable state.
converter
protected
IConverter converter
provideDefaults
protected boolean provideDefaults
UpdateSetStrategy
public UpdateSetStrategy()
- Creates a new update list strategy for automatically updating the
destination observable list whenever the source observable list changes.
A default converter will be provided. The defaults can be changed by
calling one of the setter methods.
UpdateSetStrategy
public UpdateSetStrategy(int updatePolicy)
- Creates a new update list strategy with a configurable update policy. A
default converter will be provided. The defaults can be changed by
calling one of the setter methods.
-
Parameters:
-
updatePolicy
- one of
POLICY_NEVER
,
POLICY_ON_REQUEST
, or
POLICY_UPDATE
UpdateSetStrategy
public UpdateSetStrategy(boolean provideDefaults,
int updatePolicy)
- Creates a new update list strategy with a configurable update policy. A
default converter will be provided if
provideDefaults
is
true
. The defaults can be changed by calling one of the
setter methods.
-
Parameters:
-
provideDefaults
- if true
, default validators and a default
converter will be provided based on the observable list's
type. -
updatePolicy
- one of
POLICY_NEVER
,
POLICY_ON_REQUEST
, or
POLICY_UPDATE
convert
public
Object convert(
Object element)
- When an element is added to the destination converts the element from the
source element type to the destination element type.
Default implementation will use the
converter
if one exists. If no converter exists no conversion occurs.
-
-
Parameters:
-
element
-
-
Returns:
- the converted element
fillDefaults
protected void fillDefaults(
IObservableSet source,
IObservableSet destination)
-
-
Parameters:
-
source
- -
destination
-
getUpdatePolicy
public int getUpdatePolicy()
-
-
Returns:
- the update policy
setConverter
public
UpdateSetStrategy setConverter(
IConverter converter)
- Sets the converter to be invoked when converting added elements from the
source element type to the destination element type.
-
-
Parameters:
-
converter
-
-
Returns:
- the receiver, to enable method call chaining
doAdd
protected
IStatus doAdd(
IObservableSet observableSet,
Object element)
- Adds the given element at the given index to the given observable list.
Clients may extend but must call the super implementation.
-
-
Parameters:
-
observableSet
- -
element
-
-
Returns:
- a status
doRemove
protected
IStatus doRemove(
IObservableSet observableSet,
Object element)
- Removes the element at the given index from the given observable list.
Clients may extend but must call the super implementation.
-
-
Parameters:
-
observableSet
- -
element
-
-
Returns:
- a status
checkAssignable
protected final void checkAssignable(
Object toType,
Object fromType,
String errorString)
-
createConverter
protected
IConverter createConverter(
Object fromType,
Object toType)
- Tries to create a converter that can convert from values of type
fromType. Returns
null
if no converter could be created.
Either toType or modelDescription can be null
, but not
both.
-
-
Parameters:
-
fromType
- -
toType
-
-
Returns:
- an IConverter, or
null
if unsuccessful
isAssignableFromTo
protected
Boolean isAssignableFromTo(
Object fromType,
Object toType)
- Returns
Boolean.TRUE
if the from type is assignable to the to
type, or
Boolean.FALSE
if it not, or null
if
unknown.
-
-
Parameters:
-
fromType
- -
toType
-
-
Returns:
- whether fromType is assignable to toType, or
null
if unknown
Guidelines for using Eclipse APIs.
Copyright (c) Eclipse contributors and others 2000, 2008. All rights reserved.