/*
* 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.process.layoutrules;
import org.pentaho.reporting.engine.classic.core.layout.model.RenderNode;
/**
* A sequence element. Usually all elements get their maximum width. There are only a few special cases, where the
* minimum width needs to be considered:
* <p/>
* * The element is an inline-block and there is not enough space to print he complete element. The element is
* guaranteed to always get its minimum width.
*
* @author Thomas Morgner
*/
public interface InlineSequenceElement {
public enum Classification {
START, CONTENT, END;
}
public static final int START = 0;
public static final int CONTENT = 1;
public static final int END = 2;
/**
* The minimum width of the element. This is the minimum width of the element.
*
* @return
*/
public long getMinimumWidth( final RenderNode node );
/**
* The maximum width an element wants to take. This returns the preferred size; even if offered more space, an element
* would not consume more than that.
*
* @return
*/
public long getMaximumWidth( final RenderNode node );
public boolean isPreserveWhitespace( final RenderNode node );
public int getClassification();
public Classification getType();
}