glens       02/04/22 00:12:27

  Modified:    src/java/org/apache/poi/hssf/dev BiffViewer.java
  Added:       src/java/org/apache/poi/hssf/record
                        SheetPropertiesRecord.java
               src/records/definitions sheet_properties_record.xml
               src/testcases/org/apache/poi/hssf/record
                        TestSheetPropertiesRecord.java
  Log:
  Sheet properties record.  Poi yum.
  
  Revision  Changes    Path
  1.13      +4 -0      jakarta-poi/src/java/org/apache/poi/hssf/dev/BiffViewer.java
  
  Index: BiffViewer.java
  ===================================================================
  RCS file: /home/cvs/jakarta-poi/src/java/org/apache/poi/hssf/dev/BiffViewer.java,v
  retrieving revision 1.12
  retrieving revision 1.13
  diff -u -r1.12 -r1.13
  --- BiffViewer.java   17 Apr 2002 22:21:16 -0000      1.12
  +++ BiffViewer.java   22 Apr 2002 07:12:26 -0000      1.13
  @@ -635,6 +635,10 @@
                   retval = new FormulaRecord(rectype, size, data);
                   break;
                   
  +            case SheetPropertiesRecord.sid:
  +                retval = new FormulaRecord(rectype, size, data);
  +                break;
  +
   
               default :
                   retval = new UnknownRecord(rectype, size, data);
  
  
  
  1.1                  
