w3c.css.properties.atsc.CssBackgroundRepeatATSC Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of cssvalidator Show documentation
Show all versions of cssvalidator Show documentation
Backend for the W3C CSS Validation Service
//
// $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.atsc;
import org.w3c.css.parser.CssStyle;
import org.w3c.css.properties.css.CssBackgroundConstants;
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.CssValue;
/**
*
* 5.3.4 'background-repeat'
*
*
* Value: repeat | repeat-x | repeat-y | no-repeat
* Initial: repeat
* Applies to: all elements
* Inherited: no
* Percentage values: N/A
*
* If a background image is specified, the value of 'background-repeat' determines
* how/if the image is repeated.
*
* A value of 'repeat' means that the image is repeated both horizontally and
* vertically. The 'repeat-x' ('repeat-y') value makes the image repeat horizontally
* (vertically), to create a single band of images from one side to the other.
* With a value of 'no-repeat', the image is not repeated.
*
* BODY {
* background: red url(pendant.gif);
* background-repeat: repeat-y;
* }
*
*
* In the example above, the image will only be repeated vertically.
*
* @version $Revision$
*/
public class CssBackgroundRepeatATSC extends CssProperty implements CssBackgroundConstants {
int repeat;
private static int[] hash_values;
/**
* Create a new CssBackgroundRepeatATSC
*/
public CssBackgroundRepeatATSC() {
repeat = 0;
}
/**
* Set the value of the property
*
* @param expression The expression for this property
* @throws InvalidParamException The expression is incorrect
*/
public CssBackgroundRepeatATSC(ApplContext ac, CssExpression expression,
boolean check) throws InvalidParamException {
if (check && expression.getCount() > 1) {
throw new InvalidParamException("unrecognize", ac);
}
CssValue val = expression.getValue();
setByUser();
if (val instanceof CssIdent) {
int hash = val.hashCode();
for (int i = 0; i < REPEAT.length; i++) {
if (hash_values[i] == hash) {
repeat = i;
expression.next();
return;
}
}
}
throw new InvalidParamException("value", expression.getValue(),
getPropertyName(), ac);
}
public CssBackgroundRepeatATSC(ApplContext ac, CssExpression expression)
throws InvalidParamException {
this(ac, expression, false);
}
/**
* Returns the value of this property
*/
public Object get() {
return REPEAT[repeat];
}
/**
* Returns true if this property is "softly" inherited
* e.g. his value equals inherit
*/
public boolean isSoftlyInherited() {
return repeat == 4;
}
/**
* Returns a string representation of the object.
*/
public String toString() {
return REPEAT[repeat];
}
/**
* Returns the name of this property
*/
public String getPropertyName() {
return "background-repeat";
}
/**
* Add this property to the CssStyle.
*
* @param style The CssStyle
*/
public void addToStyle(ApplContext ac, CssStyle style) {
CssBackgroundATSC cssBackground = ((ATSCStyle) style).cssBackgroundATSC;
if (cssBackground.repeat != null)
style.addRedefinitionWarning(ac, this);
cssBackground.repeat = 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 ((ATSCStyle) style).getBackgroundRepeatATSC();
} else {
return ((ATSCStyle) style).cssBackgroundATSC.repeat;
}
}
/**
* Compares two properties for equality.
*
* @param value The other property.
*/
public boolean equals(CssProperty property) {
return (property instanceof CssBackgroundRepeatATSC &&
repeat == ((CssBackgroundRepeatATSC) property).repeat);
}
/**
* Is the value of this property is a default value.
* It is used by all macro for the function print
*/
public boolean isDefault() {
return repeat == 0;
}
static {
hash_values = new int[REPEAT.length];
for (int i = 0; i < REPEAT.length; i++)
hash_values[i] = REPEAT[i].hashCode();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy