/*
 * 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
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/* $Id: KeepProperty.java 1610839 2014-07-15 20:25:58Z vhennebert $ */

package org.apache.fop.fo.properties;

import org.apache.fop.datatypes.CompoundDatatype;
import org.apache.fop.fo.FObj;
import org.apache.fop.fo.PropertyList;
import org.apache.fop.fo.expr.PropertyException;

Class for properties that wrap Keep values
/** * Class for properties that wrap Keep values */
public final class KeepProperty extends Property implements CompoundDatatype {
class holding all canonical KeepProperty instances
/** class holding all canonical KeepProperty instances*/
private static final PropertyCache<KeepProperty> CACHE = new PropertyCache<KeepProperty>(); private boolean isCachedValue; private Property withinLine; private Property withinColumn; private Property withinPage;
Inner class for creating instances of KeepProperty
/** * Inner class for creating instances of KeepProperty */
public static class Maker extends CompoundPropertyMaker {
Params:
  • propId – the id of the property for which a Maker should be created
/** * @param propId the id of the property for which a Maker should be created */
public Maker(int propId) { super(propId); }
Create a new empty instance of KeepProperty.
Returns:the new instance.
/** * Create a new empty instance of KeepProperty. * @return the new instance. */
public Property makeNewProperty() { return new KeepProperty(); }
{@inheritDoc}
/** * {@inheritDoc} */
public Property convertProperty(Property p, PropertyList propertyList, FObj fo) throws PropertyException { if (p instanceof KeepProperty) { return p; } return super.convertProperty(p, propertyList, fo); } }
{@inheritDoc}
/** * {@inheritDoc} */
public void setComponent(int cmpId, Property cmpnValue, boolean bIsDefault) { if (isCachedValue) { log.warn("KeepProperty.setComponent() called on cached value. Ignoring..."); return; } if (cmpId == CP_WITHIN_LINE) { setWithinLine(cmpnValue, bIsDefault); } else if (cmpId == CP_WITHIN_COLUMN) { setWithinColumn(cmpnValue, bIsDefault); } else if (cmpId == CP_WITHIN_PAGE) { setWithinPage(cmpnValue, bIsDefault); } }
{@inheritDoc}
/** * {@inheritDoc} */
public Property getComponent(int cmpId) { if (cmpId == CP_WITHIN_LINE) { return getWithinLine(); } else if (cmpId == CP_WITHIN_COLUMN) { return getWithinColumn(); } else if (cmpId == CP_WITHIN_PAGE) { return getWithinPage(); } else { return null; } }
Params:
  • withinLine – withinLine property to set
  • bIsDefault – not used (??)
/** * @param withinLine withinLine property to set * @param bIsDefault not used (??) */
public void setWithinLine(Property withinLine, boolean bIsDefault) { this.withinLine = withinLine; }
Params:
  • withinColumn – withinColumn property to set
  • bIsDefault – not used (??)
/** * @param withinColumn withinColumn property to set * @param bIsDefault not used (??) */
protected void setWithinColumn(Property withinColumn, boolean bIsDefault) { this.withinColumn = withinColumn; }
Params:
  • withinPage – withinPage property to set
  • bIsDefault – not used (??)
/** * @param withinPage withinPage property to set * @param bIsDefault not used (??) */
public void setWithinPage(Property withinPage, boolean bIsDefault) { this.withinPage = withinPage; }
Returns:the withinLine property
/** * @return the withinLine property */
public Property getWithinLine() { return this.withinLine; }
Returns:the withinColumn property
/** * @return the withinColumn property */
public Property getWithinColumn() { return this.withinColumn; }
Returns:the withinPage property
/** * @return the withinPage property */
public Property getWithinPage() { return this.withinPage; }
Not sure what to do here. There isn't really a meaningful single value.
Returns:String representation
/** * Not sure what to do here. There isn't really a meaningful single value. * @return String representation */
public String toString() { return "Keep[" + "withinLine:" + getWithinLine().getObject() + ", withinColumn:" + getWithinColumn().getObject() + ", withinPage:" + getWithinPage().getObject() + "]"; }
Returns:the canonical KeepProperty instance corresponding to this property
/** * @return the canonical KeepProperty instance corresponding to * this property */
public KeepProperty getKeep() { KeepProperty keep = CACHE.fetch(this); /* make sure setComponent() can never alter cached values */ keep.isCachedValue = true; return keep; }
Returns:this.keep cast as Object
/** * @return this.keep cast as Object */
public Object getObject() { return this; }
{@inheritDoc}
/** {@inheritDoc} */
public boolean equals(Object o) { if (this == o) { return true; } if (o instanceof KeepProperty) { KeepProperty keep = (KeepProperty) o; return (keep.withinColumn == this.withinColumn) && (keep.withinLine == this.withinLine) && (keep.withinPage == this.withinPage); } return false; }
{@inheritDoc}
/** {@inheritDoc} */
public int hashCode() { int hash = 17; hash = 37 * hash + (withinColumn == null ? 0 : withinColumn.hashCode()); hash = 37 * hash + (withinLine == null ? 0 : withinLine.hashCode()); hash = 37 * hash + (withinPage == null ? 0 : withinPage.hashCode()); return hash; } }