mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
usb-serial-for-android: More fields in device descriptor
As discussed in issue #2657, there are now more fields about the usb device information in android_usb_serial_device_descriptor. Additionally, the user-facing string now makes more sense: "vendor [<bus# as integer>:<dev# as integer>]" Where vendor is as reported by android, but shortened to 16 characters. Examples: FTDI [1:2] Silicon Labs [1:4] Signed-off-by: Christof Arnosti <charno@charno.ch> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
344f7861b4
commit
ce7d4d1ca6
2 changed files with 88 additions and 14 deletions
|
@ -7,6 +7,7 @@
|
|||
#include <QAndroidJniObject>
|
||||
#include <QAndroidJniEnvironment>
|
||||
#include <QtAndroid>
|
||||
#include <QRegularExpression>
|
||||
|
||||
#include <thread>
|
||||
|
||||
|
@ -203,7 +204,56 @@ dc_status_t serial_usb_android_open(dc_iostream_t **iostream, dc_context_t *cont
|
|||
return dc_custom_open(iostream, context, DC_TRANSPORT_SERIAL, &callbacks, device);
|
||||
}
|
||||
|
||||
std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices(bool driverSelection)
|
||||
android_usb_serial_device_descriptor getDescriptor(QAndroidJniObject usbDevice)
|
||||
{
|
||||
QAndroidJniEnvironment env;
|
||||
|
||||
android_usb_serial_device_descriptor descriptor;
|
||||
|
||||
descriptor.usbDevice = usbDevice;
|
||||
descriptor.pid = usbDevice.callMethod<jint>("getProductId");
|
||||
descriptor.vid = usbDevice.callMethod<jint>("getVendorId");
|
||||
|
||||
// descriptor.manufacturer = UsbDevice.getManufacturerName();
|
||||
QAndroidJniObject usbManufacturerName = usbDevice.callObjectMethod<jstring>("getManufacturerName");
|
||||
if (usbManufacturerName.isValid()) {
|
||||
const char *charArray = env->GetStringUTFChars(usbManufacturerName.object<jstring>(), nullptr);
|
||||
descriptor.manufacturer = std::string(charArray);
|
||||
env->ReleaseStringUTFChars(usbManufacturerName.object<jstring>(), charArray);
|
||||
}
|
||||
|
||||
// descriptor.product = UsbDevice.getProductName();
|
||||
QAndroidJniObject usbProductName = usbDevice.callObjectMethod<jstring>("getProductName");
|
||||
if (usbManufacturerName.isValid()) {
|
||||
const char *charArray = env->GetStringUTFChars(usbProductName.object<jstring>(), nullptr);
|
||||
descriptor.product = std::string(charArray);
|
||||
env->ReleaseStringUTFChars(usbProductName.object<jstring>(), charArray);
|
||||
}
|
||||
|
||||
// Get busnum and portnum
|
||||
QAndroidJniObject usbDeviceNameString = usbDevice.callObjectMethod<jstring>("getDeviceName");
|
||||
const char *charArray = env->GetStringUTFChars(usbDeviceNameString.object<jstring>(), nullptr);
|
||||
QRegularExpression reg("/dev/bus/usb/(\\d*)/(\\d*)");
|
||||
QRegularExpressionMatch match = reg.match(charArray);
|
||||
int busnum = match.captured(1).toInt();
|
||||
int portnum = match.captured(2).toInt();
|
||||
env->ReleaseStringUTFChars(usbDeviceNameString.object<jstring>(), charArray);
|
||||
|
||||
// The ui representation
|
||||
char buffer[128];
|
||||
if (descriptor.manufacturer.empty()) {
|
||||
sprintf(buffer, "USB Device [%i:%i]", busnum, portnum);
|
||||
} else if (descriptor.manufacturer.size() <= 16) {
|
||||
sprintf(buffer, "%s [%i:%i]", descriptor.manufacturer.c_str(), busnum, portnum);
|
||||
} else {
|
||||
sprintf(buffer, "%.16s… [%i:%i]", descriptor.manufacturer.c_str(), busnum, portnum);
|
||||
}
|
||||
descriptor.uiRepresentation = buffer;
|
||||
|
||||
return descriptor;
|
||||
}
|
||||
|
||||
std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices(book driverSelection)
|
||||
{
|
||||
std::vector<std::string> driverNames;
|
||||
if (driverSelection)
|
||||
|
@ -230,7 +280,10 @@ std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices
|
|||
// UsbDevice usbDevice = arrayOfDevices[0]
|
||||
jobject value = env->GetObjectArrayElement(arrayOfDevices.object<jobjectArray>(), 0);
|
||||
QAndroidJniObject usbDevice(value);
|
||||
return std::vector<android_usb_serial_device_descriptor> { {QAndroidJniObject(usbDevice), "", "USB Connection"} };
|
||||
android_usb_serial_device_descriptor descriptor = getDescriptor(usbDevice);
|
||||
descriptor.uiRepresentation = "USB Connection";
|
||||
|
||||
return {descriptor};
|
||||
} else {
|
||||
std::vector<android_usb_serial_device_descriptor> retval;
|
||||
for (int i = 0; i < numDevices ; i++) {
|
||||
|
@ -238,21 +291,15 @@ std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices
|
|||
jobject value = env->GetObjectArrayElement(arrayOfDevices.object<jobjectArray>(), i);
|
||||
QAndroidJniObject usbDevice(value);
|
||||
|
||||
// std::string deviceName = usbDevice.getDeviceName()
|
||||
QAndroidJniObject usbDeviceNameString = usbDevice.callObjectMethod<jstring>("getDeviceName");
|
||||
const char *charArray = env->GetStringUTFChars(usbDeviceNameString.object<jstring>(), nullptr);
|
||||
std::string deviceName(charArray);
|
||||
env->ReleaseStringUTFChars(usbDeviceNameString.object<jstring>(), charArray);
|
||||
|
||||
// TODO the deviceName should probably be something better... Currently it's the /dev-filename.
|
||||
|
||||
for (std::string driverName : driverNames) {
|
||||
std::string uiDeviceName;
|
||||
android_usb_serial_device_descriptor descriptor = getDescriptor(usbDevice);
|
||||
|
||||
descriptor.className = driverName;
|
||||
if (driverName != "")
|
||||
uiDeviceName = deviceName + " (" + driverName + ")";
|
||||
descriptor.uiRepresentation += " (" + driverName + ")";
|
||||
else
|
||||
uiDeviceName = deviceName + " (autoselect driver)";
|
||||
retval.push_back({QAndroidJniObject(usbDevice), driverName, uiDeviceName});
|
||||
descriptor.uiRepresentation += " (autoselect driver)";
|
||||
retval.push_back(descriptor);
|
||||
}
|
||||
}
|
||||
return retval;
|
||||
|
@ -265,6 +312,27 @@ std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices
|
|||
*/
|
||||
dc_status_t serial_usb_android_open(dc_iostream_t **iostream, dc_context_t *context)
|
||||
{
|
||||
// Testing of the method only!
|
||||
{
|
||||
TRACE(device->contxt, "List of devices with specific drivers:");
|
||||
std::vector<android_usb_serial_device_descriptor> devices = serial_usb_android_get_devices(true);
|
||||
for (auto device : devices) {
|
||||
TRACE(device->contxt,
|
||||
"USB Device: uiRepresentation=%s, className=%s, manufacturer=%s, product=%s, pid=%i, vid=%i",
|
||||
device.uiRepresentation.c_str(), device.className.c_str(), device.manufacturer.c_str(),
|
||||
device.product.c_str(), device.pid, device.vid);
|
||||
}
|
||||
|
||||
TRACE(device->contxt, "List of devices simple:");
|
||||
devices = serial_usb_android_get_devices(false);
|
||||
for (auto device : devices) {
|
||||
TRACE(device->contxt,
|
||||
"USB Device: uiRepresentation=%s, className=%s, manufacturer=%s, product=%s, pid=%i, vid=%i",
|
||||
device.uiRepresentation.c_str(), device.className.c_str(), device.manufacturer.c_str(),
|
||||
device.product.c_str(), device.pid, device.vid);
|
||||
}
|
||||
}
|
||||
|
||||
std::vector<android_usb_serial_device_descriptor> devices = serial_usb_android_get_devices(false);
|
||||
|
||||
if(devices.empty())
|
||||
|
|
|
@ -9,6 +9,12 @@ struct android_usb_serial_device_descriptor {
|
|||
QAndroidJniObject usbDevice; /* the UsbDevice */
|
||||
std::string className; /* the driver class name. If empty, then "autodetect" */
|
||||
std::string uiRepresentation; /* The string that can be used for the user interface. */
|
||||
|
||||
// Device information
|
||||
std::string manufacturer;
|
||||
std::string product;
|
||||
uint16_t pid;
|
||||
uint16_t vid;
|
||||
};
|
||||
|
||||
std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices(bool driverSelection);
|
||||
|
|
Loading…
Add table
Reference in a new issue