Class IntersectedPropertySet
java.lang.Object
com.inductiveautomation.ignition.common.config.IntersectedPropertySet
- All Implemented Interfaces:
Countable,Extendable<PropertySet>,Mergable<PropertySet>,MutablePropertyValueSource,PropertySet,PropertyValueSource,Serializable,Iterable<PropertyValue>
- Direct Known Subclasses:
IntersectedBoundPropertySet,IntersectedTagConfig
Represents an intersection of PropertySets. Modification operations happen on all underlying sets. Functions such as
the iterator, contains, and getProperties only apply to properties that intersect cleanly (in other words,
are the same across all sets).
The class calculates the intersectable properties on construction, so changes to the underlying PropertySets will not
be visible unless refresh() is called. Changes made through this class, however, are tracked, so it
won't normally be necessary to call refresh().
- See Also:
-
Field Summary
Fields inherited from interface com.inductiveautomation.ignition.common.config.PropertySet
EMPTY -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionboolean<T> TReturns the intersected value, or null if the values don't match or the property isn't present.intgetCount()<T> TgetOrDefault(Property<T> prop) <T> TGet the value for a givenProperty, or else fall back to value if it's not present.Collection<Property<?>>Returns the opaque PropertyValue objects.protected List<? extends PropertySet>protected <T> TbooleanisExtended(Property<?> prop) Returns whether this property set contains a value for the prop, and the prop was actually inherited.booleanisInherited(Property<?> prop) Indicates whether the property was inherited from a parent type.protected <T> booleanisPropIntersectable(Property<T> prop) iterator()voidmerge(PropertySet other, boolean localOnly) Merges the values from other collection into this one.protected voidmodifyPossibleProps(Property<?> prop, boolean remove) voidrefresh()Recalculates the intersection.void<T> voidvoidset(PropertyValue propValue) protected voidsetImpl(PropertyValue propValue) Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface java.lang.Iterable
forEach, spliteratorMethods inherited from interface com.inductiveautomation.ignition.common.config.PropertySet
extend, getExtension, newDefaultInstance, newExtensionMethods inherited from interface com.inductiveautomation.ignition.common.config.PropertyValueSource
getNonNull, getNonNull
-
Constructor Details
-
IntersectedPropertySet
-
-
Method Details
-
refresh
public void refresh()Recalculates the intersection. Should be called when underlying data changes. Modifications to the property sets through this class do not require refresh() to be called, they are tracked separately. -
internalObjects
-
iterator
- Specified by:
iteratorin interfaceIterable<PropertyValue>
-
get
Returns the intersected value, or null if the values don't match or the property isn't present.- Specified by:
getin interfacePropertyValueSource
-
contains
- Specified by:
containsin interfacePropertyValueSource- Returns:
- True if the source contains a value for prop.
-
getOrDefault
- Specified by:
getOrDefaultin interfacePropertyValueSource- Returns:
- The value for prop or
Property.getDefaultValue()if not present. Can return null if the value is null.
-
getOrElse
Description copied from interface:PropertyValueSourceGet the value for a givenProperty, or else fall back to value if it's not present.- Specified by:
getOrElsein interfacePropertyValueSource- Parameters:
prop- ThePropertyfor which a value is to be retrieved.value- The value to default to if property isn't present.- Returns:
- The value of property if present, value if not. Can return null if the value is null.
-
intersect
-
isPropIntersectable
-
modifyPossibleProps
-
set
- Specified by:
setin interfaceMutablePropertyValueSource
-
set
- Specified by:
setin interfaceMutablePropertyValueSource
-
setImpl
-
remove
- Specified by:
removein interfaceMutablePropertyValueSource
-
getCount
public int getCount() -
getProperties
- Specified by:
getPropertiesin interfacePropertyValueSource
-
getValues
Description copied from interface:PropertyValueSourceReturns the opaque PropertyValue objects. This can be useful when you want to avoid the strict type checking of the value, and it's important to note that if the property is bound, the value will be a BoundValue. Be very careful about overriding, and make sure to maintain the methodology of using getProperties to iterate and get (or getOrDefault), to get the value, because those are all handled differently by BoundPropertySets, ExtendedPropertySets, etc.- Specified by:
getValuesin interfacePropertyValueSource
-
isExtended
Description copied from interface:PropertySetReturns whether this property set contains a value for the prop, and the prop was actually inherited. In other words, this is true if the property is inherited, and an override value is present.- Specified by:
isExtendedin interfacePropertySet
-
isInherited
Description copied from interface:PropertySetIndicates whether the property was inherited from a parent type.- Specified by:
isInheritedin interfacePropertySet
-
merge
Description copied from interface:MergableMerges the values from other collection into this one. Replaces any currently existing value with those from the other set.- Specified by:
mergein interfaceMergable<PropertySet>- Specified by:
mergein interfaceMutablePropertyValueSource
-
getIntersectableProperties
-