Open Source Repository

Home /excel/jxl-2.6.12 | Repository Home



jxl/write/biff/IndexRecord.java
/*********************************************************************
*
*      Copyright (C) 2002 Andrew Khan
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
***************************************************************************/

package jxl.write.biff;

import jxl.biff.Type;
import jxl.biff.IntegerHelper;
import jxl.biff.WritableRecordData;

/**
 * Index into the cell rows in an worksheet
 */
class IndexRecord extends WritableRecordData
{
  /**
   * The binary data
   */
  private byte[] data;
  /**
   * The numbe of rows served by this index record
   */
  private int rows;
  /**
   * The position of the BOF record in the excel output stream
   */
  private int bofPosition;
  /**
   * The number of blocks needed to hold all the rows
   */
  private int blocks;

  /**
   * The position of the current 'pointer' within the byte array
   */
  private int dataPos;
  
  /**
   * Constructor
   
   @param pos the position of the BOF record
   @param bl the number of blocks
   @param r the number of rows
   */
  public IndexRecord(int pos, int r, int bl)
  {
    super(Type.INDEX);
    bofPosition = pos;
    rows = r;
    blocks = bl;

    // Allocate the amount of bytes required to hold all the blocks
    data = new byte[16 * blocks];
    dataPos = 16;
  }

  /**
   * Gets the binary data for output.  This writes out an empty data block, and
   * the information is filled in later on when the information becomes
   * available
   
   @return the binary data
   */
  protected byte[] getData()
  {
    IntegerHelper.getFourBytes(rows, data, 8);
    return data;
  }

  /**
   * Adds another index record into the array
   
   @param pos the position in the output file
   */
  void addBlockPosition(int pos)
  {
    IntegerHelper.getFourBytes(pos - bofPosition, data, dataPos);
    dataPos += 4;
  }

  /**
   * Sets the position of the data start.  This happens to be the position
   * of the DEFCOLWIDTH record
   */
  void setDataStartPosition(int pos)
  {
    IntegerHelper.getFourBytes(pos - bofPosition, data, 12);
  }
}