Subversion Repositories Projects

Compare Revisions

Ignore whitespace Rev 1577 → Rev 1578

/dongfang_FC_rewrite_tool/src/dongfang/mkt/configuration/ConfigSet.java
22,7 → 22,7
public static final int NUMBER_OF_VARIABLES = 8;
String name;
int eepromVersion;
 
List<Section> declaredSections = new ArrayList<Section>();
List<ConfigEntry> entries = new ArrayList<ConfigEntry>();
 
29,7 → 29,7
public static class Section {
String name, title;
List<ConfigEntry> entries = new ArrayList<ConfigEntry>();
 
public Section(String name, String title) {
this.name = name;
this.title = title;
38,15 → 38,20
public void addConfigEntry(ConfigEntry e) {
this.entries.add(e);
}
 
public List<ConfigEntry> getEntries() {
return entries;
}
public String getName() { return name; }
public String getTitle() { return title; }
 
public String getName() {
return name;
}
 
public String getTitle() {
return title;
}
}
 
public static abstract class ConfigEntry {
String name;
 
71,13 → 76,11
}
}
 
public static class ByteEntry extends ConfigEntry {
ByteEntry(String name, boolean isDynamic) {
public static class StaticByteEntry extends ConfigEntry {
StaticByteEntry(String name) {
super(name);
this.isDynamic = isDynamic;
}
 
boolean isDynamic;
int value;
 
int getByteCount() {
99,10 → 102,58
 
void toXML(StringBuilder result) {
String s_value;
int numberOfHighestVariable = 255;
int numberOfLowestVariable = numberOfHighestVariable
- NUMBER_OF_VARIABLES;
if (isDynamic && value >= numberOfLowestVariable) {
s_value = Integer.toString(value);
result.append(" <parameter name=\"" + name + "\" value=\""
+ s_value + "\"/>\n");
}
}
 
public static class DynamicByteEntry extends StaticByteEntry {
int minValue = 0;
int maxValue = 255;
String staticCodeName;
String dynamicCodeName;
DynamicByteEntry(String name) {
super(name);
}
 
int getMinValue() {
return minValue;
}
 
int getMaxValue() {
return maxValue;
}
 
void setMinValue(int minValue) {
this.minValue = minValue;
}
 
void setMaxValue(int maxValue) {
this.maxValue = maxValue;
}
 
String getStaticCodeName() {
return staticCodeName;
}
 
String getDynamicCodeName() {
return dynamicCodeName;
}
 
void setStaticCodeName(String staticCodeName) {
this.staticCodeName = staticCodeName;
}
 
void setDynamicCodeName(String dynamicCodeName) {
this.dynamicCodeName = dynamicCodeName;
}
 
void toXML(StringBuilder result) {
String s_value;
int numberOfLowestVariable = 256 - NUMBER_OF_VARIABLES;
if (value >= numberOfLowestVariable) {
s_value = "var" + (value - numberOfLowestVariable);
} else
s_value = Integer.toString(value);
206,7 → 257,7
public List<Section> getDeclaredSections() {
return declaredSections;
}
 
public void setData(int[] data) {
int offset = 0;
for (ConfigEntry entry : entries) {
287,55 → 338,73
 
for (int i = 0; i < sectionNodes.getLength(); i++) {
Element sectionNode = (Element) sectionNodes.item(i);
Section section = new Section(sectionNode.getAttribute("name"), sectionNode.getAttribute("title"));
Section section = new Section(sectionNode.getAttribute("name"),
sectionNode.getAttribute("title"));
result.declaredSections.add(section);
NodeList parameterNodes = (NodeList) xpath.evaluate(
"parameter", sectionNode, XPathConstants.NODESET);
 
for (int j=0; j<parameterNodes.getLength(); j++) {
Element parameterNode = (Element) parameterNodes.item(j);
NodeList parameterNodes = (NodeList) xpath.evaluate(
"parameter", sectionNode, XPathConstants.NODESET);
 
ConfigEntry entry;
if (!sectionNode.hasAttribute("name")) {
throw new IOException("A parameter element (the " + j
+ "th in section "+sectionNode.getAttribute("name")+") had no name attribute!");
}
for (int j = 0; j < parameterNodes.getLength(); j++) {
Element parameterNode = (Element) parameterNodes.item(j);
 
String s_name = parameterNode.getAttribute("name");
String s_type;
ConfigEntry entry;
 
if (parameterNode.hasAttribute("type")) {
s_type = parameterNode.getAttribute("type");
} else {
s_type = "static";
}
if (!sectionNode.hasAttribute("name")) {
throw new IOException("A parameter element (the " + j
+ "th in section "
+ sectionNode.getAttribute("name")
+ ") had no name attribute!");
}
 
if ("static".equals(s_type)) {
entry = new ConfigSet.ByteEntry(s_name, false);
} else if ("dynamic".equals(s_type)) {
entry = new ConfigSet.ByteEntry(s_name, true);
} else if ("bitset".equals(s_type)) {
NodeList bitNodes = (NodeList) xpath.evaluate("bit", parameterNode, XPathConstants.NODESET);
String[] bitNames = new String[8];
for (int k=0; k<8; k++) {
Element bitNode = (Element) bitNodes.item(k);
if (bitNode != null) {
bitNames[k] = bitNode.getAttribute("name");
} else {
bitNames[k] = "Unused";
String s_name = parameterNode.getAttribute("name");
String s_type;
 
if (parameterNode.hasAttribute("type")) {
s_type = parameterNode.getAttribute("type");
} else {
s_type = "static";
}
 
if ("static".equals(s_type)) {
entry = new ConfigSet.StaticByteEntry(s_name);
} else if ("dynamic".equals(s_type)) {
ConfigSet.DynamicByteEntry de = new ConfigSet.DynamicByteEntry(s_name);
if (parameterNode.hasAttribute("minValue")) {
de.setMinValue(Integer.parseInt(parameterNode.getAttribute("minValue")));
}
if (parameterNode.hasAttribute("maxValue")) {
de.setMinValue(Integer.parseInt(parameterNode.getAttribute("maxValue")));
}
if (parameterNode.hasAttribute("staticCodeName")) {
de.setStaticCodeName(parameterNode.getAttribute("staticCodeName"));
} else de.setStaticCodeName(de.getName());
if (parameterNode.hasAttribute("dynamicCodeName")) {
de.setDynamicCodeName(parameterNode.getAttribute("dynamicCodeName"));
} else de.setDynamicCodeName(de.getName());
entry = de;
} else if ("bitset".equals(s_type)) {
NodeList bitNodes = (NodeList) xpath.evaluate("bit",
parameterNode, XPathConstants.NODESET);
String[] bitNames = new String[8];
for (int k = 0; k < 8; k++) {
Element bitNode = (Element) bitNodes.item(k);
if (bitNode != null) {
bitNames[k] = bitNode.getAttribute("name");
} else {
bitNames[k] = "Unused";
}
}
entry = new ConfigSet.BitSetEntry(s_name, bitNames);
} else {
throw new IOException("Unknown parameter type: "
+ s_type);
}
entry = new ConfigSet.BitSetEntry(s_name, bitNames);
} else {
throw new IOException("Unknown parameter type: " + s_type);
 
result.entries.add(entry);
section.addConfigEntry(entry);
}
result.entries.add(entry);
section.addConfigEntry(entry);
}
}
result.name = "" + version;
return result;
} catch (IOException ex) {
348,4 → 417,30
throw new IOException(ex);
}
}
 
public String generateDynamicSubstitutionCode() {
StringBuilder result = new StringBuilder(
"const MMXLATION XLATIONS[] = {\n");
boolean hasEntries = false;
for (ConfigEntry entry : entries) {
if (entry instanceof ConfigSet.DynamicByteEntry) {
if (hasEntries)
result.append(",\n");
else
hasEntries = true;
ConfigSet.DynamicByteEntry de = (ConfigSet.DynamicByteEntry) entry;
result.append("{offsetof(ParamSet_t, ");
result.append(de.getStaticCodeName());
result.append("), offsetof(DynamicParams_t, ");
result.append(de.getDynamicCodeName());
result.append("),");
result.append(Integer.toString(de.getMinValue()));
result.append(",");
result.append(Integer.toString(de.getMaxValue()));
result.append("}");
}
}
result.append("};");
return result.toString();
}
}
/dongfang_FC_rewrite_tool/src/dongfang/mkt/main/CodeGenerator.java
0,0 → 1,16
package dongfang.mkt.main;
 
import java.io.IOException;
 
import dongfang.mkt.configuration.ConfigSet;
 
public class CodeGenerator {
static void generateDynamicSubstitutionCode(int paramSetVersion) throws IOException {
ConfigSet cs = ConfigSet.parseXMLConfigSet(paramSetVersion);
System.out.println(cs.generateDynamicSubstitutionCode());
}
public static void main (String[] args) throws IOException {
CodeGenerator.generateDynamicSubstitutionCode(3);
}
}
/dongfang_FC_rewrite_tool/src/dongfang/mkt/main/UniversalConfigurator.java
121,13 → 121,11
 
private static int substituteVariables(String s_value) {
int numberOfHighestVar = 255;
int numberOfLowestVar = numberOfHighestVar
- ConfigSet.NUMBER_OF_VARIABLES;
int numberOfLowestVar = numberOfHighestVar - ConfigSet.NUMBER_OF_VARIABLES + 1;
for (int i = 0; i < ConfigSet.NUMBER_OF_VARIABLES; i++) {
String varName = "var" + i;
if (varName.equals(s_value)) {
System.out.println("Substing: " + s_value + "-->"
+ (numberOfLowestVar + i));
System.out.println("Substing: " + s_value + "-->" + (numberOfLowestVar + i));
return numberOfLowestVar + i;
}
}