Class MutableAttributeImpl

    • Method Detail

      • resetToValuesMap

        public void resetToValuesMap()
      • valueFromMap

        protected String valueFromMap()
        Return the attribute value string by splicing the values of the map using valueListDelimiter and valueNameDelimiter with replacements of the given name/value if provided. If the name is not empty and value is empty then this will be removed from the final string
        Returns:
        string for value of this attribute from map
      • setValue

        public MutableAttributeImpl setValue​(CharSequence value)
        Description copied from interface: Attribute
        Add a new value or values depending on list and name delimiter settings and value content

        If the attribute does not have a list delimiter then its value will be set to the given value.

        If the attribute has a list delimiter but not name delimiter then value will be split by list delimiter and all values will be added to the attribute's value list. New ones added at the end, old ones left as is.

        If the attribute has a list delimiter and a name delimiter then value will be split by list delimiter and the name portion of each value will be used to find duplicates whose value will be replaced. New ones added at the end, old ones left where they are but with a new value.

        Specified by:
        setValue in interface Attribute
        Specified by:
        setValue in interface MutableAttribute
        Parameters:
        value - value or list of values (if attribute has a list delimiter and name delimiter) to change
        Returns:
        new attribute or same attribute if nothing changed or attribute is mutable
      • removeValue

        public MutableAttributeImpl removeValue​(CharSequence value)
        Description copied from interface: Attribute
        Add a new value or values depending on list and name delimiter settings and value content.

        If the attribute does not have a list delimiter and its value is equal to the given value then its value is set to empty

        If the attribute has a list delimiter but not name delimiter then value will be split by list delimiter and any values in attribute's value list will be removed

        If the attribute has a list delimiter and a name delimiter then value will be split by list delimiter and only the name portion of each value will be used for removal from the attribute's value list

        Specified by:
        removeValue in interface Attribute
        Specified by:
        removeValue in interface MutableAttribute
        Parameters:
        value - value or list of values (if attribute has a list delimiter and name delimiter) to remove
        Returns:
        new attribute or same attribute if nothing changed or attribute is mutable
      • containsValue

        public boolean containsValue​(CharSequence value)
        Description copied from interface: Attribute
        See if the attribute contains the value (if attribute has list delimiter set) or is equal to the value if no list delimiter is set
        Specified by:
        containsValue in interface Attribute
        Specified by:
        containsValue in interface MutableAttribute
        Parameters:
        value - name part of the attribute value list or the value if the attribute does not have a value list delimiter
        Returns:
        true if the attribute contains the valueName
      • hashCode

        public int hashCode()
        Overrides:
        hashCode in class Object