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 SummaryFields inherited from interface com.inductiveautomation.ignition.common.config.PropertySetEMPTY
- 
Constructor SummaryConstructors
- 
Method SummaryModifier 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.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface java.lang.IterableforEach, spliteratorMethods inherited from interface com.inductiveautomation.ignition.common.config.PropertySetextend, getExtension, newDefaultInstance, newExtensionMethods inherited from interface com.inductiveautomation.ignition.common.config.PropertyValueSourcegetNonNull, getNonNull
- 
Constructor Details- 
IntersectedPropertySet
 
- 
- 
Method Details- 
refreshpublic 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 interface- Iterable<PropertyValue>
 
- 
getReturns the intersected value, or null if the values don't match or the property isn't present.- Specified by:
- getin interface- PropertyValueSource
 
- 
contains- Specified by:
- containsin interface- PropertyValueSource
- Returns:
- True if the source contains a value for prop.
 
- 
getOrDefault- Specified by:
- getOrDefaultin interface- PropertyValueSource
- Returns:
- The value for prop or Property.getDefaultValue()if not present. Can return null if the value is null.
 
- 
getOrElseDescription copied from interface:PropertyValueSourceGet the value for a givenProperty, or else fall back to value if it's not present.- Specified by:
- getOrElsein interface- PropertyValueSource
- Parameters:
- prop- The- Propertyfor 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 interface- MutablePropertyValueSource
 
- 
set- Specified by:
- setin interface- MutablePropertyValueSource
 
- 
setImpl
- 
remove- Specified by:
- removein interface- MutablePropertyValueSource
 
- 
getCountpublic int getCount()
- 
getProperties- Specified by:
- getPropertiesin interface- PropertyValueSource
 
- 
getValuesDescription 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 interface- PropertyValueSource
 
- 
isExtendedDescription 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 interface- PropertySet
 
- 
isInheritedDescription copied from interface:PropertySetIndicates whether the property was inherited from a parent type.- Specified by:
- isInheritedin interface- PropertySet
 
- 
mergeDescription 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 interface- Mergable<PropertySet>
- Specified by:
- mergein interface- MutablePropertyValueSource
 
- 
getIntersectableProperties
 
-