removed obsolete scratchpad files
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@776937 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
5fb78707f7
commit
5a4ac88a81
@ -1,157 +0,0 @@
|
|||||||
|
|
||||||
/* ====================================================================
|
|
||||||
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
contributor license agreements. See the NOTICE file distributed with
|
|
||||||
this work for additional information regarding copyright ownership.
|
|
||||||
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
(the "License"); you may not use this file except in compliance with
|
|
||||||
the License. You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
==================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
package org.apache.poi.generator;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <p>For iterating through our fields.</p>
|
|
||||||
*
|
|
||||||
* @author Glen Stampoultzis (glens at apache.org)
|
|
||||||
*/
|
|
||||||
public class FieldIterator
|
|
||||||
{
|
|
||||||
protected int offset;
|
|
||||||
|
|
||||||
public FieldIterator()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This utility function returns a fill method entry for a given field
|
|
||||||
*
|
|
||||||
* @param size - how big of an "int" or the name of the size field for a string
|
|
||||||
* @param type - int or string
|
|
||||||
*/
|
|
||||||
public String fillDecoder(String size, String type)
|
|
||||||
{
|
|
||||||
String javaType = RecordUtil.getType(size, type, 0);
|
|
||||||
|
|
||||||
String result = "";
|
|
||||||
if (javaType.equals("short"))
|
|
||||||
result = "LittleEndian.getShort(data, pos + 0x" + Integer.toHexString(offset) + " + offset)";
|
|
||||||
else if (javaType.equals("short[]"))
|
|
||||||
result = "LittleEndian.getShortArray(data, pos + 0x" + Integer.toHexString(offset) + " + offset)";
|
|
||||||
else if (javaType.equals("int"))
|
|
||||||
result = "LittleEndian.getInt(data, pos + 0x" + Integer.toHexString(offset) + " + offset)";
|
|
||||||
else if (javaType.equals("byte"))
|
|
||||||
result = "data[ pos + 0x" + Integer.toHexString(offset) + " + offset ]";
|
|
||||||
else if (javaType.equals("double"))
|
|
||||||
result = "LittleEndian.getDouble(data, pos + 0x" + Integer.toHexString(offset) + " + offset)";
|
|
||||||
else if (javaType.equals("String") && !type.equals("hbstring"))
|
|
||||||
result = "StringUtil.getFromUnicode(data, pos + 0x" + Integer.toHexString(offset) + " + offset,("+ size + "-1)/2)";
|
|
||||||
else if (javaType.equals("String") && type.equals("hbstring"))
|
|
||||||
result = "StringUtil.getFromUnicodeHigh(data, pos + 0x" + Integer.toHexString(offset) + " + offset, ("+ size+"/2))";
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
offset += Integer.parseInt(size);
|
|
||||||
}
|
|
||||||
catch (NumberFormatException ignore)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String fillDecoder2(int position, String name, String size, String type)
|
|
||||||
{
|
|
||||||
if (type.startsWith("custom:"))
|
|
||||||
{
|
|
||||||
StringBuffer result = new StringBuffer();
|
|
||||||
result.append( RecordUtil.getFieldName( position, name, 0 ) );
|
|
||||||
result.append( " = new " );
|
|
||||||
String javaType = type.substring( 7 );
|
|
||||||
result.append(javaType);
|
|
||||||
result.append( "();\n");
|
|
||||||
result.append( " pos += " );
|
|
||||||
result.append(RecordUtil.getFieldName(position, name, 0))
|
|
||||||
.append(".fillField(data,size,pos + offset + ")
|
|
||||||
.append(offset)
|
|
||||||
.append(")");
|
|
||||||
return result.toString();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return RecordUtil.getFieldName(position, name, 30) +
|
|
||||||
" = " + fillDecoder(size, type);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//position(),@name,@size,@type
|
|
||||||
public String serialiseEncoder( int fieldNumber, String fieldName, String size, String type)
|
|
||||||
{
|
|
||||||
String javaType = RecordUtil.getType(size, type, 0);
|
|
||||||
String javaFieldName = RecordUtil.getFieldName(fieldNumber,fieldName,0);
|
|
||||||
|
|
||||||
String result = "";
|
|
||||||
if (type.startsWith("custom:"))
|
|
||||||
result = "pos += " + javaFieldName + ".serializeField( pos + " + (offset+4) + " + offset, data );";
|
|
||||||
else if (javaType.equals("short"))
|
|
||||||
result = "LittleEndian.putShort(data, " + (offset+4) + " + offset + pos, " + javaFieldName + ");";
|
|
||||||
else if (javaType.equals("short[]"))
|
|
||||||
result = "LittleEndian.putShortArray(data, " + (offset+4) + " + offset + pos, " + javaFieldName + ");";
|
|
||||||
else if (javaType.equals("int"))
|
|
||||||
result = "LittleEndian.putInt(data, " + (offset+4) + " + offset + pos, " + javaFieldName + ");";
|
|
||||||
else if (javaType.equals("byte"))
|
|
||||||
result = "data[ " + (offset+4) + " + offset + pos ] = " + javaFieldName + ";";
|
|
||||||
else if (javaType.equals("double"))
|
|
||||||
result = "LittleEndian.putDouble(data, " + (offset+4) + " + offset + pos, " + javaFieldName + ");";
|
|
||||||
else if (javaType.equals("String") && !type.equals("hbstring"))
|
|
||||||
result = "StringUtil.putUncompressedUnicode("+ javaFieldName +", data, offset + pos + 4);";
|
|
||||||
else if (javaType.equals("String") && type.equals("hbstring"))
|
|
||||||
result = "StringUtil.putUncompressedUnicodeHigh("+ javaFieldName +", data, "+(offset+4)+" + offset + pos);";
|
|
||||||
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
offset += Integer.parseInt(size);
|
|
||||||
}
|
|
||||||
catch (NumberFormatException ignore)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public String calcSize( int fieldNumber, String fieldName, String size, String type)
|
|
||||||
{
|
|
||||||
String result = " + ";
|
|
||||||
if (type.startsWith("custom:"))
|
|
||||||
{
|
|
||||||
String javaFieldName = RecordUtil.getFieldName(fieldNumber, fieldName, 0);
|
|
||||||
return result + javaFieldName + ".getSize()";
|
|
||||||
}
|
|
||||||
else if ("var".equals(size))
|
|
||||||
{
|
|
||||||
String javaFieldName = RecordUtil.getFieldName(fieldNumber,fieldName,0);
|
|
||||||
return result + " ("+javaFieldName + ".length() *2)";
|
|
||||||
}
|
|
||||||
else if ("varword".equals(size))
|
|
||||||
{
|
|
||||||
String javaFieldName = RecordUtil.getFieldName(fieldNumber,fieldName,0);
|
|
||||||
return result + javaFieldName + ".length * 2 + 2";
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
return result + size;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
@ -1,241 +0,0 @@
|
|||||||
|
|
||||||
/* ====================================================================
|
|
||||||
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
contributor license agreements. See the NOTICE file distributed with
|
|
||||||
this work for additional information regarding copyright ownership.
|
|
||||||
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
(the "License"); you may not use this file except in compliance with
|
|
||||||
the License. You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
==================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
package org.apache.poi.generator;
|
|
||||||
|
|
||||||
import java.util.StringTokenizer;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Helper functions for the record transformations.
|
|
||||||
*
|
|
||||||
* @author Glen Stampoultzis (glens at apache.org)
|
|
||||||
* @author Andrew C. Oliver (acoliver at apache dot org)
|
|
||||||
*/
|
|
||||||
public class RecordUtil
|
|
||||||
{
|
|
||||||
private static final String CR = "\n";
|
|
||||||
|
|
||||||
public static String getFieldName(int position, String name, int padTo)
|
|
||||||
{
|
|
||||||
StringBuffer fieldName = new StringBuffer("field_" + position + "_");
|
|
||||||
toIdentifier(name, fieldName);
|
|
||||||
pad(fieldName, padTo);
|
|
||||||
|
|
||||||
return fieldName.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected static StringBuffer pad(StringBuffer fieldName, int padTo)
|
|
||||||
{
|
|
||||||
for (int i = fieldName.length(); i < padTo; i++)
|
|
||||||
fieldName.append(' ');
|
|
||||||
return fieldName;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getFieldName(String name, int padTo)
|
|
||||||
{
|
|
||||||
StringBuffer fieldName = new StringBuffer();
|
|
||||||
toIdentifier(name, fieldName);
|
|
||||||
pad(fieldName, padTo);
|
|
||||||
|
|
||||||
return fieldName.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getFieldName1stCap(String name, int padTo)
|
|
||||||
{
|
|
||||||
StringBuffer fieldName = new StringBuffer();
|
|
||||||
toIdentifier(name, fieldName);
|
|
||||||
fieldName.setCharAt(0, Character.toUpperCase(fieldName.charAt(0)));
|
|
||||||
pad(fieldName, padTo);
|
|
||||||
|
|
||||||
return fieldName.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String clone(String name, String type, int pos) {
|
|
||||||
StringBuffer fieldName = new StringBuffer();
|
|
||||||
toIdentifier(name, fieldName);
|
|
||||||
|
|
||||||
String javaFieldName = getFieldName(pos, name, 0);
|
|
||||||
|
|
||||||
if (type.startsWith("custom:"))
|
|
||||||
{
|
|
||||||
String javaType = type.substring(7);
|
|
||||||
return "rec." + javaFieldName + " = ((" + javaType + ")" + javaFieldName + ".clone());";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return "rec." + javaFieldName + " = " + javaFieldName;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String initializeText(String size, String type)
|
|
||||||
{
|
|
||||||
// Removed because of wierdo initialization sequence in constructors.
|
|
||||||
// if (type.startsWith("custom:"))
|
|
||||||
// {
|
|
||||||
// String javaType = type.substring( 7 );
|
|
||||||
// return " = new " + javaType + "()";
|
|
||||||
// }
|
|
||||||
// else
|
|
||||||
// {
|
|
||||||
// return "";
|
|
||||||
// }
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void toIdentifier(String name, StringBuffer fieldName)
|
|
||||||
{
|
|
||||||
for (int i = 0; i < name.length(); i++)
|
|
||||||
{
|
|
||||||
if (name.charAt(i) == ' ')
|
|
||||||
fieldName.append(Character.toUpperCase(name.charAt(++i)));
|
|
||||||
else
|
|
||||||
fieldName.append(name.charAt(i));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void toConstIdentifier(String name, StringBuffer fieldName)
|
|
||||||
{
|
|
||||||
for (int i = 0; i < name.length(); i++)
|
|
||||||
{
|
|
||||||
if (name.charAt(i) == ' ')
|
|
||||||
fieldName.append('_');
|
|
||||||
else
|
|
||||||
fieldName.append(Character.toUpperCase(name.charAt(i)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getType(String size, String type, int padTo)
|
|
||||||
{
|
|
||||||
|
|
||||||
boolean wholeNumber = type.equals("bits") || type.equals("int");
|
|
||||||
if (wholeNumber && "1".equals(size))
|
|
||||||
return pad(new StringBuffer("byte"), padTo).toString();
|
|
||||||
else if (wholeNumber && "2".equals(size))
|
|
||||||
return pad(new StringBuffer("short"), padTo).toString();
|
|
||||||
else if (type.equals("int") && "varword".equals(size))
|
|
||||||
return pad(new StringBuffer("short[]"), padTo).toString();
|
|
||||||
else if (wholeNumber && "4".equals(size))
|
|
||||||
return pad(new StringBuffer("int"), padTo).toString();
|
|
||||||
else if (type.equals("float") && "8".equals(size))
|
|
||||||
return pad(new StringBuffer("double"), padTo).toString();
|
|
||||||
else if (type.equals("string"))
|
|
||||||
return pad(new StringBuffer("String"), padTo).toString();
|
|
||||||
else if (type.equals("hbstring"))
|
|
||||||
return pad(new StringBuffer("String"), padTo).toString();
|
|
||||||
else if (type.startsWith("custom:"))
|
|
||||||
{
|
|
||||||
int pos = type.lastIndexOf('.');
|
|
||||||
return pad(new StringBuffer(type.substring(pos+1)), padTo)
|
|
||||||
.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
return "short"; // if we don't know, default to short
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getType1stCap(String size, String type, int padTo)
|
|
||||||
{
|
|
||||||
StringBuffer result;
|
|
||||||
boolean numeric = type.equals("bits") || type.equals("int");
|
|
||||||
if (numeric && "1".equals(size))
|
|
||||||
result = pad(new StringBuffer("byte"), padTo);
|
|
||||||
else if (type.equals("int") && "varword".equals(size))
|
|
||||||
result = pad(new StringBuffer("short[]"), padTo);
|
|
||||||
else if (numeric && "2".equals(size))
|
|
||||||
result = pad(new StringBuffer("short"), padTo);
|
|
||||||
else if (type.equals("string"))
|
|
||||||
result = pad(new StringBuffer("String"), padTo);
|
|
||||||
else if (type.equals("hbstring"))
|
|
||||||
result = pad(new StringBuffer("HighByteString"), padTo);
|
|
||||||
|
|
||||||
else
|
|
||||||
return "";
|
|
||||||
|
|
||||||
result.setCharAt(0, Character.toUpperCase(result.charAt(0)));
|
|
||||||
|
|
||||||
return result.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getMask(int bit)
|
|
||||||
{
|
|
||||||
//if (bit > 1) bit--;
|
|
||||||
int mask = (int)Math.pow(2, bit);
|
|
||||||
|
|
||||||
return "0x" + Integer.toHexString(mask);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getConstName(String parentName, String constName, int padTo)
|
|
||||||
{
|
|
||||||
StringBuffer fieldName = new StringBuffer();
|
|
||||||
toConstIdentifier(parentName, fieldName);
|
|
||||||
fieldName.append('_');
|
|
||||||
toConstIdentifier(constName, fieldName);
|
|
||||||
pad(fieldName, padTo);
|
|
||||||
return fieldName.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return a byte array formatted string from a HexDump formatted string
|
|
||||||
* for example (byte)0x00,(byte)0x01 instead of 00 01
|
|
||||||
*/
|
|
||||||
public static String getByteArrayString(String data) {
|
|
||||||
StringTokenizer tokenizer = new StringTokenizer(data);
|
|
||||||
StringBuffer retval = new StringBuffer();
|
|
||||||
|
|
||||||
while (tokenizer.hasMoreTokens()) {
|
|
||||||
retval.append("(byte)0x").append(tokenizer.nextToken());
|
|
||||||
if (tokenizer.hasMoreTokens()) {
|
|
||||||
retval.append(",");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return retval.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getToString(String fieldName, String type, String size) {
|
|
||||||
StringBuffer result = new StringBuffer();
|
|
||||||
result.append(" buffer.append(\" .");
|
|
||||||
result.append(getFieldName(fieldName, 20));
|
|
||||||
result.append(" = \")" + CR);
|
|
||||||
if (type.equals("string") == false
|
|
||||||
&& type.equals("hbstring") == false
|
|
||||||
&& type.equals("float") == false
|
|
||||||
// && type.equals("varword") == false
|
|
||||||
&& size.equals("varword") == false
|
|
||||||
&& type.startsWith("custom:") == false)
|
|
||||||
{
|
|
||||||
result.append(" .append(\"0x\")");
|
|
||||||
result.append(".append(HexDump.toHex( ");
|
|
||||||
// result.append(getType(size, type, 0));
|
|
||||||
result.append(" get");
|
|
||||||
result.append(getFieldName1stCap(fieldName, 0));
|
|
||||||
result.append(" ()))" + CR);
|
|
||||||
}
|
|
||||||
result.append(" .append(\" (\").append( get");
|
|
||||||
result.append(getFieldName1stCap(fieldName,0));
|
|
||||||
result.append("() ).append(\" )\");");
|
|
||||||
return result.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getRecordId(String recordName, String excelName)
|
|
||||||
{
|
|
||||||
if (excelName == null || excelName.equals(""))
|
|
||||||
return recordName;
|
|
||||||
else
|
|
||||||
return excelName;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,103 +0,0 @@
|
|||||||
|
|
||||||
/* ====================================================================
|
|
||||||
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
contributor license agreements. See the NOTICE file distributed with
|
|
||||||
this work for additional information regarding copyright ownership.
|
|
||||||
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
(the "License"); you may not use this file except in compliance with
|
|
||||||
the License. You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
==================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
package org.apache.poi.hdf.generator;
|
|
||||||
|
|
||||||
import org.apache.poi.generator.FieldIterator;
|
|
||||||
import org.apache.poi.generator.RecordUtil;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This class overrides FieldIterator to handle HDF specific types
|
|
||||||
*/
|
|
||||||
public class HDFFieldIterator extends FieldIterator
|
|
||||||
{
|
|
||||||
|
|
||||||
public HDFFieldIterator()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public String fillDecoder(String size, String type)
|
|
||||||
{
|
|
||||||
|
|
||||||
String result = "";
|
|
||||||
|
|
||||||
if (type.equals("short[]"))
|
|
||||||
result = "LittleEndian.getSimpleShortArray(data, 0x" + Integer.toHexString(offset) + " + offset," + size + ")";
|
|
||||||
else if (type.equals("byte[]"))
|
|
||||||
result = "LittleEndian.getByteArray(data, 0x" + Integer.toHexString(offset) + " + offset," + size + ")";
|
|
||||||
else if (type.equals("BorderCode"))
|
|
||||||
result = "new BorderCode(data, 0x" + Integer.toHexString(offset) + " + offset)";
|
|
||||||
else if (type.equals("DateAndTime"))
|
|
||||||
result = "new DateAndTime(data, 0x" + Integer.toHexString(offset) + " + offset)";
|
|
||||||
else if (size.equals("2"))
|
|
||||||
result = "LittleEndian.getShort(data, 0x" + Integer.toHexString(offset) + " + offset)";
|
|
||||||
else if (size.equals("4"))
|
|
||||||
result = "LittleEndian.getInt(data, 0x" + Integer.toHexString(offset) + " + offset)";
|
|
||||||
else if (size.equals("1"))
|
|
||||||
result = "data[ 0x" + Integer.toHexString(offset) + " + offset ]";
|
|
||||||
else if (type.equals("double"))
|
|
||||||
result = "LittleEndian.getDouble(data, 0x" + Integer.toHexString(offset) + " + offset)";
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
offset += Integer.parseInt(size);
|
|
||||||
}
|
|
||||||
catch (NumberFormatException ignore)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String serialiseEncoder( int fieldNumber, String fieldName, String size, String type)
|
|
||||||
{
|
|
||||||
//String javaType = RecordUtil.getType(size, type, 0);
|
|
||||||
String javaFieldName = RecordUtil.getFieldName(fieldNumber,fieldName,0);
|
|
||||||
|
|
||||||
String result = "";
|
|
||||||
|
|
||||||
|
|
||||||
if (type.equals("short[]"))
|
|
||||||
result = "LittleEndian.putShortArray(data, 0x" + Integer.toHexString(offset) + " + offset, " + javaFieldName + ");";
|
|
||||||
else if (type.equals("byte[]"))
|
|
||||||
result = "System.arraycopy(" + javaFieldName + ", 0, data, 0x" + Integer.toHexString(offset) + " + offset, " + javaFieldName + ".length);";
|
|
||||||
else if (type.equals("BorderCode"))
|
|
||||||
result = javaFieldName + ".serialize(data, 0x" + Integer.toHexString(offset) + " + offset);";
|
|
||||||
else if (type.equals("DateAndTime"))
|
|
||||||
result = javaFieldName + ".serialize(data, 0x" + Integer.toHexString(offset) + " + offset);";
|
|
||||||
else if (size.equals("2"))
|
|
||||||
result = "LittleEndian.putShort(data, 0x" + Integer.toHexString(offset) + " + offset, (short)" + javaFieldName + ");";
|
|
||||||
else if (size.equals("4"))
|
|
||||||
result = "LittleEndian.putInt(data, 0x" + Integer.toHexString(offset) + " + offset, " + javaFieldName + ");";
|
|
||||||
else if (size.equals("1"))
|
|
||||||
result = "data[ 0x" + Integer.toHexString(offset) + " + offset] = " + javaFieldName + ";";
|
|
||||||
else if (type.equals("double"))
|
|
||||||
result = "LittleEndian.putDouble(data, 0x" + Integer.toHexString(offset) + " + offset, " + javaFieldName + ");";
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
offset += Integer.parseInt(size);
|
|
||||||
}
|
|
||||||
catch (NumberFormatException ignore)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,136 +0,0 @@
|
|||||||
|
|
||||||
/* ====================================================================
|
|
||||||
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
contributor license agreements. See the NOTICE file distributed with
|
|
||||||
this work for additional information regarding copyright ownership.
|
|
||||||
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
(the "License"); you may not use this file except in compliance with
|
|
||||||
the License. You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
==================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
package org.apache.poi.hdf.generator;
|
|
||||||
|
|
||||||
import org.apache.poi.generator.RecordUtil;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This class overrides RecordUtil to handle HDF specific types
|
|
||||||
*/
|
|
||||||
public class HDFRecordUtil extends RecordUtil
|
|
||||||
{
|
|
||||||
|
|
||||||
public HDFRecordUtil()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getType(String size, String type, int padTo)
|
|
||||||
{
|
|
||||||
|
|
||||||
return type;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getType1stCap(String size, String type, int padTo)
|
|
||||||
{
|
|
||||||
StringBuffer result = new StringBuffer();
|
|
||||||
result.append(type);
|
|
||||||
result = pad(result, padTo);
|
|
||||||
result.setCharAt(0, Character.toUpperCase(result.charAt(0)));
|
|
||||||
|
|
||||||
return result.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getBitFieldFunction(String name, String bitMask, String parentType, String withType)
|
|
||||||
{
|
|
||||||
String type = getBitFieldType(name, bitMask, parentType);
|
|
||||||
|
|
||||||
String retVal = new String();
|
|
||||||
if(withType.equals("true"))
|
|
||||||
{
|
|
||||||
retVal = type + " ";
|
|
||||||
}
|
|
||||||
if(type.equals("boolean"))
|
|
||||||
{
|
|
||||||
retVal += "is" + getFieldName1stCap(name, 0);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
retVal +="get" + getFieldName1stCap(name, 0);
|
|
||||||
}
|
|
||||||
return retVal;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getBitFieldGet(String name, String bitMask, String parentType, String parentField)
|
|
||||||
{
|
|
||||||
String type = getBitFieldType(name, bitMask, parentType);
|
|
||||||
|
|
||||||
String retVal = null;
|
|
||||||
|
|
||||||
if(type.equals("boolean"))
|
|
||||||
retVal = name + ".isSet(" + parentField + ");";
|
|
||||||
else
|
|
||||||
retVal = "( " + type + " )" + name + ".getValue(" + parentField + ");";
|
|
||||||
|
|
||||||
return retVal;
|
|
||||||
|
|
||||||
}
|
|
||||||
public static String getBitFieldSet(String name, String bitMask, String parentType, String parentField)
|
|
||||||
{
|
|
||||||
String type = getBitFieldType(name, bitMask, parentType);
|
|
||||||
|
|
||||||
String retVal = null;
|
|
||||||
|
|
||||||
if(type.equals("boolean"))
|
|
||||||
retVal = "(" + parentType + ")" + getFieldName(name, 0) + ".setBoolean(" + parentField + ", value)";
|
|
||||||
else
|
|
||||||
retVal = "(" + parentType + ")" + getFieldName(name, 0) + ".setValue(" + parentField + ", value)";
|
|
||||||
return retVal;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getBitFieldType(String name, String bitMask, String parentType)
|
|
||||||
{
|
|
||||||
byte parentSize = 0;
|
|
||||||
byte numBits = 0;
|
|
||||||
int mask = (int)Long.parseLong(bitMask.substring(2), 16);
|
|
||||||
|
|
||||||
if (parentType.equals("byte"))
|
|
||||||
parentSize = 8;
|
|
||||||
else if (parentType.equals("short"))
|
|
||||||
parentSize = 16;
|
|
||||||
else if (parentType.equals("int"))
|
|
||||||
parentSize = 32;
|
|
||||||
|
|
||||||
for (int x = 0; x < parentSize; x++)
|
|
||||||
{
|
|
||||||
int temp = mask;
|
|
||||||
numBits += (temp >> x) & 0x1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(numBits == 1)
|
|
||||||
{
|
|
||||||
return "boolean";
|
|
||||||
}
|
|
||||||
else if (numBits < 8)
|
|
||||||
{
|
|
||||||
return "byte";
|
|
||||||
}
|
|
||||||
else if (numBits < 16)
|
|
||||||
{
|
|
||||||
return "short";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return "int";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user