From 25b5e4943c2611a02cba5d717a6a3aa212505add Mon Sep 17 00:00:00 2001 From: rusefi Date: Mon, 3 Apr 2017 21:09:04 -0400 Subject: [PATCH 1/4] #382 improvements to generator to support simple string constants --- java_tools/ConfigDefinition.jar | Bin 32357 -> 32879 bytes .../src/com/rusefi/ConfigField.java | 3 ++- .../src/com/rusefi/VariableRegistry.java | 17 ++++++++++++++++- 3 files changed, 18 insertions(+), 2 deletions(-) diff --git a/java_tools/ConfigDefinition.jar b/java_tools/ConfigDefinition.jar index 7ce6969b9295f69d6e42aed5a325d68ac2ecef2f..22711af658c71546d48b5538053558e1325cae0c 100644 GIT binary patch delta 11147 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 Kk^22R%6|cGT704a diff --git a/java_tools/configuration_definition/src/com/rusefi/ConfigField.java b/java_tools/configuration_definition/src/com/rusefi/ConfigField.java index b728253c54..bc4c7ea050 100644 --- a/java_tools/configuration_definition/src/com/rusefi/ConfigField.java +++ b/java_tools/configuration_definition/src/com/rusefi/ConfigField.java @@ -29,6 +29,7 @@ public class ConfigField { public static final int LENGTH = 24; private static final char TS_COMMENT_TAG = '+'; + public static final String ENUM_SUFFIX = "_enum"; /** * field name without structure name @@ -224,7 +225,7 @@ public class ConfigField { writeJavaFieldName(javaFieldsWriter, nameWithPrefix, tsPosition); javaFieldsWriter.write("FieldType.FLOAT);" + EOL); } else { - String enumOptions = VariableRegistry.INSTANCE.get(type + "_enum"); + String enumOptions = VariableRegistry.INSTANCE.get(type + ENUM_SUFFIX); if (enumOptions != null && !javaEnums.contains(type)) { javaEnums.add(type); diff --git a/java_tools/configuration_definition/src/com/rusefi/VariableRegistry.java b/java_tools/configuration_definition/src/com/rusefi/VariableRegistry.java index c942271799..fd711748a2 100644 --- a/java_tools/configuration_definition/src/com/rusefi/VariableRegistry.java +++ b/java_tools/configuration_definition/src/com/rusefi/VariableRegistry.java @@ -24,6 +24,7 @@ public class VariableRegistry extends TreeMap { private final StringBuilder cAllDefinitions = new StringBuilder("//\n// generated by ConfigDefinition.jar tool based on rusefi_config.txt\n//\n\n"); private final StringBuilder javaNumbericDefinitions = new StringBuilder(); + private final StringBuilder javaStringDefinitions = new StringBuilder(); private VariableRegistry() { super(String.CASE_INSENSITIVE_ORDER); @@ -64,9 +65,23 @@ public class VariableRegistry extends TreeMap { javaNumbericDefinitions.append("\tpublic static final int " + var + " = " + intValue + ";" + EOL); } catch (NumberFormatException e) { System.out.println("Not an integer: " + value); + + if (isQuoted(value) && !var.trim().endsWith(ConfigField.ENUM_SUFFIX)) { + // quoted and not with enum suffix means plain string define statement + javaStringDefinitions.append("\tpublic static final String " + var + " = " + value + ";" + EOL); + } } } + private boolean isQuoted(String value) { + if (value == null) + return false; + value = value.trim(); + if (value.isEmpty()) + return false; + return value.charAt(0) == '"' && value.charAt(value.length() - 1) == '"'; + } + public void register(String var, int i) { register(var, Integer.toString(i)); register(var + "_hex", Integer.toString(i, 16)); @@ -82,6 +97,6 @@ public class VariableRegistry extends TreeMap { } public String getJavaConstants() { - return javaNumbericDefinitions.toString(); + return javaNumbericDefinitions.toString() + javaStringDefinitions.toString(); } } From 724f99aa75a52e623957daee03cd7ba622223c53 Mon Sep 17 00:00:00 2001 From: rusefi Date: Mon, 3 Apr 2017 21:12:21 -0400 Subject: [PATCH 2/4] #382 using constants in TS project --- .../algo/engine_configuration_generated_structures.h | 4 ++-- firmware/tunerstudio/rusefi.ini | 10 +++++----- firmware/tunerstudio/rusefi.input | 8 ++++---- java_console/models/src/com/rusefi/config/Fields.java | 6 +++++- 4 files changed, 16 insertions(+), 12 deletions(-) diff --git a/firmware/controllers/algo/engine_configuration_generated_structures.h b/firmware/controllers/algo/engine_configuration_generated_structures.h index 1e995df446..8cede97fd6 100644 --- a/firmware/controllers/algo/engine_configuration_generated_structures.h +++ b/firmware/controllers/algo/engine_configuration_generated_structures.h @@ -1,4 +1,4 @@ -// this section was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Mar 27 22:26:05 EDT 2017 +// this section was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Apr 03 21:10:42 EDT 2017 // begin #ifndef ENGINE_CONFIGURATION_GENERATED_H_ #define ENGINE_CONFIGURATION_GENERATED_H_ @@ -2057,4 +2057,4 @@ typedef struct { #endif // end -// this section was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Mar 27 22:26:05 EDT 2017 +// this section was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Apr 03 21:10:42 EDT 2017 diff --git a/firmware/tunerstudio/rusefi.ini b/firmware/tunerstudio/rusefi.ini index 126f9cc599..ef22156ebf 100644 --- a/firmware/tunerstudio/rusefi.ini +++ b/firmware/tunerstudio/rusefi.ini @@ -44,7 +44,7 @@ enable2ndByteCanID = false ; see PAGE_0_SIZE in C source code ; CONFIG_DEFINITION_START -; this section was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Mar 27 22:26:05 EDT 2017 +; this section was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Apr 03 21:10:42 EDT 2017 pageSize = 16376 page = 1 @@ -1320,14 +1320,14 @@ fileVersion = { 20161225 } entry = baseFuel, "fuel: base", float, "%.2f" entry = fuelPidCorrection,"fuel: pid", float, "%.2f" entry = veValue, "fuel: VE", float, "%.3f" - entry = injectorDutyCycle,"fuel: duty cyc",float,"%.3f" - entry = coilDutyCycle, "dwell: duty", float,"%.3f" + entry = injectorDutyCycle,"fuel: injector duty cycle",float,"%.3f" + entry = coilDutyCycle, "dwell: coil duty cycle", float,"%.3f" - entry = engineLoadAccelExtra, "fuel: load extra",float, "%.3f" + entry = engineLoadAccelExtra, "fuel: engine load acceleration extra fuel",float, "%.3f" entry = engineLoadDelta, "fuel: load change",float, "%.3f" entry = deltaTps, "fuel: TPS change",float, "%.3f" - entry = tpsAccelFuel, "fuel: TOS enrich", float, "%.3f" + entry = tpsAccelFuel, "fuel: TPS acceleration extra fuel", float, "%.3f" entry = wallFuelCorrection,"fuel: wall corr ms", float, "%.3f" entry = wallFuelAmount, "fuel: wall amount", float, "%.3f" diff --git a/firmware/tunerstudio/rusefi.input b/firmware/tunerstudio/rusefi.input index d42f3206d2..f11afc63ca 100644 --- a/firmware/tunerstudio/rusefi.input +++ b/firmware/tunerstudio/rusefi.input @@ -591,14 +591,14 @@ fileVersion = { 20161225 } entry = baseFuel, "fuel: base", float, "%.2f" entry = fuelPidCorrection,"fuel: pid", float, "%.2f" entry = veValue, "fuel: VE", float, "%.3f" - entry = injectorDutyCycle,"fuel: duty cyc",float,"%.3f" - entry = coilDutyCycle, "dwell: duty", float,"%.3f" + entry = injectorDutyCycle,@@GAUGE_NAME_FUEL_INJ_DUTY@@,float,"%.3f" + entry = coilDutyCycle, @@GAUGE_NAME_DWELL_DUTY@@, float,"%.3f" - entry = engineLoadAccelExtra, "fuel: load extra",float, "%.3f" + entry = engineLoadAccelExtra, @@GAUGE_NAME_FUEL_EL_EXTRA@@,float, "%.3f" entry = engineLoadDelta, "fuel: load change",float, "%.3f" entry = deltaTps, "fuel: TPS change",float, "%.3f" - entry = tpsAccelFuel, "fuel: TOS enrich", float, "%.3f" + entry = tpsAccelFuel, @@GAUGE_NAME_FUEL_TPS_EXTRA@@, float, "%.3f" entry = wallFuelCorrection,"fuel: wall corr ms", float, "%.3f" entry = wallFuelAmount, "fuel: wall amount", float, "%.3f" diff --git a/java_console/models/src/com/rusefi/config/Fields.java b/java_console/models/src/com/rusefi/config/Fields.java index 6ce4dc4e63..128269d0ae 100644 --- a/java_console/models/src/com/rusefi/config/Fields.java +++ b/java_console/models/src/com/rusefi/config/Fields.java @@ -1,6 +1,6 @@ package com.rusefi.config; -// this file was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Mar 27 22:26:05 EDT 2017 +// this file was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Apr 03 21:10:42 EDT 2017 public class Fields { public static final int LE_COMMAND_LENGTH = 200; public static final int FSIO_ADC_COUNT = 4; @@ -1026,6 +1026,10 @@ public class Fields { public static final int fsioTable4LoadBins_offset = 16312; public static final int fsioTable4RpmBins_offset = 16344; public static final int TOTAL_CONFIG_SIZE = 16376; + public static final String GAUGE_NAME_FUEL_TPS_EXTRA = "fuel: TPS acceleration extra fuel"; + public static final String GAUGE_NAME_FUEL_EL_EXTRA = "fuel: engine load acceleration extra fuel"; + public static final String GAUGE_NAME_FUEL_INJ_DUTY = "fuel: injector duty cycle"; + public static final String GAUGE_NAME_DWELL_DUTY = "dwell: coil duty cycle"; public static final Field ENGINETYPE = Field.create("ENGINETYPE", 0, FieldType.INT); public static final Field ENGINESNIFFERRPMTHRESHOLD = Field.create("ENGINESNIFFERRPMTHRESHOLD", 4, FieldType.INT); public static final Field INJECTOR_FLOW = Field.create("INJECTOR_FLOW", 8, FieldType.FLOAT); From 7a55c9b54aff0f73ebb7fe4022ef632a202752d8 Mon Sep 17 00:00:00 2001 From: rusefi Date: Mon, 3 Apr 2017 21:19:11 -0400 Subject: [PATCH 3/4] #382 using constants in java console --- .../models/src/com/rusefi/core/Sensor.java | 27 ++++++++++++++----- 1 file changed, 20 insertions(+), 7 deletions(-) diff --git a/java_console/models/src/com/rusefi/core/Sensor.java b/java_console/models/src/com/rusefi/core/Sensor.java index 2d639081ac..17d926e303 100644 --- a/java_console/models/src/com/rusefi/core/Sensor.java +++ b/java_console/models/src/com/rusefi/core/Sensor.java @@ -1,6 +1,7 @@ package com.rusefi.core; import com.rusefi.config.FieldType; +import com.rusefi.config.Fields; import eu.hansolo.steelseries.tools.BackgroundColor; import java.util.ArrayList; @@ -104,8 +105,8 @@ public enum Sensor { deltaTps(SensorCategory.FUEL, FieldType.FLOAT, 116, BackgroundColor.MUD), engineLoadAccelDelta(SensorCategory.FUEL, FieldType.FLOAT, 124, BackgroundColor.MUD), - tpsAccelFuel(SensorCategory.FUEL, FieldType.FLOAT, 128, BackgroundColor.MUD), - injectorDutyCycle(SensorCategory.OPERATIONS, FieldType.FLOAT, 140, BackgroundColor.MUD), + tpsAccelFuel(Fields.GAUGE_NAME_FUEL_TPS_EXTRA, SensorCategory.FUEL, FieldType.FLOAT, 128, BackgroundColor.MUD), + injectorDutyCycle(Fields.GAUGE_NAME_FUEL_INJ_DUTY, SensorCategory.OPERATIONS, FieldType.FLOAT, 140, BackgroundColor.MUD), wallFuelAmount(SensorCategory.FUEL, FieldType.FLOAT, 160, BackgroundColor.MUD), iatCorrection(SensorCategory.FUEL, FieldType.FLOAT, 164, BackgroundColor.MUD, 0, 5), wallFuelCorrection(SensorCategory.FUEL, FieldType.FLOAT, 168, BackgroundColor.MUD), @@ -136,7 +137,7 @@ public enum Sensor { debugFloatField6(SensorCategory.OPERATIONS, FieldType.FLOAT, 256, BackgroundColor.MUD, 0, 5), debugFloatField7(SensorCategory.OPERATIONS, FieldType.FLOAT, 260, BackgroundColor.MUD, 0, 5), - coilDutyCycle(SensorCategory.OPERATIONS, FieldType.FLOAT, 272, BackgroundColor.MUD), + coilDutyCycle(Fields.GAUGE_NAME_DWELL_DUTY, SensorCategory.OPERATIONS, FieldType.FLOAT, 272, BackgroundColor.MUD), INJ_1_2_DELTA("inj 1-2 delta", SensorCategory.SNIFFING), INJ_3_4_DELTA("inj 3-4 delta", SensorCategory.SNIFFING), @@ -151,8 +152,8 @@ public enum Sensor { private final FieldType type; private final int offset; - Sensor(SensorCategory category, FieldType type, int offset, BackgroundColor color, double minValue, double maxValue, String units) { - name = name(); + Sensor(String name, SensorCategory category, FieldType type, int offset, BackgroundColor color, double minValue, double maxValue, String units) { + this.name = name == null ? name() : name; this.type = type; this.offset = offset; this.category = category; @@ -162,12 +163,24 @@ public enum Sensor { this.maxValue = maxValue; } + Sensor(SensorCategory category, FieldType type, int offset, BackgroundColor color, double minValue, double maxValue, String units) { + this(null, category, type, offset, color, minValue, maxValue, units); + } + + Sensor(String name, SensorCategory category, FieldType type, int offset, BackgroundColor color, double minValue, double maxValue) { + this(name, category, type, offset, color, minValue, maxValue, "n/a"); + } + Sensor(SensorCategory category, FieldType type, int offset, BackgroundColor color, double minValue, double maxValue) { - this(category, type, offset, color, minValue, maxValue, "n/a"); + this(null, category, type, offset, color, minValue, maxValue); } Sensor(SensorCategory category, FieldType type, int offset, BackgroundColor color) { - this(category, type, offset, color, 0, 100); + this(null, category, type, offset, color); + } + + Sensor(String name, SensorCategory category, FieldType type, int offset, BackgroundColor color) { + this(name, category, type, offset, color, 0, 100); } Sensor(String name, SensorCategory category) { From 94ed4f25b8e0dc5ebeec899d71230bb5edb0f3e7 Mon Sep 17 00:00:00 2001 From: rusefi Date: Mon, 3 Apr 2017 21:27:38 -0400 Subject: [PATCH 4/4] #382 example how to convert one field to use constant --- firmware/controllers/algo/rusefi_generated.h | 1 + firmware/integration/rusefi_config.txt | 4 +++- firmware/tunerstudio/rusefi.ini | 4 ++-- firmware/tunerstudio/rusefi.input | 2 +- java_console/models/src/com/rusefi/config/Fields.java | 3 ++- java_console/models/src/com/rusefi/core/Sensor.java | 2 +- 6 files changed, 10 insertions(+), 6 deletions(-) diff --git a/firmware/controllers/algo/rusefi_generated.h b/firmware/controllers/algo/rusefi_generated.h index 861b70f0e5..b4becedc0a 100644 --- a/firmware/controllers/algo/rusefi_generated.h +++ b/firmware/controllers/algo/rusefi_generated.h @@ -1495,3 +1495,4 @@ #define GAUGE_NAME_FUEL_EL_EXTRA "fuel: engine load acceleration extra fuel" #define GAUGE_NAME_FUEL_INJ_DUTY "fuel: injector duty cycle" #define GAUGE_NAME_DWELL_DUTY "dwell: coil duty cycle" +#define GAUGE_COIL_DWELL_TIME "dwell: coil charge time" diff --git a/firmware/integration/rusefi_config.txt b/firmware/integration/rusefi_config.txt index 8021afe7ce..a8379a957b 100644 --- a/firmware/integration/rusefi_config.txt +++ b/firmware/integration/rusefi_config.txt @@ -870,4 +870,6 @@ end_struct #define GAUGE_NAME_FUEL_INJ_DUTY "fuel: injector duty cycle" -#define GAUGE_NAME_DWELL_DUTY "dwell: coil duty cycle" \ No newline at end of file +#define GAUGE_NAME_DWELL_DUTY "dwell: coil duty cycle" + +#define GAUGE_COIL_DWELL_TIME "dwell: coil charge time" diff --git a/firmware/tunerstudio/rusefi.ini b/firmware/tunerstudio/rusefi.ini index ef22156ebf..b30272fba8 100644 --- a/firmware/tunerstudio/rusefi.ini +++ b/firmware/tunerstudio/rusefi.ini @@ -44,7 +44,7 @@ enable2ndByteCanID = false ; see PAGE_0_SIZE in C source code ; CONFIG_DEFINITION_START -; this section was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Apr 03 21:10:42 EDT 2017 +; this section was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Apr 03 21:25:16 EDT 2017 pageSize = 16376 page = 1 @@ -1336,7 +1336,7 @@ fileVersion = { 20161225 } entry = iatCorrection, "fuel: IAT corr", float, "%.3f" entry = cltCorrection, "cltCorrection", float,"%.3f" - entry = sparkDwellValue, "dwell", float,"%.3f" + entry = sparkDwellValue, "dwell: coil charge time", float,"%.3f" entry = vvtPosition, "VVT", float,"%.2f" ; is there a way to log parameter? entry = debugMode, "debugMode",int,"%d" diff --git a/firmware/tunerstudio/rusefi.input b/firmware/tunerstudio/rusefi.input index f11afc63ca..87e299b760 100644 --- a/firmware/tunerstudio/rusefi.input +++ b/firmware/tunerstudio/rusefi.input @@ -607,7 +607,7 @@ fileVersion = { 20161225 } entry = iatCorrection, "fuel: IAT corr", float, "%.3f" entry = cltCorrection, "cltCorrection", float,"%.3f" - entry = sparkDwellValue, "dwell", float,"%.3f" + entry = sparkDwellValue, @@GAUGE_COIL_DWELL_TIME@@, float,"%.3f" entry = vvtPosition, "VVT", float,"%.2f" ; is there a way to log parameter? entry = debugMode, "debugMode",int,"%d" diff --git a/java_console/models/src/com/rusefi/config/Fields.java b/java_console/models/src/com/rusefi/config/Fields.java index 128269d0ae..fd0feff94c 100644 --- a/java_console/models/src/com/rusefi/config/Fields.java +++ b/java_console/models/src/com/rusefi/config/Fields.java @@ -1,6 +1,6 @@ package com.rusefi.config; -// this file was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Apr 03 21:10:42 EDT 2017 +// this file was generated automatically by ConfigDefinition.jar based on rusefi_config.txt Mon Apr 03 21:25:16 EDT 2017 public class Fields { public static final int LE_COMMAND_LENGTH = 200; public static final int FSIO_ADC_COUNT = 4; @@ -1030,6 +1030,7 @@ public class Fields { public static final String GAUGE_NAME_FUEL_EL_EXTRA = "fuel: engine load acceleration extra fuel"; public static final String GAUGE_NAME_FUEL_INJ_DUTY = "fuel: injector duty cycle"; public static final String GAUGE_NAME_DWELL_DUTY = "dwell: coil duty cycle"; + public static final String GAUGE_COIL_DWELL_TIME = "dwell: coil charge time"; public static final Field ENGINETYPE = Field.create("ENGINETYPE", 0, FieldType.INT); public static final Field ENGINESNIFFERRPMTHRESHOLD = Field.create("ENGINESNIFFERRPMTHRESHOLD", 4, FieldType.INT); public static final Field INJECTOR_FLOW = Field.create("INJECTOR_FLOW", 8, FieldType.FLOAT); diff --git a/java_console/models/src/com/rusefi/core/Sensor.java b/java_console/models/src/com/rusefi/core/Sensor.java index 17d926e303..c67c0568d0 100644 --- a/java_console/models/src/com/rusefi/core/Sensor.java +++ b/java_console/models/src/com/rusefi/core/Sensor.java @@ -96,7 +96,7 @@ public enum Sensor { T_CHARGE(SensorCategory.FUEL, FieldType.FLOAT, 52, BackgroundColor.MUD, 30, 140), // todo: unify with TIMING ignitionAdvance(SensorCategory.OPERATIONS, FieldType.FLOAT, 56, BackgroundColor.MUD, 30, 140), - DWELL(SensorCategory.OPERATIONS, FieldType.FLOAT, 60, BackgroundColor.MUD, 1, 10), + DWELL(Fields.GAUGE_COIL_DWELL_TIME, SensorCategory.OPERATIONS, FieldType.FLOAT, 60, BackgroundColor.MUD, 1, 10), actualLastInjection(SensorCategory.FUEL, FieldType.FLOAT, 64, BackgroundColor.MUD, 0, 30, "ms"), debugFloatField1(SensorCategory.OPERATIONS, FieldType.FLOAT, 68, BackgroundColor.MUD, 0, 5), VSS(SensorCategory.OPERATIONS, FieldType.FLOAT, 76, BackgroundColor.BLUE),