/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you 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. */ /* * $Id$ */ /* * * LoggingContentHandler.java * */ package org.apache.qetest.xsl; import org.apache.qetest.Logger; import org.apache.qetest.LoggingHandler; import org.xml.sax.Attributes; import org.xml.sax.ContentHandler; import org.xml.sax.Locator; import org.xml.sax.SAXException; /** * Cheap-o ContentHandler for use by API tests. *
Implements ContentHandler and dumps simplistic info * everything to a Logger; a way to debug SAX stuff.
* @author shane_curcuru@lotus.com * @version $Id$ */ public class LoggingContentHandler extends LoggingHandler implements ContentHandler { /** No-op sets logger to default. */ public LoggingContentHandler() { setLogger(getDefaultLogger()); } /** * Ctor that calls setLogger automatically. * * @param r Logger we should log to */ public LoggingContentHandler(Logger l) { setLogger(l); } /** * Our default handler that we pass all events through to. */ protected ContentHandler defaultHandler = null; /** * Set a default handler for us to wrapper. * Set a ContentHandler for us to use. * * @param default Object of the correct type to pass-through to; * throws IllegalArgumentException if null or incorrect type */ public void setDefaultHandler(Object defaultC) { try { defaultHandler = (ContentHandler)defaultC; } catch (Throwable t) { throw new java.lang.IllegalArgumentException("setDefaultHandler illegal type: " + t.toString()); } } /** * Accessor method for our default handler. * * @return default (Object) our default handler; null if unset */ public Object getDefaultHandler() { return (Object)defaultHandler; } /** Prefixed to all logger msg output. */ public final String prefix = "LCH:"; /** Cheap-o string representation of last event we got. */ protected String lastItem = NOTHING_HANDLED; /** * Accessor for string representation of last event we got. * @param s string to set */ protected void setLastItem(String s) { lastItem = s; } /** * Accessor for string representation of last event we got. * @return last event string we had */ public String getLast() { return lastItem; } /** setExpected, etc. not yet implemented. */ /** How many characters to report from characters event. */ private int charLimit = 30; /** * How many characters to report from characters event. * @param l charLimit for us to use */ public void setCharLimit(int l) { charLimit = l; } /** * How many characters to report from characters event. * @return charLimit we use */ public int getCharLimit() { return charLimit; } ////////////////// Implement ContentHandler ////////////////// protected Locator ourLocator = null; public void setDocumentLocator (Locator locator) { // Note: this implies this class is !not! threadsafe setLastItem("setDocumentLocator"); ourLocator = locator; // future use logger.logMsg(level, prefix + getLast()); if (null != defaultHandler) defaultHandler.setDocumentLocator(locator); } public void startDocument () throws SAXException { setLastItem("startDocument"); logger.logMsg(level, prefix + getLast()); if (null != defaultHandler) defaultHandler.startDocument(); } public void endDocument() throws SAXException { setLastItem("endDocument"); logger.logMsg(level, prefix + getLast()); if (null != defaultHandler) defaultHandler.endDocument(); } public void startPrefixMapping (String prefix, String uri) throws SAXException { setLastItem("startPrefixMapping: " + prefix + ", " + uri); logger.logMsg(level, prefix + getLast()); if (null != defaultHandler) defaultHandler.startPrefixMapping(prefix, uri); } public void endPrefixMapping (String prefix) throws SAXException { setLastItem("endPrefixMapping: " + prefix); logger.logMsg(level, prefix + getLast()); if (null != defaultHandler) defaultHandler.endPrefixMapping(prefix); } public void startElement (String namespaceURI, String localName, String qName, Attributes atts) throws SAXException { StringBuffer buf = new StringBuffer(); buf.append("startElement: " + namespaceURI + ", " + namespaceURI + ", " + qName); int n = atts.getLength(); for(int i = 0; i < n; i++) { buf.append(", " + atts.getQName(i)); } setLastItem(buf.toString()); logger.logMsg(level, prefix + getLast()); if (null != defaultHandler) defaultHandler.startElement(namespaceURI, localName, qName, atts); } public void endElement (String namespaceURI, String localName, String qName) throws SAXException { setLastItem("endElement: " + namespaceURI + ", " + namespaceURI + ", " + qName); logger.logMsg(level, prefix + getLast()); if (null != defaultHandler) defaultHandler.endElement(namespaceURI, localName, qName); } public void characters (char ch[], int start, int length) throws SAXException { String s = new String(ch, start, (length > charLimit) ? charLimit : length); if(length > charLimit) setLastItem("characters: \"" + s + "\"..."); else setLastItem("characters: \"" + s + "\""); logger.logMsg(level, prefix + getLast()); if (null != defaultHandler) defaultHandler.characters(ch, start, length); } public void ignorableWhitespace (char ch[], int start, int length) throws SAXException { setLastItem("ignorableWhitespace: len " + length); logger.logMsg(level, prefix + getLast()); if (null != defaultHandler) defaultHandler.ignorableWhitespace(ch, start, length); } public void processingInstruction (String target, String data) throws SAXException { setLastItem("processingInstruction: " + target + ", " + data); logger.logMsg(level, prefix + getLast()); if (null != defaultHandler) defaultHandler.processingInstruction(target, data); } public void skippedEntity (String name) throws SAXException { setLastItem("skippedEntity: " + name); logger.logMsg(level, prefix + getLast()); if (null != defaultHandler) defaultHandler.skippedEntity(name); } }