All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.poi.ss.formula.eval.RefEval Maven / Gradle / Ivy

There is a newer version: 5.2.5
Show newest version
/* ====================================================================
   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.
==================================================================== */

package org.apache.poi.ss.formula.eval;

import org.apache.poi.ss.formula.SheetRange;
import org.apache.poi.ss.usermodel.CellType;

/**
 * RefEval is the super interface for Ref2D and Ref3DEval. Basically a RefEval
 * impl should contain reference to the original ReferencePtg or Ref3DPtg as
 * well as the final "value" resulting from the evaluation of the cell
 * reference. Thus if the Cell has type {@link CellType#NUMERIC}, the contained
 * value object should be of type NumberEval; if cell type is {@link CellType#STRING},
 * contained value object should be of type StringEval
 */
public interface RefEval extends ValueEval, SheetRange {
    /**
     * @return the evaluated value of the cell referred to by this RefEval on the given sheet
     */
    ValueEval getInnerValueEval(int sheetIndex);

    /**
     * returns the zero based column index.
     */
    int getColumn();

    /**
     * returns the zero based row index.
     */
    int getRow();
    
    /**
     * returns the first sheet index this applies to
     */
    int getFirstSheetIndex();

    /**
     * returns the last sheet index this applies to, which
     *  will be the same as the first for a 2D and many 3D references
     */
    int getLastSheetIndex();
    
    /**
     * returns the number of sheets this applies to
     */
    int getNumberOfSheets();

    /**
     * Creates an {@link AreaEval} offset by a relative amount from this RefEval
     */
    AreaEval offset(int relFirstRowIx, int relLastRowIx, int relFirstColIx, int relLastColIx);
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy