/* * 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) 2001 - 2013 Object Refinery Ltd, Pentaho Corporation and Contributors.. All rights reserved. */ package org.pentaho.reporting.engine.classic.core.layout.output; import org.pentaho.reporting.engine.classic.core.ReportAttributeMap; import org.pentaho.reporting.engine.classic.core.layout.text.ExtendedBaselineInfo; import org.pentaho.reporting.engine.classic.core.style.StyleSheet; import org.pentaho.reporting.libraries.base.config.Configuration; import org.pentaho.reporting.libraries.fonts.registry.FontMetrics; /** * The output processor metadata contains global configuration settings for a give report processing run. It is tightly * coupled to its output-processor and generally not interchangeable with output-processor-metadata objects from other * output-processors. * <p/> * The output processor meta-data object is statefull and must not be reused between different report processing runs. * * @author Thomas Morgner */ public interface OutputProcessorMetaData { public void initialize( final Configuration configuration ); public boolean isFeatureSupported( OutputProcessorFeature.BooleanOutputProcessorFeature feature ); public double getNumericFeatureValue( OutputProcessorFeature.NumericOutputProcessorFeature feature ); public boolean isContentSupported( Object content ); public FontMetrics getFontMetrics( StyleSheet styleSheet ); public ExtendedBaselineInfo getBaselineInfo( int codePoint, StyleSheet styleSheet ); public String getNormalizedFontFamilyName( final String name ); /** * The export descriptor is a string that describes the output characteristics. For libLayout outputs, it should start * with the output class (one of 'pageable', 'flow' or 'stream'), followed by '/liblayout/' and finally followed by * the output type (ie. PDF, Print, etc). * * @return the export descriptor. */ public String getExportDescriptor(); public Configuration getConfiguration(); public void commit(); /** * Checks whether this element provides some extra content that is not part of the visible layout structure. This can * be embedded scripts, anchors etc. * * @param style * @param attributes * @return */ public boolean isExtraContentElement( final StyleSheet style, final ReportAttributeMap attributes ); }