Open Source Repository

Home /excel/jxl-2.6.12 | Repository Home



jxl/write/biff/WritableFormattingRecords.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.common.Assert;

import jxl.biff.Fonts;
import jxl.biff.FormattingRecords;
import jxl.biff.NumFormatRecordsException;
import jxl.write.NumberFormats;
import jxl.write.WritableCellFormat;


/**
 * Handles the Format and XF record indexing.  The writable subclass
 * instantiates the predetermined list of XF records and formats
 * present in every Excel Workbook
 */
public class WritableFormattingRecords extends FormattingRecords
{
  /**
   * The statically defined normal style
   */
  public static WritableCellFormat normalStyle;

  /**
   * Constructor.  Instantiates the prerequisite list of formats and
   * styles required by all Excel workbooks
   
   @param f the list of Fonts
   @param styles the list of style clones
   */
  public WritableFormattingRecords(Fonts f, Styles styles)
  {
    super(f);

    try
    {
      // Hard code all the styles
      StyleXFRecord sxf = new StyleXFRecord
        (styles.getArial10Pt(),NumberFormats.DEFAULT);
      sxf.setLocked(true);
      addStyle(sxf);

      sxf = new StyleXFRecord(getFonts().getFont(1),NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(getFonts().getFont(1),NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(getFonts().getFont(1),NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(getFonts().getFont(2),NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(getFonts().getFont(3),NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(styles.getArial10Pt(),
                              NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(styles.getArial10Pt(),
                              NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(styles.getArial10Pt(),
                              NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(styles.getArial10Pt(),
                              NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(styles.getArial10Pt(),
                              NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(styles.getArial10Pt(),
                              NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(styles.getArial10Pt(),
                              NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(styles.getArial10Pt(),
                              NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      sxf = new StyleXFRecord(styles.getArial10Pt(),
                              NumberFormats.DEFAULT);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf400);
      addStyle(sxf);

      // That's the end of the built ins.  Write the normal style
      // cell XF here
      addStyle(styles.getNormalStyle());

      // Continue with "user defined" styles
      sxf = new StyleXFRecord(getFonts().getFont(1),
                              NumberFormats.FORMAT7);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf800);
      addStyle(sxf);

      sxf = new StyleXFRecord(getFonts().getFont(1),
                              NumberFormats.FORMAT5);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf800);
      addStyle(sxf);

      sxf = new StyleXFRecord(getFonts().getFont(1),
                              NumberFormats.FORMAT8);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf800);
      addStyle(sxf);

      sxf = new StyleXFRecord(getFonts().getFont(1),
                              NumberFormats.FORMAT6);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf800);
      addStyle(sxf);

      sxf = new StyleXFRecord(getFonts().getFont(1),
                              NumberFormats.PERCENT_INTEGER);
      sxf.setLocked(true);
      sxf.setCellOptions(0xf800);
      addStyle(sxf);

      // Hard code in the pre-defined number formats for now
      /*
        FormatRecord fr = new FormatRecord
        ("\"$\"#,##0_);\\(\"$\"#,##0\\)",5);
        addFormat(fr);

        fr = new FormatRecord
        ("\"$\"#,##0_);[Red]\\(\"$\"#,##0\\)", 6);
        addFormat(fr);

        fr = new FormatRecord
        ("\"$\"#,##0.00_);\\(\"$\"#,##0.00\\)", 7);
        addFormat(fr);

        fr = new FormatRecord
        ("\"$\"#,##0.00_);[Red]\\(\"$\"#,##0.00\\)", 8);
        addFormat(fr);

        fr = new FormatRecord
        ("_(\"$\"* #,##0_);_(\"$\"* \\(#,##0\\);_(\"$\"* \"-\"_);_(@_)",
        0x2a);
        //        outputFile.write(fr);

        fr = new FormatRecord
        ("_(* #,##0_);_(* \\(#,##0\\);_(* \"-\"_);_(@_)",
        0x2e);
        //        outputFile.write(fr);

        fr = new FormatRecord
        ("_(\"$\"* #,##0.00_);_(\"$\"* \\(#,##0.00\\);_(\"$\"* \"-\"??_);_(@_)",
        0x2c);
        //        outputFile.write(fr);

        fr = new FormatRecord
        ("_(* #,##0.00_);_(* \\(#,##0.00\\);_(* \"-\"??_);_(@_)",
        0x2b);
        //        outputFile.write(fr);
        */
    }
    catch (NumFormatRecordsException e)
    {
      // This should not happen yet, since we are just creating the file. 
      // Bomb out
      Assert.verify(false, e.getMessage());
    }
  }
}