jakarta-poi/src/java/org/apache/poi/hssf/record/SheetPropertiesRecord.java
  
  Index: SheetPropertiesRecord.java
  ===================================================================
  
  /* ====================================================================
   * The Apache Software License, Version 1.1
   *
   * Copyright (c) 2002 The Apache Software Foundation.  All rights
   * reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   *
   * 1. Redistributions of source code must retain the above copyright
   *    notice, this list of conditions and the following disclaimer.
   *
   * 2. Redistributions in binary form must reproduce the above copyright
   *    notice, this list of conditions and the following disclaimer in
   *    the documentation and/or other materials provided with the
   *    distribution.
   *
   * 3. The end-user documentation included with the redistribution,
   *    if any, must include the following acknowledgment:
   *       "This product includes software developed by the
   *        Apache Software Foundation (http://www.apache.org/)."
   *    Alternately, this acknowledgment may appear in the software itself,
   *    if and wherever such third-party acknowledgments normally appear.
   *
   * 4. The names "Apache" and "Apache Software Foundation" and
   *    "Apache POI" must not be used to endorse or promote products
   *    derived from this software without prior written permission. For
   *    written permission, please contact [EMAIL PROTECTED]
   *
   * 5. Products derived from this software may not be called "Apache",
   *    "Apache POI", nor may "Apache" appear in their name, without
   *    prior written permission of the Apache Software Foundation.
   *
   * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
   * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
   * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
   * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
   * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
   * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
   * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
   * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
   * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
   * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   * SUCH DAMAGE.
   * ====================================================================
   *
   * This software consists of voluntary contributions made by many
   * individuals on behalf of the Apache Software Foundation.  For more
   * information on the Apache Software Foundation, please see
   * <http://www.apache.org/>.
   */
  
  
  package org.apache.poi.hssf.record;
  
  
  
  import org.apache.poi.util.BitField;
  import org.apache.poi.util.LittleEndian;
  import org.apache.poi.util.StringUtil;
  import org.apache.poi.util.HexDump;
  
  /**
   * Describes a chart sheet properties record.
   * NOTE: This source is automatically generated please do not modify this file.  
Either subclass or
   *       remove the record in src/records/definitions.
  
   * @author Glen Stampoultzis (glens at apache.org)
   */
  public class SheetPropertiesRecord
      extends Record
  {
      public final static short      sid                             = 0x1044;
      private  short      field_1_flags;
      private BitField   chartTypeManuallyFormatted                 = new 
BitField(0x1);
      private BitField   plotVisibleOnly                            = new 
BitField(0x2);
      private BitField   doNotSizeWithWindow                        = new 
BitField(0x4);
      private BitField   defaultPlotDimensions                      = new 
BitField(0x8);
      private BitField   autoPlotArea                               = new 
BitField(0x10);
      private  byte       field_2_empty;
      public final static byte        EMPTY_NOT_PLOTTED              = 0;
      public final static byte        EMPTY_ZERO                     = 1;
      public final static byte        EMPTY_INTERPOLATED             = 2;
  
  
      public SheetPropertiesRecord()
      {
  
      }
  
      /**
       * Constructs a SheetProperties record and sets its fields appropriately.
       *
       * @param id    id must be 0x1044 or an exception
       *              will be throw upon validation
       * @param size  size the size of the data area of the record
       * @param data  data of the record (should not contain sid/len)
       */
  
      public SheetPropertiesRecord(short id, short size, byte [] data)
      {
          super(id, size, data);
      }
  
      /**
       * Constructs a SheetProperties record and sets its fields appropriately.
       *
       * @param id    id must be 0x1044 or an exception
       *              will be throw upon validation
       * @param size  size the size of the data area of the record
       * @param data  data of the record (should not contain sid/len)
       * @param offset of the record's data
       */
  
      public SheetPropertiesRecord(short id, short size, byte [] data, int offset)
      {
          super(id, size, data, offset);
      }
  
      /**
       * Checks the sid matches the expected side for this record
       *
       * @param id   the expected sid.
       */
      protected void validateSid(short id)
      {
          if (id != sid)
          {
              throw new RecordFormatException("Not a SheetProperties record");
          }
      }
  
      protected void fillFields(byte [] data, short size, int offset)
      {
          field_1_flags                   = LittleEndian.getShort(data, 0x0 + offset);
          field_2_empty                   = data[ 0x2 + offset ];
  
      }
  
      public String toString()
      {
          StringBuffer buffer = new StringBuffer();
  
          buffer.append("[SheetProperties]\n");
  
          buffer.append("    .flags                = ")
              .append("0x")
              .append(HexDump.toHex((short)getFlags()))
              .append(" (").append(getFlags()).append(" )\n");
          buffer.append("         .chartTypeManuallyFormatted     = 
").append(isChartTypeManuallyFormatted()).append('\n');
          buffer.append("         .plotVisibleOnly          = 
").append(isPlotVisibleOnly     ()).append('\n');
          buffer.append("         .doNotSizeWithWindow      = 
").append(isDoNotSizeWithWindow ()).append('\n');
          buffer.append("         .defaultPlotDimensions     = 
").append(isDefaultPlotDimensions()).append('\n');
          buffer.append("         .autoPlotArea             = ").append(isAutoPlotArea 
       ()).append('\n');
  
          buffer.append("    .empty                = ")
              .append("0x")
              .append(HexDump.toHex((byte)getEmpty()))
              .append(" (").append(getEmpty()).append(" )\n");
  
          buffer.append("[/SheetProperties]\n");
          return buffer.toString();
      }
  
      public int serialize(int offset, byte[] data)
      {
          LittleEndian.putShort(data, 0 + offset, sid);
          LittleEndian.putShort(data, 2 + offset, (short)(getRecordSize() - 4));
  
          LittleEndian.putShort(data, 4 + offset, field_1_flags);
          data[ 6 + offset ] = field_2_empty;
  
          return getRecordSize();
      }
  
      /**
       * Size of record (exluding 4 byte header)
       */
      public int getRecordSize()
      {
          return 4 + 2 + 1;
      }
  
      public short getSid()
      {
          return this.sid;
      }
  
  
      /**
       * Get the flags field for the SheetProperties record.
       */
      public short getFlags()
      {
          return field_1_flags;
      }
  
      /**
       * Set the flags field for the SheetProperties record.
       */
      public void setFlags(short field_1_flags)
      {
          this.field_1_flags = field_1_flags;
      }
  
      /**
       * Get the empty field for the SheetProperties record.
       *
       * @return  One of 
       *        EMPTY_NOT_PLOTTED
       *        EMPTY_ZERO
       *        EMPTY_INTERPOLATED
       */
      public byte getEmpty()
      {
          return field_2_empty;
      }
  
      /**
       * Set the empty field for the SheetProperties record.
       *
       * @param field_2_empty
       *        One of 
       *        EMPTY_NOT_PLOTTED
       *        EMPTY_ZERO
       *        EMPTY_INTERPOLATED
       */
      public void setEmpty(byte field_2_empty)
      {
          this.field_2_empty = field_2_empty;
      }
  
      /**
       * Sets the chart type manually formatted field value.
       * Has the chart type been manually formatted?
       */
      public void setChartTypeManuallyFormatted(boolean value)
      {
          field_1_flags = chartTypeManuallyFormatted.setShortBoolean(field_1_flags, 
value);
      }
  
      /**
       * Has the chart type been manually formatted?
       * @return  the chart type manually formatted field value.
       */
      public boolean isChartTypeManuallyFormatted()
      {
          return chartTypeManuallyFormatted.isSet(field_1_flags);
      }
  
      /**
       * Sets the plot visible only field value.
       * Only show visible cells on the chart.
       */
      public void setPlotVisibleOnly(boolean value)
      {
          field_1_flags = plotVisibleOnly.setShortBoolean(field_1_flags, value);
      }
  
      /**
       * Only show visible cells on the chart.
       * @return  the plot visible only field value.
       */
      public boolean isPlotVisibleOnly()
      {
          return plotVisibleOnly.isSet(field_1_flags);
      }
  
      /**
       * Sets the do not size with window field value.
       * Do not size the chart when the window changes size
       */
      public void setDoNotSizeWithWindow(boolean value)
      {
          field_1_flags = doNotSizeWithWindow.setShortBoolean(field_1_flags, value);
      }
  
      /**
       * Do not size the chart when the window changes size
       * @return  the do not size with window field value.
       */
      public boolean isDoNotSizeWithWindow()
      {
          return doNotSizeWithWindow.isSet(field_1_flags);
      }
  
      /**
       * Sets the default plot dimensions field value.
       * Indicates that the default area dimensions should be used.
       */
      public void setDefaultPlotDimensions(boolean value)
      {
          field_1_flags = defaultPlotDimensions.setShortBoolean(field_1_flags, value);
      }
  
      /**
       * Indicates that the default area dimensions should be used.
       * @return  the default plot dimensions field value.
       */
      public boolean isDefaultPlotDimensions()
      {
          return defaultPlotDimensions.isSet(field_1_flags);
      }
  
      /**
       * Sets the auto plot area field value.
       * ??
       */
      public void setAutoPlotArea(boolean value)
      {
          field_1_flags = autoPlotArea.setShortBoolean(field_1_flags, value);
      }
  
      /**
       * ??
       * @return  the auto plot area field value.
       */
      public boolean isAutoPlotArea()
      {
          return autoPlotArea.isSet(field_1_flags);
      }
  
  
  }  // END OF CLASS
  
  
  
  
  
  
  
  1.1                  jakarta-poi/src/records/definitions/sheet_properties_record.xml
  
  Index: sheet_properties_record.xml
  ===================================================================
  <record id="0x1044" name="SheetProperties" package="org.apache.poi.hssf.record">
      <suffix>Record</suffix>
      <extends>Record</extends>
      <description>Describes a chart sheet properties record.</description>
      <author>Glen Stampoultzis (glens at apache.org)</author>
      <fields>
          <field type="bits" size="2" name="flags">
              <bit number="0" name="chart type manually formatted" description="Has 
the chart type been manually formatted?"/>
              <bit number="1" name="plot visible only" description="Only show visible 
cells on the chart."/>
              <bit number="2" name="do not size with window" description="Do not size 
the chart when the window changes size"/>
              <bit number="3" name="default plot dimensions" description="Indicates 
that the default area dimensions should be used."/>
              <bit number="4" name="auto plot area" description="??"/>
          </field>
          <field type="int" size="1" name="empty">
              <const name="not plotted" value="0" description="Empty cells are not 
plotted"/>
              <const name="zero" value="1" description="Empty cells are treated as 
zero"/>
              <const name="interpolated" value="2" description="Empty cells are 
interpolated"/>
          </field>
      </fields>
  </record>
  
  
  
  1.1                  
jakarta-poi/src/testcases/org/apache/poi/hssf/record/TestSheetPropertiesRecord.java
  
  Index: TestSheetPropertiesRecord.java
  ===================================================================
  
  /* ====================================================================
   * The Apache Software License, Version 1.1
   *
   * Copyright (c) 2002 The Apache Software Foundation.  All rights
   * reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   *
   * 1. Redistributions of source code must retain the above copyright
   *    notice, this list of conditions and the following disclaimer.
   *
   * 2. Redistributions in binary form must reproduce the above copyright
   *    notice, this list of conditions and the following disclaimer in
   *    the documentation and/or other materials provided with the
   *    distribution.
   *
   * 3. The end-user documentation included with the redistribution,
   *    if any, must include the following acknowledgment:
   *       "This product includes software developed by the
   *        Apache Software Foundation (http://www.apache.org/)."
   *    Alternately, this acknowledgment may appear in the software itself,
   *    if and wherever such third-party acknowledgments normally appear.
   *
   * 4. The names "Apache" and "Apache Software Foundation" and
   *    "Apache POI" must not be used to endorse or promote products
   *    derived from this software without prior written permission. For
   *    written permission, please contact [EMAIL PROTECTED]
   *
   * 5. Products derived from this software may not be called "Apache",
   *    "Apache POI", nor may "Apache" appear in their name, without
   *    prior written permission of the Apache Software Foundation.
   *
   * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
   * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
   * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
   * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
   * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
   * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
   * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
   * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
   * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
   * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   * SUCH DAMAGE.
   * ====================================================================
   *
   * This software consists of voluntary contributions made by many
   * individuals on behalf of the Apache Software Foundation.  For more
   * information on the Apache Software Foundation, please see
   * <http://www.apache.org/>.
   */
  
  
  package org.apache.poi.hssf.record;
  
  
  import junit.framework.TestCase;
  
  /**
   * Tests the serialization and deserialization of the SheetPropertiesRecord
   * class works correctly.  Test data taken directly from a real
   * Excel file.
   *
  
   * @author Glen Stampoultzis (glens at apache.org)
   */
  public class TestSheetPropertiesRecord
          extends TestCase
  {
      byte[] data = new byte[] {
          (byte)0x0A,(byte)0x00,
          (byte)0x00
          //,(byte)0x00       // not sure where that last byte comes from
      };
  
      public TestSheetPropertiesRecord(String name)
      {
          super(name);
      }
  
      public void testLoad()
              throws Exception
      {
          SheetPropertiesRecord record = new SheetPropertiesRecord((short)0x1044, 
(short)data.length, data);
          assertEquals( 10, record.getFlags());
          assertEquals( false, record.isChartTypeManuallyFormatted() );
          assertEquals( true, record.isPlotVisibleOnly() );
          assertEquals( false, record.isDoNotSizeWithWindow() );
          assertEquals( true, record.isDefaultPlotDimensions() );
          assertEquals( false, record.isAutoPlotArea() );
          assertEquals( 0, record.getEmpty());
  
  
          assertEquals( 7, record.getRecordSize() );
  
          record.validateSid((short)0x1044);
      }
  
      public void testStore()
      {
          SheetPropertiesRecord record = new SheetPropertiesRecord();
          record.setChartTypeManuallyFormatted( false );
          record.setPlotVisibleOnly( true );
          record.setDoNotSizeWithWindow( false );
          record.setDefaultPlotDimensions( true );
          record.setAutoPlotArea( false );
          record.setEmpty( (byte)0 );
  
  
          byte [] recordBytes = record.serialize();
          assertEquals(recordBytes.length - 4, data.length);
          for (int i = 0; i < data.length; i++)
              assertEquals("At offset " + i, data[i], recordBytes[i+4]);
      }
  }
  
  
  


Reply via email to