Class ValueFactory

java.lang.Object
io.sf.carte.doc.style.css.property.ValueFactory
All Implemented Interfaces:
CSSValueFactory

public class ValueFactory extends Object implements CSSValueFactory
Factory of CSS values.
  • Constructor Details Link icon

    • ValueFactory Link icon

      public ValueFactory()
    • ValueFactory Link icon

      public ValueFactory(short flags)
  • Method Details Link icon

    • isSizeSACUnit Link icon

      public static boolean isSizeSACUnit(LexicalUnit unit)
      Tests whether the unit type of the given NSAC lexical unit can apply to size (e.g. block size).
      Parameters:
      unit - the NSAC lexical unit.
      Returns:
      true if it is a size type (including percentage and unknown dimension), false otherwise.
    • isResolutionSACUnit Link icon

      public static boolean isResolutionSACUnit(LexicalUnit unit)
      Tests whether the unit type of the given NSAC lexical unit is a resolution unit.
      Parameters:
      unit - the NSAC lexical unit value.
      Returns:
      true if it is a resolution type, false otherwise.
    • isPositiveSizeSACUnit Link icon

      public static boolean isPositiveSizeSACUnit(LexicalUnit unit)
      Tests whether the given NSAC value could represent a size greater than zero (e.g. font size).
      Parameters:
      unit - the lexical value.
      Returns:
      true if it is a size type (including percentage and unknown dimension), false otherwise.
    • isSizeOrNumberSACUnit Link icon

      public static boolean isSizeOrNumberSACUnit(LexicalUnit unit)
      Tests whether the given NSAC unit type is a size or numeric unit (or a unknown unit).
      Parameters:
      unit - the lexical value.
      Returns:
      true if it is a size or numeric type (including percentage), false otherwise.
    • isPlainNumberOrPercentSACUnit Link icon

      public static boolean isPlainNumberOrPercentSACUnit(LexicalUnit unit)
      Tests whether the given NSAC unit type is a plain number (real or integer) or a percentage.
      Parameters:
      unit - the lexical value.
      Returns:
      true if is a plain number or a percentage, false otherwise.
    • isAngleSACUnit Link icon

      public static boolean isAngleSACUnit(LexicalUnit unit)
      Tests whether the given NSAC unit type is an angle unit.
      Parameters:
      unit - the lexical value.
      Returns:
      true if is an angle type, false otherwise.
    • isTimeSACUnit Link icon

      public static boolean isTimeSACUnit(LexicalUnit unit)
      Tests whether the given NSAC unit type is a time unit.
      Parameters:
      unit - the lexical value.
      Returns:
      true if is a time type, false otherwise.
    • parseProperty Link icon

      public StyleValue parseProperty(String value) throws DOMException
      Parses a property value. Assumes that the property is not a shorthand sub-property.

      Parameters:
      value - the string containing the property value.
      Returns:
      the CSSValue object containing the parsed value.
      Throws:
      DOMException - if a problem was found parsing the property.
    • parseProperty Link icon

      public StyleValue parseProperty(String value, Parser parser) throws DOMException
      Parses a property value with the supplied parser.
      Parameters:
      value - the string containing the property value.
      parser - the NSAC parser.
      Returns:
      the CSSValue object containing the parsed value.
      Throws:
      DOMException - if a problem was found parsing the property.
    • parseProperty Link icon

      public StyleValue parseProperty(String propertyName, String value, CSSParser parser) throws DOMException
      Parses a property value with the supplied parser.
      Parameters:
      propertyName - the string containing the property name.
      value - the string containing the property value.
      parser - the NSAC parser.
      Returns:
      the CSSValue object containing the parsed value.
      Throws:
      DOMException - if a problem was found parsing the property.
    • parseProperty Link icon

      public StyleValue parseProperty(String propertyName, String value, Parser parser) throws DOMException
      Parses a property value with the supplied parser.
      Parameters:
      value - the string containing the property value.
      parser - the NSAC parser.
      Returns:
      the CSSValue object containing the parsed value.
      Throws:
      DOMException - if a problem was found parsing the property.
    • parseMediaFeature Link icon

      public PrimitiveValue parseMediaFeature(String feature) throws DOMException
      Parses a feature value.

      Parameters:
      feature - the string containing the feature value
      Returns:
      the PrimitiveValue object containing the parsed value.
      Throws:
      DOMException - if a problem was found parsing the feature.
    • parseMediaFeature Link icon

      public PrimitiveValue parseMediaFeature(String feature, Parser parser) throws DOMException
      Parses a feature value.

      Parameters:
      feature - the string containing the feature value.
      parser - the parser used to parse values.
      Returns:
      the PrimitiveValue object containing the parsed value.
      Throws:
      DOMException - if a problem was found parsing the feature.
    • createCSSValue Link icon

      public StyleValue createCSSValue(LexicalUnit lunit) throws DOMException
      Creates a CSSValue according to the given lexical value.

      The value is assumed to be stand-alone, independent.

      Specified by:
      createCSSValue in interface CSSValueFactory
      Parameters:
      lunit - the lexical value.
      Returns:
      a CSSValue associated to the given lexical value, or null if a bracket list was empty.
      Throws:
      DOMException - if the lexical unit had a wrong content to create a value.
    • createCSSValue Link icon

      public StyleValue createCSSValue(LexicalUnit lunit, AbstractCSSStyleDeclaration style) throws DOMException
      Creates a CSSValue according to the given lexical value.

      The value is assumed to be stand-alone, independent.

      Parameters:
      lunit - the lexical value.
      style - the (style) declaration that should handle errors, or null to not handle errors.
      Returns:
      a CSSValue associated to the given lexical value, or null if a bracket list was empty.
      Throws:
      DOMException - if the lexical unit had a wrong content to create a value.
    • createCSSValue Link icon

      public StyleValue createCSSValue(LexicalUnit lunit, AbstractCSSStyleDeclaration style, boolean subproperty) throws DOMException
      Creates a CSSValue according to the given lexical value.
      Parameters:
      lunit - the lexical value.
      style - the (style) declaration that should handle errors, or null to not handle errors.
      subproperty - the flag marking whether it is a sub-property.
      Returns:
      a CSSValue associated to the given lexical value, or null if a bracket list was empty.
      Throws:
      DOMException - if the lexical unit had a wrong content to create a value.
    • parseBracketList Link icon

      public ValueFactory.ListValueItem parseBracketList(LexicalUnit nlu, AbstractCSSStyleDeclaration style, boolean subproperty)
      Parse a bracket list.
      Parameters:
      nlu - the lexical unit containing the first item in the bracket list.
      style - the style declaration to report issues to.
      subproperty - true if the value must be a subproperty.
      Returns:
      the bracket list, or null if the list was empty.
    • createCSSValueItem Link icon

      public ValueItem createCSSValueItem(LexicalUnit lunit, boolean subproperty) throws DOMException
      Creates a CSSValue simple item according to the given lexical value.

      This method either returns a value or throws an exception, but cannot return null.

      Parameters:
      lunit - the lexical value.
      subproperty - true if the value is created under the umbrella of a shorthand set.
      Returns:
      a ValueItem associated to the given lexical value.
      Throws:
      DOMException - if a problem was found setting the lexical value to a CSS value.
    • createCSSPrimitiveValue Link icon

      public PrimitiveValue createCSSPrimitiveValue(LexicalUnit lunit) throws DOMException
      Creates a primitive value according to the given lexical value.

      This method won't return a ratio value (callers must check for values spanning more than one lexical unit).

      If the lexical unit is a slash operator and is in content context, returns a LexicalValue.

      If the lexical unit is an operator and a parameter, returns an UnknownValue.

      Specified by:
      createCSSPrimitiveValue in interface CSSValueFactory
      Parameters:
      lunit - the lexical value.
      Returns:
      the primitive value.
      Throws:
      DOMException - if the lexical unit does not represent a valid primitive.
    • appendValueString Link icon

      public LexicalUnit appendValueString(StringBuilder buf, LexicalUnit lunit)
    • appendMinifiedValueString Link icon

      public LexicalUnit appendMinifiedValueString(StringBuilder buf, LexicalUnit lunit)
    • hasFactoryFlag Link icon

      public boolean hasFactoryFlag(short flag)
      Check whether the factory has the given flag set.
      Parameters:
      flag - the flag.
      Returns:
      true if the flag is set.