/* * 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.metadata; import org.pentaho.reporting.engine.classic.core.ReportElement; import org.pentaho.reporting.libraries.resourceloader.ResourceManager; import java.beans.PropertyEditor; /** * Describes the known attributes an element can take. * * @author Thomas Morgner */ public interface AttributeMetaData extends MetaData { public String getNameSpace(); public Class getTargetType(); /** * Can be one of "Value", "Resource", "Content", "Field", "Group", "Query", "Message", "Bundle-Key", "Bundle-Name", * "Name", "ElementName", "DateFormat", "NumberFormat" * * @return */ public String getValueRole(); public boolean isMandatory(); /** * Indicates if this attribute is computed. This indicates that values of the attribute will be computed at runtime * and any value set in the element itself is merely there for caching purposes and can be removed before writing the * PRPT file, before serializing and before deriving an element. */ public boolean isComputed(); /** * Indicates whether this attribute should be omitted when element is serialized to disk or written into a PRPT file. * Only mark attributes as transient which contain values that have been handled elsewhere. */ public boolean isTransient(); public boolean isBulk(); /** * Indicates whether this attribute is a design-time value. Such values will not be computed at runtime and any * expression given for that attribute will be ignored. * * @return */ public boolean isDesignTimeValue(); /** * This method can return null if there is no property editor registered for this type. * * @return */ public PropertyEditor getEditor(); public String[] getReferencedFields( ReportElement element, Object attributeValue ); public String[] getReferencedGroups( ReportElement element, Object attributeValue ); public ResourceReference[] getReferencedResources( ReportElement element, ResourceManager resourceManager, Object attributeValue ); public String[] getExtraCalculationFields(); }