ConfigDefinition stuff (#2940)

* add check for empty string

* try catching duplicates, while allowing same id on a pin

* js brain

* fixes

* fixes

* comment out

* build

* bump submo

* comment
This commit is contained in:
David Holdeman 2021-07-09 21:07:07 -05:00 committed by GitHub
parent 64ea4aabac
commit 5582518a04
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 26 additions and 17 deletions

Binary file not shown.

View File

@ -411,6 +411,7 @@ public class ConfigDefinition {
SystemOut.println(data);
Objects.requireNonNull(data, "data");
for (Map<String, Object> pin : data) {
ArrayList<Map<String, Object>> thisPinList = new ArrayList<>();
Object pinId = pin.get("id");
Object pinClass = pin.get("class");
Object pinName = pin.get("ts_name");
@ -423,22 +424,36 @@ public class ConfigDefinition {
throw new IllegalStateException("Expected multiple classes for " + pinIds);
for (int i = 0; i < pinIds.size(); i++) {
String id = pinIds.get(i);
addPinToList(listPins, thisPinList, id, pinName, ((ArrayList<String>) pinClass).get(i));
}
} else if (pinId instanceof String) {
if (((String) pinId).length() == 0) {
throw new IllegalStateException("Unexpected empty ID field");
}
addPinToList(listPins, thisPinList, pinId, pinName, pinClass);
} else {
throw new IllegalStateException("Unexpected type of ID field: " + pinId.getClass().getSimpleName());
}
listPins.addAll(thisPinList);
}
}
private static void addPinToList(ArrayList<Map<String, Object>> listPins, ArrayList<Map<String, Object>> thisPinList, Object id, Object pinName, Object pinClass) {
/*
This doesn't work as expected because it's possible that a board has multiple connector pins connected to the same MCU pin.
https://github.com/rusefi/rusefi/issues/2897
https://github.com/rusefi/rusefi/issues/2925
for (int i = 0; i < listPins.size(); i++) {
if (id.equals(listPins.get(i).get("id"))) {
throw new IllegalStateException("ID used multiple times: " + id);
}
}
*/
Map<String, Object> thisPin = new HashMap<>();
thisPin.put("id", id);
thisPin.put("ts_name", pinName);
thisPin.put("class", ((ArrayList<String>) pinClass).get(i));
listPins.add(thisPin);
}
} else if (pinId instanceof String) {
Map<String, Object> thisPin = new HashMap<>();
thisPin.put("id", pinId);
thisPin.put("ts_name", pinName);
thisPin.put("class", pinClass);
listPins.add(thisPin);
} else {
throw new IllegalStateException("Unexpected type of id field: " + pinId.getClass().getSimpleName());
}
}
thisPinList.add(thisPin);
}
private static void registerPins(ArrayList<Map<String, Object>> listPins, VariableRegistry registry, ReaderState state) {
@ -452,12 +467,6 @@ public class ConfigDefinition {
names.put("switch_inputs", new ArrayList<>());
for (int i = 0; i < listPins.size(); i++) {
String id = (String) listPins.get(i).get("id");
for (int ii = i + 1; ii < listPins.size(); ii++) {
if (id.equals(listPins.get(ii).get("id"))) {
// todo: re-enable once we fix https://github.com/rusefi/rusefi/issues/2897
//throw new IllegalStateException("ID used multiple times: " + id);
}
}
String className = (String) listPins.get(i).get("class");
ArrayList<String> classList = names.get(className);
if (classList == null) {