/*************************GO-LICENSE-START*********************************
* Copyright 2014 ThoughtWorks, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*************************GO-LICENSE-END***********************************/
package com.thoughtworks.go.domain;
import org.apache.log4j.Logger;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.XMLReader;
import org.xml.sax.helpers.XMLFilterImpl;
/**
* This filter deletes elements without child nodes (text or elements) with
* the given tagname.
* It is used by the AntBuilder to get rid of empty tags
* generated by Ant's XmlLogger, like empty messages and tasks.
*
* @author <a href="mailto:joriskuipers@xs4all.nl">Joris Kuipers</a>
*/
public class EmptyElementFilter extends XMLFilterImpl {
private static final Logger LOG = Logger.getLogger(EmptyElementFilter.class);
private final String tagName;
private boolean checkingTag = false;
// atts for storing the Element info
private String messageUri;
private String messageQName;
private Attributes messageAtts;
/**
* Constructor for EmptyElementFilter.
*/
public EmptyElementFilter(String tagName) {
super();
this.tagName = tagName;
}
/**
* Constructor for EmptyElementFilter.
* @param arg0
*/
public EmptyElementFilter(String tagName, XMLReader arg0) {
super(arg0);
this.tagName = tagName;
}
/**
* @see org.xml.sax.ContentHandler#characters(char[], int, int)
*/
public void characters(char[] ch, int start, int length) throws SAXException {
if (checkingTag) {
cancelCheck();
}
super.characters(ch, start, length);
}
/**
* @see org.xml.sax.ContentHandler#endElement(String, String, String)
*/
public void endElement(String uri, String localName, String qName) throws SAXException {
if (checkingTag) {
// localName must be tagName now, and we're dealing with an empty tag
checkingTag = false;
if (LOG.isDebugEnabled()) {
LOG.debug("Skipping empty <" + localName + ">-tag");
}
} else {
super.endElement(uri, localName, qName);
}
}
/**
* @see org.xml.sax.ContentHandler#startElement(String, String, String, org.xml.sax.Attributes)
*/
public void startElement(String uri, String localName, String qName, Attributes atts) throws SAXException {
if (checkingTag) {
cancelCheck();
}
if (localName.equals(tagName)) {
// hold the delegation until we're sure this is not an empty tag
checkingTag = true;
messageUri = uri;
messageQName = qName;
messageAtts = atts;
} else {
super.startElement(uri, localName, qName, atts);
}
}
private void cancelCheck() throws SAXException {
// delegate the describeChange that we've held back and stop checking
super.startElement(messageUri, tagName, messageQName, messageAtts);
checkingTag = false;
}
}