All Downloads are FREE. Search and download functionalities are using the official Maven repository.

w3c.css.properties.css2.font.FontVariant Maven / Gradle / Ivy

There is a newer version: 1.0.8
Show newest version
//
// $Id$
// From Philippe Le Hegaret ([email protected])
//
// (c) COPYRIGHT MIT and INRIA, 1997.
// Please first read the full copyright statement in file COPYRIGHT.html
/*
 */
package org.w3c.css.properties.css2.font;

import org.w3c.css.parser.CssStyle;
import org.w3c.css.properties.css.CssProperty;
import org.w3c.css.util.ApplContext;
import org.w3c.css.util.InvalidParamException;
import org.w3c.css.values.CssExpression;
import org.w3c.css.values.CssIdent;
import org.w3c.css.values.CssOperator;
import org.w3c.css.values.CssValue;

import java.util.Vector;

/**
 */
public class FontVariant extends CssProperty implements FontConstant {

    Vector values = new Vector();

    private static CssIdent all = new CssIdent("all");

    /**
     * Create a new FontVariant
     */
    public FontVariant() {
        // nothing to do
    }

    /**
     * Creates a new FontVariant
     *
     * @param expression the font variant
     * @throws InvalidParamException values are incorrect
     */
    public FontVariant(ApplContext ac, CssExpression expression, boolean check)
            throws InvalidParamException {
        char op = expression.getOperator();
        CssValue val = expression.getValue();
        setByUser();

        do {
            if (expression.getValue() instanceof CssIdent) {
                int hash = ((CssIdent) expression.getValue()).hashCode();
                int i = 0;
                for (; i < hash_values.length; i++) {
                    if (hash_values[i] == hash) {
                        values.addElement(FONTVARIANT[i]);
                        break;
                    }
                }
                if (i == FONTVARIANT.length) {
                    throw new InvalidParamException("value",
                            expression.getValue(),
                            getPropertyName(), ac);
                }
            } else {
                throw new InvalidParamException("value", expression.getValue(),
                        getPropertyName(), ac);
            }
            op = expression.getOperator();
            expression.next();
        } while (op == CssOperator.COMMA);

    }

    public FontVariant(ApplContext ac, CssExpression expression)
            throws InvalidParamException {
        this(ac, expression, false);
    }

    /**
     * Returns the current value
     */
    public Object get() {
        return values.elementAt(0);
    }

    /**
     * Returns a string representation of the object.
     */
    public String toString() {
        String ret = "";
        int i = 0;

        while (i < values.size()) {
            ret += ", " + values.elementAt(i);
            i++;
        }

        return ret.substring(2);
    }

    /**
     * Returns the name of this property
     */
    public String getPropertyName() {
        return "font-variant";
    }

    /**
     * Add this property to the CssStyle.
     *
     * @param style The CssStyle
     */
    public void addToStyle(ApplContext ac, CssStyle style) {
        Css2Style style0 = (Css2Style) style;
        if (style0.fontVariant != null) {
            style0.addRedefinitionWarning(ac, this);
        }
        style0.fontVariant = this;
    }

    /**
     * Get this property in the style.
     *
     * @param style   The style where the property is
     * @param resolve if true, resolve the style to find this property
     */
    public CssProperty getPropertyInStyle(CssStyle style, boolean resolve) {
        if (resolve) {
            return ((Css2Style) style).getFaceFontVariant();
        } else {
            return ((Css2Style) style).fontVariant;
        }
    }

    /**
     * Compares two properties for equality.
     *
     * @param value The other property.
     */
    public boolean equals(CssProperty property) {
        // @@TODO
        return false;
    }

    /**
     * Is the value of this property is a default value.
     * It is used by all macro for the function print
     */
    public boolean isDefault() {
        return false;
    }

    private static int[] hash_values;

    static {
        hash_values = new int[FONTVARIANT.length];
        for (int i = 0; i < FONTVARIANT.length; i++)
            hash_values[i] = FONTVARIANT[i].hashCode();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy