logging of live data structs was: data points #3614
This commit is contained in:
parent
4f35c31c44
commit
d7e8d2179f
|
@ -132,7 +132,12 @@ public class SensorGauge {
|
||||||
//radial1.setTrackStop(to);
|
//radial1.setTrackStop(to);
|
||||||
|
|
||||||
radial1.setMinValue(minValue);
|
radial1.setMinValue(minValue);
|
||||||
radial1.setMaxValue(maxValue);
|
if (minValue == maxValue) {
|
||||||
|
// a bit of a hack to survive not great input data
|
||||||
|
radial1.setMaxValue(minValue + 10);
|
||||||
|
} else {
|
||||||
|
radial1.setMaxValue(maxValue);
|
||||||
|
}
|
||||||
radial1.setThresholdVisible(false);
|
radial1.setThresholdVisible(false);
|
||||||
radial1.setPointerColor(ColorDef.RED);
|
radial1.setPointerColor(ColorDef.RED);
|
||||||
|
|
||||||
|
|
Binary file not shown.
|
@ -3,6 +3,7 @@ package com.rusefi.ldmp;
|
||||||
import com.rusefi.ConfigDefinition;
|
import com.rusefi.ConfigDefinition;
|
||||||
import com.rusefi.ReaderState;
|
import com.rusefi.ReaderState;
|
||||||
import com.rusefi.output.JavaSensorsConsumer;
|
import com.rusefi.output.JavaSensorsConsumer;
|
||||||
|
import com.rusefi.util.SystemOut;
|
||||||
import org.yaml.snakeyaml.Yaml;
|
import org.yaml.snakeyaml.Yaml;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
@ -26,6 +27,8 @@ public class UsagesReader {
|
||||||
"#include \"pch.h\"\n" +
|
"#include \"pch.h\"\n" +
|
||||||
"#include \"tunerstudio.h\"\n");
|
"#include \"tunerstudio.h\"\n");
|
||||||
|
|
||||||
|
int sensorTsPosition = 0;
|
||||||
|
|
||||||
public static void main(String[] args) throws IOException {
|
public static void main(String[] args) throws IOException {
|
||||||
if (args.length != 1) {
|
if (args.length != 1) {
|
||||||
System.err.println("One parameter expected: name of live data yaml input file");
|
System.err.println("One parameter expected: name of live data yaml input file");
|
||||||
|
@ -37,8 +40,9 @@ public class UsagesReader {
|
||||||
|
|
||||||
StringBuilder totalSensors = new StringBuilder();
|
StringBuilder totalSensors = new StringBuilder();
|
||||||
|
|
||||||
|
UsagesReader usagesReader = new UsagesReader();
|
||||||
|
|
||||||
EntryHandler handler = new EntryHandler() {
|
EntryHandler handler = new EntryHandler() {
|
||||||
int sensorTsPosition = 0;
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onEntry(String name, List elements) throws IOException {
|
public void onEntry(String name, List elements) throws IOException {
|
||||||
|
@ -66,7 +70,7 @@ public class UsagesReader {
|
||||||
state.setDefinitionInputFile(folder + File.separator + name + ".txt");
|
state.setDefinitionInputFile(folder + File.separator + name + ".txt");
|
||||||
state.withC_Defines = withCDefines;
|
state.withC_Defines = withCDefines;
|
||||||
|
|
||||||
JavaSensorsConsumer javaSensorsConsumer = new JavaSensorsConsumer(state, sensorTsPosition);
|
JavaSensorsConsumer javaSensorsConsumer = new JavaSensorsConsumer(state, usagesReader.sensorTsPosition);
|
||||||
state.addDestination(javaSensorsConsumer);
|
state.addDestination(javaSensorsConsumer);
|
||||||
|
|
||||||
state.addPrepend(prepend);
|
state.addPrepend(prepend);
|
||||||
|
@ -74,15 +78,22 @@ public class UsagesReader {
|
||||||
state.addJavaDestination("../java_console/models/src/main/java/com/rusefi/config/generated/" + javaName);
|
state.addJavaDestination("../java_console/models/src/main/java/com/rusefi/config/generated/" + javaName);
|
||||||
state.doJob();
|
state.doJob();
|
||||||
|
|
||||||
sensorTsPosition = javaSensorsConsumer.sensorTsPosition;
|
usagesReader.sensorTsPosition = javaSensorsConsumer.sensorTsPosition;
|
||||||
totalSensors.append(javaSensorsConsumer.getContent());
|
totalSensors.append(javaSensorsConsumer.getContent());
|
||||||
|
|
||||||
|
SystemOut.println("TS_TOTAL_OUTPUT_SIZE=" + usagesReader.sensorTsPosition);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
UsagesReader usagesReader = new UsagesReader();
|
|
||||||
usagesReader.handleYaml(data, handler);
|
usagesReader.handleYaml(data, handler);
|
||||||
usagesReader.writeFiles();
|
usagesReader.writeFiles();
|
||||||
|
|
||||||
|
try (FileWriter fw = new FileWriter("console/binary/generated/total_live_data_generated.h")) {
|
||||||
|
fw.write(header);
|
||||||
|
fw.write("#define TS_TOTAL_OUTPUT_SIZE " + usagesReader.sensorTsPosition);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
try (FileWriter fw = new FileWriter("console/binary/generated/sensors.java")) {
|
try (FileWriter fw = new FileWriter("console/binary/generated/sensors.java")) {
|
||||||
fw.write(totalSensors.toString());
|
fw.write(totalSensors.toString());
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,7 +56,7 @@ public class JavaSensorsConsumer implements ConfigurationConsumer {
|
||||||
|
|
||||||
String string = state.variableRegistry.applyVariables(configField.getComment());
|
String string = state.variableRegistry.applyVariables(configField.getComment());
|
||||||
if (string == null) {
|
if (string == null) {
|
||||||
string = "\"\"";
|
string = quote(configField.getName());
|
||||||
} else if (string.isEmpty() || string.charAt(0) != '"') {
|
} else if (string.isEmpty() || string.charAt(0) != '"') {
|
||||||
// huh? weird conditional quoting?
|
// huh? weird conditional quoting?
|
||||||
string = quote(string);
|
string = quote(string);
|
||||||
|
|
|
@ -24,7 +24,7 @@ public class JavaSensorsConsumerTest {
|
||||||
"uint16_t autoscale RPMValue;@@GAUGE_NAME_RPM@@;\"RPM\",1, 0, 0, 8000, 0\n" +
|
"uint16_t autoscale RPMValue;@@GAUGE_NAME_RPM@@;\"RPM\",1, 0, 0, 8000, 0\n" +
|
||||||
"uint16_t rpmAcceleration;dRPM;\"RPM/s\",1, 0, 0, 5, 0\n" +
|
"uint16_t rpmAcceleration;dRPM;\"RPM/s\",1, 0, 0, 5, 0\n" +
|
||||||
"\tuint16_t autoscale speedToRpmRatio;@@GAUGE_NAME_GEAR_RATIO@@;\"value\",{1/@@PACK_MULT_PERCENT@@}, 0, 0, 0, 0\n" +
|
"\tuint16_t autoscale speedToRpmRatio;@@GAUGE_NAME_GEAR_RATIO@@;\"value\",{1/@@PACK_MULT_PERCENT@@}, 0, 0, 0, 0\n" +
|
||||||
"\tuint8_t autoscale vehicleSpeedKph;name2;\"kph\",1, 0, 0, 0, 0\n" +
|
"\tuint8_t vehicleSpeedKph\n" +
|
||||||
"\tint8_t autoscale internalMcuTemperature;mcu;\"deg C\",1, 0, 0, 0, 0\n" +
|
"\tint8_t autoscale internalMcuTemperature;mcu;\"deg C\",1, 0, 0, 0, 0\n" +
|
||||||
"end_struct\n";
|
"end_struct\n";
|
||||||
JavaSensorsConsumer javaSensorsConsumer = new JavaSensorsConsumer(state, 0);
|
JavaSensorsConsumer javaSensorsConsumer = new JavaSensorsConsumer(state, 0);
|
||||||
|
@ -33,7 +33,7 @@ public class JavaSensorsConsumerTest {
|
||||||
assertEquals("RPMValue(\"hello\", SensorCategory.SENSOR_INPUTS, FieldType.INT16, 4, 1.0, 0.0, 8000.0, \"RPM\"),\n" +
|
assertEquals("RPMValue(\"hello\", SensorCategory.SENSOR_INPUTS, FieldType.INT16, 4, 1.0, 0.0, 8000.0, \"RPM\"),\n" +
|
||||||
"rpmAcceleration(\"dRPM\", SensorCategory.SENSOR_INPUTS, FieldType.INT16, 6, 1.0, 0.0, 5.0, \"RPM/s\"),\n" +
|
"rpmAcceleration(\"dRPM\", SensorCategory.SENSOR_INPUTS, FieldType.INT16, 6, 1.0, 0.0, 5.0, \"RPM/s\"),\n" +
|
||||||
"speedToRpmRatio(\"ra\", SensorCategory.SENSOR_INPUTS, FieldType.INT16, 8, 0.01, 0.0, 0.0, \"value\"),\n" +
|
"speedToRpmRatio(\"ra\", SensorCategory.SENSOR_INPUTS, FieldType.INT16, 8, 0.01, 0.0, 0.0, \"value\"),\n" +
|
||||||
"vehicleSpeedKph(\"name2\", SensorCategory.SENSOR_INPUTS, FieldType.INT8, 10, 1.0, 0.0, 0.0, \"kph\"),\n" +
|
"vehicleSpeedKph(\"vehicleSpeedKph\", SensorCategory.SENSOR_INPUTS, FieldType.INT8, 10, 1.0, -1.0, -1.0, \"\"),\n" +
|
||||||
"internalMcuTemperature(\"mcu\", SensorCategory.SENSOR_INPUTS, FieldType.INT8, 11, 1.0, 0.0, 0.0, \"deg C\"),\n",
|
"internalMcuTemperature(\"mcu\", SensorCategory.SENSOR_INPUTS, FieldType.INT8, 11, 1.0, 0.0, 0.0, \"deg C\"),\n",
|
||||||
javaSensorsConsumer.getContent());
|
javaSensorsConsumer.getContent());
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue