fixes for series text

PR:
Obtained from:
Submitted by:
Reviewed by:


git-svn-id: https://svn.apache.org/repos/asf/jakarta/poi/trunk@352624 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Andrew C. Oliver 2002-05-18 15:54:29 +00:00
parent 0b6b261c00
commit b29967698f
4 changed files with 86 additions and 73 deletions

View File

@ -1,4 +1,5 @@
/* ====================================================================
/*
* ====================================================================
* The Apache Software License, Version 1.1
*
* Copyright (c) 2002 The Apache Software Foundation. All rights
@ -51,7 +52,6 @@
* information on the Apache Software Foundation, please see
* <http://www.apache.org/>.
*/
package org.apache.poi.dev;
import org.w3c.dom.Document;
@ -61,38 +61,53 @@ import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import java.io.File;
public class RecordGenerator
{
/**
* Description of the Class
*
*@author andy
*@created May 10, 2002
*/
public class RecordGenerator {
/**
* The main program for the RecordGenerator class
*
*@param args The command line arguments
*@exception Exception Description of the Exception
*/
public static void main(String[] args)
throws Exception
{
throws Exception {
// Force load so that we don't start generating records and realise this hasn't compiled yet.
Class.forName("org.apache.poi.generator.FieldIterator");
if (args.length != 4)
{
if (args.length != 4) {
System.out.println("Usage:");
System.out.println(" java org.apache.poi.hssf.util.RecordGenerator RECORD_DEFINTIONS RECORD_STYLES DEST_SRC_PATH TEST_SRC_PATH");
} else
{
} else {
generateRecords(args[0], args[1], args[2], args[3]);
}
}
/**
* Description of the Method
*
*@param defintionsDir Description of the Parameter
*@param recordStyleDir Description of the Parameter
*@param destSrcPathDir Description of the Parameter
*@param testSrcPathDir Description of the Parameter
*@exception Exception Description of the Exception
*/
private static void generateRecords(String defintionsDir, String recordStyleDir, String destSrcPathDir, String testSrcPathDir)
throws Exception
{
throws Exception {
File definitionsFile = new File(defintionsDir);
for (int i = 0; i < definitionsFile.listFiles().length; i++)
{
for (int i = 0; i < definitionsFile.listFiles().length; i++) {
File file = definitionsFile.listFiles()[i];
if (file.isFile() &&
(file.getName().endsWith("_record.xml") ||
file.getName().endsWith("_type.xml")
)
)
{
) {
// Get record name and package
DocumentBuilderFactory factory =
DocumentBuilderFactory.newInstance();
@ -122,8 +137,7 @@ public class RecordGenerator
destinationPathFile = new File(destinationPath);
destinationPathFile.mkdirs();
destinationFilepath = destinationPath + "/Test" + recordName + suffix + ".java";
if (new File(destinationFilepath).exists() == false)
{
if (new File(destinationFilepath).exists() == false) {
String temp = (recordStyleDir + "/" + extendstg.toLowerCase() + "_test.xsl");
args = new String[]{"-in", file.getAbsolutePath(), "-xsl",
temp,
@ -131,8 +145,7 @@ public class RecordGenerator
"-TEXT"};
org.apache.xalan.xslt.Process.main(args);
System.out.println("Generated test: " + destinationFilepath);
} else
{
} else {
System.out.println("Skipped test generation: " + destinationFilepath);
}
}

View File

@ -10,10 +10,10 @@
<field type="int" size="1" name="text length">
<testresult value="0x0C"/>
</field>
<field type="int" size="2" name="undocumented">
<testresult value="0x5601"/>
<field type="int" size="1" name="undocumented" description="probably highbyte flag to tell whether string is little or big endian">
<testresult value="0x01"/>
</field>
<field type="string" size="(field_2_textLength * 2)" name="text">
<field type="hbstring" size="(field_2_textLength *2)" name="text">
<testresult value="Value Number"/>
</field>
</fields>

View File

@ -266,7 +266,7 @@ public class <xsl:value-of select="@name"/>Record
</xsl:template>
<xsl:template match="field" mode="tostring">
buffer.append(" .<xsl:value-of select="recutil:getFieldName(@name,20)"/> = ")<xsl:choose><xsl:when test="@type != 'string' and @type != 'float' and @size != 'varword'">
buffer.append(" .<xsl:value-of select="recutil:getFieldName(@name,20)"/> = ")<xsl:choose><xsl:when test="@type != 'string' and @type != 'hbstring' and @type != 'float' and @size != 'varword'">
.append("0x")
.append(HexDump.toHex((<xsl:value-of select="recutil:getType(@size,@type,00)"/>)get<xsl:value-of select="recutil:getFieldName1stCap(@name,0)"/>()))</xsl:when></xsl:choose>
.append(" (").append(get<xsl:value-of select="recutil:getFieldName1stCap(@name,0)"/>()).append(" )\n");

View File

@ -90,7 +90,7 @@ public class Test<xsl:value-of select="@name"/>Record
<xsl:value-of select="@name"/>Record record = new <xsl:value-of select="@name"/>Record((short)<xsl:value-of select="@id"/>, (short)data.length, data);
<xsl:for-each select="//fields/field">
<xsl:choose><xsl:when test="@type='string'">
<xsl:choose><xsl:when test="@type='string' or @type='hbstring'">
assertEquals( "<xsl:value-of select="./testresult/@value"/>", record.get<xsl:value-of select="recutil:getFieldName1stCap(@name,0)"/>());
</xsl:when><xsl:when test="@size='1'">
assertEquals( (byte)<xsl:value-of select="./testresult/@value"/>, record.get<xsl:value-of select="recutil:getFieldName1stCap(@name,0)"/>());
@ -115,7 +115,7 @@ public class Test<xsl:value-of select="@name"/>Record
<xsl:for-each select="//fields/field">
<xsl:choose><xsl:when test="@type='string'">
<xsl:choose><xsl:when test="@type='string' or @type='hbstring'">
record.set<xsl:value-of select="recutil:getFieldName1stCap(@name,0)"/>( "<xsl:value-of select="./testresult/@value"/>" );
</xsl:when><xsl:when test="@size='1'">
record.set<xsl:value-of select="recutil:getFieldName1stCap(@name,0)"/>( (byte)<xsl:value-of select="./testresult/@value"/> );