Move J2534 library lookup and check from ConnectionManagerFactory

This commit is contained in:
Dale Schultz 2022-02-15 20:03:55 -05:00
parent dd6a974009
commit 5a0a4a9d64
No known key found for this signature in database
GPG Key ID: EA2C8AD6CB5C2AF2
2 changed files with 51 additions and 13 deletions

View File

@ -1,6 +1,6 @@
DISCONNECTED = Disconnected DISCONNECTED = Disconnected
SENDINIT = Sending {0} Init ... SENDINIT = Sending {0} Init: {1} ...
INITDONE = Sending {0} Init ... done INITDONE = Sending {0} Init: {1} ... done
INITFAIL = Unable to send {0} init - check cable is connected and ignition is on INITFAIL = Unable to send {0} init - check cable is connected and ignition is on
SELECTPARAMS = Select parameters to be logged ... SELECTPARAMS = Select parameters to be logged ...
QUERYING = Querying {0} ... QUERYING = Querying {0} ...

View File

@ -22,6 +22,7 @@ package com.romraider.logger.ecu.comms.manager;
import static com.romraider.logger.ecu.comms.io.connection.LoggerConnectionFactory.getConnection; import static com.romraider.logger.ecu.comms.io.connection.LoggerConnectionFactory.getConnection;
import static com.romraider.logger.ecu.definition.EcuDataType.EXTERNAL; import static com.romraider.logger.ecu.definition.EcuDataType.EXTERNAL;
import static com.romraider.util.ParamChecker.checkNotNull; import static com.romraider.util.ParamChecker.checkNotNull;
import static com.romraider.util.ParamChecker.isNullOrEmpty;
import static com.romraider.util.ThreadUtil.sleep; import static com.romraider.util.ThreadUtil.sleep;
import static java.lang.System.currentTimeMillis; import static java.lang.System.currentTimeMillis;
import static java.util.Collections.synchronizedList; import static java.util.Collections.synchronizedList;
@ -34,12 +35,15 @@ import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.ResourceBundle; import java.util.ResourceBundle;
import java.util.Set;
import javax.swing.SwingUtilities; import javax.swing.SwingUtilities;
import org.apache.log4j.Logger; import org.apache.log4j.Logger;
import com.romraider.Settings; import com.romraider.Settings;
import com.romraider.io.j2534.api.J2534Library;
import com.romraider.io.j2534.api.J2534LibraryLocator;
import com.romraider.logger.ecu.comms.io.connection.LoggerConnection; import com.romraider.logger.ecu.comms.io.connection.LoggerConnection;
import com.romraider.logger.ecu.comms.query.EcuInitCallback; import com.romraider.logger.ecu.comms.query.EcuInitCallback;
import com.romraider.logger.ecu.comms.query.EcuQuery; import com.romraider.logger.ecu.comms.query.EcuQuery;
@ -192,24 +196,58 @@ public final class QueryManagerImpl implements QueryManager {
} }
private boolean doEcuInit(Module module) { private boolean doEcuInit(Module module) {
final Set<J2534Library> libraries = J2534LibraryLocator.getLibraries(
settings.getTransportProtocol().toUpperCase());
if (isNullOrEmpty(settings.getJ2534Device())) {
// No previous J2534 library selected in settings
for (J2534Library dll : libraries) {
LOGGER.info(String.format("Trying new J2534/%s connection: %s",
settings.getTransportProtocol(),
dll.getVendor()));
settings.setJ2534Device(dll.getLibrary());
if (initConnection(module, dll.getVendor())) {
return true;
}
}
}
else {
// Try previous J2534 library from settings
LOGGER.info(String.format(
"Trying previous J2534/%s connection: %s",
settings.getTransportProtocol(),
settings.getJ2534Device()));
if (initConnection(module, settings.getJ2534Device())) {
return true;
}
}
settings.setJ2534Device("");
// Finally try Serial
if (initConnection(module, settings.getLoggerPort())) {
return true;
}
return false;
}
private boolean initConnection(final Module module, final String name) {
LoggerConnection connection = null; LoggerConnection connection = null;
boolean rv = false; boolean rv = false;
try { try {
connection = messageListener.reportMessage(MessageFormat.format(
getConnection(settings.getLoggerProtocol(), rb.getString("SENDINIT"), module.getName(), name));
settings.getLoggerPort(), connection = getConnection(settings.getLoggerProtocol(),
settings.getLoggerConnectionProperties()); settings.getLoggerPort(),
messageListener.reportMessage(MessageFormat.format( settings.getLoggerConnectionProperties());
rb.getString("SENDINIT"), module.getName())); connection.ecuInit(ecuInitCallback, module);
connection.ecuInit(ecuInitCallback, module); messageListener.reportMessage(MessageFormat.format(
messageListener.reportMessage(MessageFormat.format( rb.getString("INITDONE"), module.getName(), name));
rb.getString("INITDONE"), module.getName())); rv = true;
rv = true;
} catch (Exception e) { } catch (Exception e) {
messageListener.reportMessage(MessageFormat.format( messageListener.reportMessage(MessageFormat.format(
rb.getString("INITFAIL"), module.getName())); rb.getString("INITFAIL"), module.getName()));
LOGGER.error("Error sending init: " + e.getMessage()); LOGGER.error("Error sending init: " + e.getMessage());
settings.setJ2534Device("");
} }
finally { finally {
if (connection != null) connection.close(); if (connection != null) connection.close();