diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/ConfigDefinition.java b/java_tools/configuration_definition/src/main/java/com/rusefi/ConfigDefinition.java index cfbddde6fd..ba7f1e103c 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/ConfigDefinition.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/ConfigDefinition.java @@ -257,7 +257,7 @@ public class ConfigDefinition { List destinations = new ArrayList<>(); if (TS_OUTPUTS_DESTINATION != null) { destinations.add(new OutputsSectionConsumer(TS_OUTPUTS_DESTINATION + File.separator + "generated/output_channels.ini", state)); - destinations.add(new DataLogConsumer(TS_OUTPUTS_DESTINATION + File.separator + "generated/data_logs.ini", state)); + destinations.add(new DataLogConsumer(TS_OUTPUTS_DESTINATION + File.separator + "generated/data_logs.ini")); destinations.add(new GaugeConsumer(TS_OUTPUTS_DESTINATION + File.separator + "generated/gauges.ini", state)); } if (tsInputFileFolder != null) { diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/ConfigField.java b/java_tools/configuration_definition/src/main/java/com/rusefi/ConfigField.java index 9e8a740c03..bf2102cb0d 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/ConfigField.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/ConfigField.java @@ -46,6 +46,7 @@ public class ConfigField { private final boolean hasAutoscale; private final String trueName; private final String falseName; + private boolean isFromIterate; /** * todo: one day someone should convert this into a builder @@ -328,5 +329,13 @@ public class ConfigField { return token.substring(1, length - 1); return token; } + + public void isFromIterate(boolean isFromIterate) { + this.isFromIterate = isFromIterate; + } + + public boolean isFromIterate() { + return isFromIterate; + } } diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/ReaderState.java b/java_tools/configuration_definition/src/main/java/com/rusefi/ReaderState.java index 4825a058fe..adee6c9f84 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/ReaderState.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/ReaderState.java @@ -156,7 +156,7 @@ public class ReaderState { structures.put(structure.getName(), structure); for (ConfigurationConsumer consumer : consumers) - consumer.handleEndStruct(structure); + consumer.handleEndStruct(this, structure); } public void readBufferedReader(String inputString, List consumers) throws IOException { @@ -267,6 +267,7 @@ public class ReaderState { for (int i = 1; i <= cf.getArraySizes()[0]; i++) { ConfigField element = new ConfigField(state, cf.getName() + i, cf.getComment(), null, cf.getType(), new int[0], cf.getTsInfo(), false, false, false, null, null); + element.isFromIterate(true); structure.addTs(element); } } else if (cf.isDirective()) { diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/output/BaseCHeaderConsumer.java b/java_tools/configuration_definition/src/main/java/com/rusefi/output/BaseCHeaderConsumer.java index fb2d1a13e9..5f18f4bb7a 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/output/BaseCHeaderConsumer.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/output/BaseCHeaderConsumer.java @@ -39,7 +39,7 @@ public abstract class BaseCHeaderConsumer extends AbstractConfigurationConsumer } @Override - public void handleEndStruct(ConfigStructure structure) { + public void handleEndStruct(ReaderState readerState, ConfigStructure structure) { if (structure.comment != null) { content.append("/**" + EOL + ConfigDefinition.packComment(structure.comment, "") + EOL + "*/" + EOL); } diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/output/ConfigurationConsumer.java b/java_tools/configuration_definition/src/main/java/com/rusefi/output/ConfigurationConsumer.java index 8f5c66374d..eb27f19965 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/output/ConfigurationConsumer.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/output/ConfigurationConsumer.java @@ -1,5 +1,7 @@ package com.rusefi.output; +import com.rusefi.ReaderState; + import java.io.IOException; public interface ConfigurationConsumer { @@ -7,5 +9,5 @@ public interface ConfigurationConsumer { void endFile() throws IOException; - void handleEndStruct(ConfigStructure structure) throws IOException; + void handleEndStruct(ReaderState readerState, ConfigStructure structure) throws IOException; } diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/output/DataLogConsumer.java b/java_tools/configuration_definition/src/main/java/com/rusefi/output/DataLogConsumer.java index ac0f644128..585113a470 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/output/DataLogConsumer.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/output/DataLogConsumer.java @@ -18,19 +18,17 @@ import static org.abego.treelayout.internal.util.java.lang.string.StringUtil.quo public class DataLogConsumer extends AbstractConfigurationConsumer { public static final String UNUSED = "unused"; private final String fileName; - private final ReaderState state; private final CharArrayWriter tsWriter = new CharArrayWriter(); private final TreeSet comments = new TreeSet<>(String.CASE_INSENSITIVE_ORDER); - public DataLogConsumer(String fileName, ReaderState state) { + public DataLogConsumer(String fileName) { this.fileName = fileName; - this.state = state; } @Override - public void handleEndStruct(ConfigStructure structure) throws IOException { - if (state.stack.isEmpty()) { - PerFieldWithStructuresIterator iterator = new PerFieldWithStructuresIterator(structure.tsFields, "", + public void handleEndStruct(ReaderState readerState, ConfigStructure structure) throws IOException { + if (readerState.stack.isEmpty()) { + PerFieldWithStructuresIterator iterator = new PerFieldWithStructuresIterator(readerState, structure.tsFields, "", this::handle); iterator.loop(); String content = iterator.sb.toString(); @@ -48,7 +46,7 @@ public class DataLogConsumer extends AbstractConfigurationConsumer { } } - private String handle(ConfigField configField, String prefix) { + private String handle(ReaderState state, ConfigField configField, String prefix) { if (configField.getName().contains(UNUSED)) return ""; diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/output/GaugeConsumer.java b/java_tools/configuration_definition/src/main/java/com/rusefi/output/GaugeConsumer.java index ae1650cd0b..e2ff6cdbe2 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/output/GaugeConsumer.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/output/GaugeConsumer.java @@ -21,10 +21,10 @@ public class GaugeConsumer extends AbstractConfigurationConsumer { } @Override - public void handleEndStruct(ConfigStructure structure) throws IOException { + public void handleEndStruct(ReaderState readerState, ConfigStructure structure) throws IOException { if (state.stack.isEmpty()) { - PerFieldWithStructuresIterator iterator = new PerFieldWithStructuresIterator(structure.tsFields, "", - this::handle); + PerFieldWithStructuresIterator iterator = new PerFieldWithStructuresIterator(state, structure.tsFields, "", + (state, configField, prefix) -> handle(configField, prefix)); iterator.loop(); String content = iterator.sb.toString(); charArrayWriter.append(content); diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/output/GetConfigValueConsumer.java b/java_tools/configuration_definition/src/main/java/com/rusefi/output/GetConfigValueConsumer.java index 43a5331e46..a4b856298e 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/output/GetConfigValueConsumer.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/output/GetConfigValueConsumer.java @@ -1,6 +1,7 @@ package com.rusefi.output; import com.rusefi.ConfigField; +import com.rusefi.ReaderState; import org.jetbrains.annotations.Nullable; import java.io.FileWriter; @@ -28,18 +29,12 @@ public class GetConfigValueConsumer extends AbstractConfigurationConsumer { } @Override - public void handleEndStruct(ConfigStructure structure) throws IOException { - FieldIterator iterator = new FieldIterator(structure.cFields); - for (int i = 0; i < structure.cFields.size(); i++) { - iterator.start(i); - - - append(iterator.cf); - - - iterator.end(); + public void handleEndStruct(ReaderState state, ConfigStructure structure) throws IOException { + if (state.stack.isEmpty()) { + PerFieldWithStructuresIterator iterator = new PerFieldWithStructuresIterator(state, structure.tsFields, "", + this::process, "."); + iterator.loop(); } - } @Override @@ -55,12 +50,16 @@ public class GetConfigValueConsumer extends AbstractConfigurationConsumer { writeStringToFile(outputFIleName, content.toString()); } - private void append(ConfigField cf) { + private String process(ReaderState readerState, ConfigField cf, String prefix) { if (cf.getName().contains(UNUSED) || cf.getName().contains(ALIGNMENT_FILL_AT)) - return; + return ""; - content.append("\tif (strEqualCaseInsensitive(name, \"" + cf.getName() + "\"))\n"); - content.append("\t\treturn engineConfiguration->" + cf.getName() + ";\n"); + if (cf.isArray() || cf.isFromIterate()) + return ""; + + content.append("\tif (strEqualCaseInsensitive(name, \"" + prefix + cf.getName() + "\"))\n"); + content.append("\t\treturn engineConfiguration->" + prefix + cf.getName() + ";\n"); + return ""; } public String getContent() { diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/output/JavaFieldsConsumer.java b/java_tools/configuration_definition/src/main/java/com/rusefi/output/JavaFieldsConsumer.java index 6273653c74..239781dea3 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/output/JavaFieldsConsumer.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/output/JavaFieldsConsumer.java @@ -111,7 +111,7 @@ public abstract class JavaFieldsConsumer implements ConfigurationConsumer { return custom != null && custom.toLowerCase().startsWith(IniFileModel.FIELD_TYPE_STRING); } - public void handleEndStruct(ConfigStructure structure) throws IOException { + public void handleEndStruct(ReaderState readerState, ConfigStructure structure) throws IOException { if (state.stack.isEmpty()) { writeJavaFields(structure.tsFields, "", 0); } diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/output/OutputsSectionConsumer.java b/java_tools/configuration_definition/src/main/java/com/rusefi/output/OutputsSectionConsumer.java index f7ec3352fc..5db44fbc13 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/output/OutputsSectionConsumer.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/output/OutputsSectionConsumer.java @@ -21,7 +21,7 @@ public class OutputsSectionConsumer extends AbstractConfigurationConsumer { } @Override - public void handleEndStruct(ConfigStructure structure) throws IOException { + public void handleEndStruct(ReaderState readerState, ConfigStructure structure) throws IOException { System.out.println("handleEndStruct"); if (state.stack.isEmpty()) { diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/output/PerFieldWithStructuresIterator.java b/java_tools/configuration_definition/src/main/java/com/rusefi/output/PerFieldWithStructuresIterator.java index 88389887e9..b0217f58d8 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/output/PerFieldWithStructuresIterator.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/output/PerFieldWithStructuresIterator.java @@ -1,18 +1,27 @@ package com.rusefi.output; import com.rusefi.ConfigField; +import com.rusefi.ReaderState; import java.util.List; class PerFieldWithStructuresIterator extends FieldIterator { + private final ReaderState state; private final String prefix; private final Strategy strategy; + private final String prefixSeparator; StringBuilder sb = new StringBuilder(); - public PerFieldWithStructuresIterator(List fields, String prefix, Strategy strategy) { + public PerFieldWithStructuresIterator(ReaderState state, List fields, String prefix, Strategy strategy, String prefixSeparator) { super(fields); + this.state = state; this.prefix = prefix; this.strategy = strategy; + this.prefixSeparator = prefixSeparator; + } + + public PerFieldWithStructuresIterator(ReaderState state, List fields, String prefix, Strategy strategy) { + this(state, fields, prefix, strategy, "_"); } @Override @@ -20,18 +29,18 @@ class PerFieldWithStructuresIterator extends FieldIterator { ConfigStructure cs = cf.getState().structures.get(cf.getType()); String content; if (cs != null) { - String extraPrefix = cs.withPrefix ? cf.getName() + "_" : ""; - PerFieldWithStructuresIterator fieldIterator = new PerFieldWithStructuresIterator(cs.tsFields, extraPrefix, strategy); + String extraPrefix = cs.withPrefix ? cf.getName() + prefixSeparator : ""; + PerFieldWithStructuresIterator fieldIterator = new PerFieldWithStructuresIterator(state, cs.tsFields, extraPrefix, strategy); fieldIterator.loop(); content = fieldIterator.sb.toString(); } else { - content = strategy.process(cf, prefix); + content = strategy.process(state, cf, prefix); } sb.append(content); super.end(); } interface Strategy { - String process(ConfigField configField, String prefix); + String process(ReaderState state, ConfigField configField, String prefix); } } diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/output/SignatureConsumer.java b/java_tools/configuration_definition/src/main/java/com/rusefi/output/SignatureConsumer.java index ddff5adde3..252a34e537 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/output/SignatureConsumer.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/output/SignatureConsumer.java @@ -19,7 +19,7 @@ public class SignatureConsumer extends AbstractConfigurationConsumer { } @Override - public void handleEndStruct(ConfigStructure structure) throws IOException { + public void handleEndStruct(ReaderState readerState, ConfigStructure structure) throws IOException { ConfigDefinition.writeDefinesToFile(registry, destHeader); } } diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/output/TSProjectConsumer.java b/java_tools/configuration_definition/src/main/java/com/rusefi/output/TSProjectConsumer.java index 1b822be867..ebfec90aa9 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/output/TSProjectConsumer.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/output/TSProjectConsumer.java @@ -148,7 +148,7 @@ public class TSProjectConsumer implements ConfigurationConsumer { } @Override - public void handleEndStruct(ConfigStructure structure) throws IOException { + public void handleEndStruct(ReaderState readerState, ConfigStructure structure) throws IOException { state.variableRegistry.register(structure.name + "_size", structure.getTotalSize()); if (state.stack.isEmpty()) { totalTsSize = tsOutput.writeTunerStudio(structure, "", tsWriter, 0); diff --git a/java_tools/configuration_definition/src/main/java/com/rusefi/test/OutputsTest.java b/java_tools/configuration_definition/src/main/java/com/rusefi/test/OutputsTest.java index cb84e9467c..9f4a61c0ab 100644 --- a/java_tools/configuration_definition/src/main/java/com/rusefi/test/OutputsTest.java +++ b/java_tools/configuration_definition/src/main/java/com/rusefi/test/OutputsTest.java @@ -99,7 +99,7 @@ public class OutputsTest { state.variableRegistry.register("PACK_MULT_PERCENT", 100); state.variableRegistry.register("GAUGE_NAME_FUEL_BASE", "hello"); - DataLogConsumer dataLogConsumer = new DataLogConsumer(null, state); + DataLogConsumer dataLogConsumer = new DataLogConsumer(null); state.readBufferedReader(test, Collections.singletonList(dataLogConsumer)); assertEquals( "entry = issue_294_31, \"issue_294_31\", int, \"%d\"\n" + @@ -128,6 +128,7 @@ public class OutputsTest { "float resistance_2;;\"Ohm\", 1, 0, 0, 200000, 1\n" + "float resistance_3;;\"Ohm\", 1, 0, 0, 200000, 1\n" + "\n" + + "\tint[12 iterate] ignitionPins;\n" + "\tfloat bias_resistor;+Pull-up resistor value on your board;\"Ohm\", 1, 0, 0, 200000, 1\n" + "end_struct\n" + "struct ThermistorConf @brief Thermistor curve parameters\n" + @@ -171,18 +172,26 @@ public class OutputsTest { "\t\treturn engineConfiguration->resistance_3;\n" + "\tif (strEqualCaseInsensitive(name, \"bias_resistor\"))\n" + "\t\treturn engineConfiguration->bias_resistor;\n" + - "\tif (strEqualCaseInsensitive(name, \"config\"))\n" + - "\t\treturn engineConfiguration->config;\n" + - "\tif (strEqualCaseInsensitive(name, \"adcChannel\"))\n" + - "\t\treturn engineConfiguration->adcChannel;\n" + - "\tif (strEqualCaseInsensitive(name, \"clt\"))\n" + - "\t\treturn engineConfiguration->clt;\n" + - "\tif (strEqualCaseInsensitive(name, \"iat\"))\n" + - "\t\treturn engineConfiguration->iat;\n" + + "\tif (strEqualCaseInsensitive(name, \"clt.adcChannel\"))\n" + + "\t\treturn engineConfiguration->clt.adcChannel;\n" + + "\tif (strEqualCaseInsensitive(name, \"tempC_1\"))\n" + + "\t\treturn engineConfiguration->tempC_1;\n" + + "\tif (strEqualCaseInsensitive(name, \"tempC_2\"))\n" + + "\t\treturn engineConfiguration->tempC_2;\n" + + "\tif (strEqualCaseInsensitive(name, \"tempC_3\"))\n" + + "\t\treturn engineConfiguration->tempC_3;\n" + + "\tif (strEqualCaseInsensitive(name, \"resistance_1\"))\n" + + "\t\treturn engineConfiguration->resistance_1;\n" + + "\tif (strEqualCaseInsensitive(name, \"resistance_2\"))\n" + + "\t\treturn engineConfiguration->resistance_2;\n" + + "\tif (strEqualCaseInsensitive(name, \"resistance_3\"))\n" + + "\t\treturn engineConfiguration->resistance_3;\n" + + "\tif (strEqualCaseInsensitive(name, \"bias_resistor\"))\n" + + "\t\treturn engineConfiguration->bias_resistor;\n" + + "\tif (strEqualCaseInsensitive(name, \"iat.adcChannel\"))\n" + + "\t\treturn engineConfiguration->iat.adcChannel;\n" + "\tif (strEqualCaseInsensitive(name, \"issue_294_31\"))\n" + "\t\treturn engineConfiguration->issue_294_31;\n" + - "\tif (strEqualCaseInsensitive(name, \"knock\"))\n" + - "\t\treturn engineConfiguration->knock;\n" + "\tif (strEqualCaseInsensitive(name, \"baseFuel\"))\n" + "\t\treturn engineConfiguration->baseFuel;\n" + "\tif (strEqualCaseInsensitive(name, \"afr_type\"))\n" + @@ -214,7 +223,7 @@ public class OutputsTest { "end_struct\n"; ReaderState state = new ReaderState(); - DataLogConsumer dataLogConsumer = new DataLogConsumer(null, state); + DataLogConsumer dataLogConsumer = new DataLogConsumer(null); GaugeConsumer gaugeConsumer = new GaugeConsumer(null, state); state.readBufferedReader(test, Arrays.asList(dataLogConsumer, gaugeConsumer)); assertEquals(