001: /*
002:
003: ============================================================================
004: The Apache Software License, Version 1.1
005: ============================================================================
006:
007: Copyright (C) 1999-2003 The Apache Software Foundation. All rights reserved.
008:
009: Redistribution and use in source and binary forms, with or without modifica-
010: tion, are permitted provided that the following conditions are met:
011:
012: 1. Redistributions of source code must retain the above copyright notice,
013: this list of conditions and the following disclaimer.
014:
015: 2. Redistributions in binary form must reproduce the above copyright notice,
016: this list of conditions and the following disclaimer in the documentation
017: and/or other materials provided with the distribution.
018:
019: 3. The end-user documentation included with the redistribution, if any, must
020: include the following acknowledgment: "This product includes software
021: developed by the Apache Software Foundation (http://www.apache.org/)."
022: Alternately, this acknowledgment may appear in the software itself, if
023: and wherever such third-party acknowledgments normally appear.
024:
025: 4. The names "Batik" and "Apache Software Foundation" must not be
026: used to endorse or promote products derived from this software without
027: prior written permission. For written permission, please contact
028: apache@apache.org.
029:
030: 5. Products derived from this software may not be called "Apache", nor may
031: "Apache" appear in their name, without prior written permission of the
032: Apache Software Foundation.
033:
034: THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
035: INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
036: FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
037: APACHE SOFTWARE FOUNDATION OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
038: INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLU-
039: DING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
040: OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
041: ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
042: (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
043: THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
044:
045: This software consists of voluntary contributions made by many individuals
046: on behalf of the Apache Software Foundation. For more information on the
047: Apache Software Foundation, please see <http://www.apache.org/>.
048:
049: */
050:
051: package org.apache.batik.css.engine.sac;
052:
053: import java.util.Set;
054:
055: import org.w3c.css.sac.Selector;
056: import org.w3c.css.sac.SimpleSelector;
057: import org.w3c.dom.Element;
058: import org.w3c.dom.Node;
059:
060: /**
061: * This class provides an implementation of the
062: * {@link org.w3c.css.sac.DescendantSelector} interface.
063: *
064: * @author <a href="mailto:stephane@hillion.org">Stephane Hillion</a>
065: * @version $Id$
066: */
067: public class CSSChildSelector extends AbstractDescendantSelector {
068:
069: /**
070: * Creates a new CSSChildSelector object.
071: */
072: public CSSChildSelector(Selector ancestor, SimpleSelector simple) {
073: super (ancestor, simple);
074: }
075:
076: /**
077: * <b>SAC</b>: Implements {@link
078: * org.w3c.css.sac.Selector#getSelectorType()}.
079: */
080: public short getSelectorType() {
081: return SAC_CHILD_SELECTOR;
082: }
083:
084: /**
085: * Tests whether this selector matches the given element.
086: */
087: public boolean match(Element e, String pseudoE) {
088: Node n = e.getParentNode();
089: if (n != null && n.getNodeType() == Node.ELEMENT_NODE) {
090: return ((ExtendedSelector) getAncestorSelector()).match(
091: (Element) n, null)
092: && ((ExtendedSelector) getSimpleSelector()).match(
093: e, pseudoE);
094: }
095: return false;
096: }
097:
098: /**
099: * Fills the given set with the attribute names found in this selector.
100: */
101: public void fillAttributeSet(Set attrSet) {
102: ((ExtendedSelector) getAncestorSelector())
103: .fillAttributeSet(attrSet);
104: ((ExtendedSelector) getSimpleSelector())
105: .fillAttributeSet(attrSet);
106: }
107:
108: /**
109: * Returns a representation of the selector.
110: */
111: public String toString() {
112: SimpleSelector s = getSimpleSelector();
113: if (s.getSelectorType() == SAC_PSEUDO_ELEMENT_SELECTOR) {
114: return "" + getAncestorSelector() + s;
115: }
116: return getAncestorSelector() + " > " + s;
117: }
118: }
|