/* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * 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 . */ package org.libreoffice.report.pentaho.parser.table; import org.libreoffice.report.OfficeToken; import org.libreoffice.report.pentaho.OfficeNamespaces; import org.libreoffice.report.pentaho.parser.ElementReadHandler; import java.util.ArrayList; import java.util.List; import org.jfree.report.structure.Element; import org.jfree.report.structure.Section; import org.pentaho.reporting.libraries.xmlns.parser.XmlReadHandler; import org.xml.sax.Attributes; import org.xml.sax.SAXException; /** * Creation-Date: 03.07.2006, 13:50:41 * */ public class TableColumnsReadHandler extends ElementReadHandler { private final List columns; private final Section tableColumns; public TableColumnsReadHandler() { columns = new ArrayList(); tableColumns = new Section(); } /** * Returns the handler for a child element. * * @param tagName the tag name. * @param atts the attributes. * @return the handler or null, if the tagname is invalid. * @throws org.xml.sax.SAXException if there is a parsing error. */ @Override protected XmlReadHandler getHandlerForChild(final String uri, final String tagName, final Attributes atts) throws SAXException { if (OfficeNamespaces.TABLE_NS.equals(uri) && OfficeToken.TABLE_COLUMN.equals(tagName)) { final TableColumnReadHandler readHandler = new TableColumnReadHandler(); columns.add(readHandler); return readHandler; } return null; } /** * Done parsing. * * @throws org.xml.sax.SAXException if there is a parsing error. */ @Override protected void doneParsing() throws SAXException { for (int i = 0; i < columns.size(); i++) { final TableColumnReadHandler handler = columns.get(i); tableColumns.addNode(handler.getElement()); } } @Override public Element getElement() { return tableColumns; } }