1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
/*
* This program is free software; you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License, version 2.1 as published by the Free Software
* Foundation.
*
* You should have received a copy of the GNU Lesser General Public License along with this
* program; if not, you can obtain a copy at http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html
* or from the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU Lesser General Public License for more details.
*
* Copyright (c) 2006 - 2009 Object Refinery Ltd, Pentaho Corporation and Contributors. All rights reserved.
*/
package org.pentaho.reporting.libraries.xmlns.parser;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
/**
* A XmlReadHandler that reads character-data for the given element.
*
* @author Thomas Morgner
*/
public class StringReadHandler extends AbstractXmlReadHandler
{
/**
* A buffer containing the characters read so far.
*/
private StringBuffer buffer;
/**
* The string under construction.
*/
private String result;
/**
* Creates a new handler.
*/
public StringReadHandler()
{
super();
}
/**
* Starts parsing.
*
* @param attrs the attributes.
* @throws SAXException if there is a parsing error.
*/
protected void startParsing(final Attributes attrs)
throws SAXException
{
this.buffer = new StringBuffer();
}
/**
* This method is called to process the character data between element tags.
*
* @param ch the character buffer.
* @param start the start index.
* @param length the length.
* @throws SAXException if there is a parsing error.
*/
public void characters(final char[] ch, final int start, final int length)
throws SAXException
{
this.buffer.append(ch, start, length);
}
/**
* Done parsing.
*
* @throws SAXException if there is a parsing error.
*/
protected void doneParsing()
throws SAXException
{
this.result = this.buffer.toString();
this.buffer = null;
}
/**
* Returns the result as string.
*
* @return the parse-result as string.
*/
public String getResult()
{
return result;
}
/**
* Returns the object for this element.
*
* @return the object.
*/
public Object getObject()
{
return this.result;
}
}
|