Open Source Repository

Home /excel/jxl-2.6.12 | Repository Home



jxl/write/biff/DBCellRecord.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 java.util.ArrayList;
import java.util.Iterator;

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

/**
 * Indexes the first row record of the block and each individual cell.  
 * This is invoked by the sheets write process
 */
class DBCellRecord extends WritableRecordData
{
  /**
   * The file position of the first Row record in this block
   */
  private int rowPos;

  /**
   * The position of the start of the next cell after the first row.  This
   * is used as the offset for the cell positions
   */
  private int cellOffset;

  /**
   * The list of all cell positions in this block
   */
  private ArrayList cellRowPositions;

  /**
   * The position of this record in the file.  Vital for calculating offsets
   */
  private int  position;

  /**
   * Constructor
   
   @param rp the position of this row
   */
  public DBCellRecord(int rp)
  {
    super(Type.DBCELL);
    rowPos = rp;
    cellRowPositions = new ArrayList(10);
  }

  /**
   * Sets the offset of this cell record within the sheet stream
   
   @param pos the offset
   */
  void setCellOffset(int pos)
  {
    cellOffset = pos;
  }

  /**
   * Adds a cell
   
   @param pos 
   */
  void addCellRowPosition(int pos)
  {
    cellRowPositions.add(new Integer(pos));
  }

  /**
   * Sets the position of this cell within the sheet stream
   
   @param pos the position
   */
  void setPosition(int pos)
  {
    position = pos;
  }

  /**
   * Gets the binary data for this cell record
   
   @return the binary data
   */
  protected byte[] getData()
  {
    byte[] data = new byte[* cellRowPositions.size()];

    // Set the offset to the first row
    IntegerHelper.getFourBytes(position - rowPos, data, 0);

    // Now add in all the cell offsets
    int pos = 4;
    int lastCellPos = cellOffset;
    Iterator i = cellRowPositions.iterator();
    while (i.hasNext())
    {
      int cellPos = ((Integeri.next()).intValue();
      IntegerHelper.getTwoBytes(cellPos - lastCellPos, data, pos);
      lastCellPos = cellPos;
      pos += 2;
    }

    return data;
  }
}