mirror of https://github.com/apache/poi.git
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:
parent
0b6b261c00
commit
b29967698f
|
@ -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);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -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>
|
||||
|
|
|
@ -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");
|
||||
|
|
|
@ -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"/> );
|
||||
|
|
Loading…
Reference in New Issue