X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fdevices%2Fhardwaredevice.cpp;h=953864d589429fb9fb1c20e05d106de5132f55f9;hp=4fa27f6dd7521e8b8a82433c9b5c940bc4bea435;hb=b961bf17ba19203193ab70598ca53312520af99d;hpb=da30ecb7e72bd2547e524258efa5ec642988b70b diff --git a/pv/devices/hardwaredevice.cpp b/pv/devices/hardwaredevice.cpp index 4fa27f6d..953864d5 100644 --- a/pv/devices/hardwaredevice.cpp +++ b/pv/devices/hardwaredevice.cpp @@ -18,34 +18,87 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ +#include + #include #include +#include + #include "hardwaredevice.hpp" +using std::dynamic_pointer_cast; using std::shared_ptr; using std::static_pointer_cast; +using std::string; +using std::vector; + +using boost::algorithm::join; + +using sigrok::HardwareDevice; namespace pv { namespace devices { HardwareDevice::HardwareDevice(const std::shared_ptr &context, std::shared_ptr device) : - context_(context) { + context_(context), + device_open_(false) { device_ = device; } HardwareDevice::~HardwareDevice() { - device_->close(); + if (device_open_) + device_->close(); + if (session_) session_->remove_devices(); } +string HardwareDevice::full_name() const { + vector parts = {device_->vendor(), device_->model(), + device_->version(), device_->serial_number()}; + if (device_->connection_id().length() > 0) + parts.push_back("(" + device_->connection_id() + ")"); + return join(parts, " "); +} + shared_ptr HardwareDevice::hardware_device() const { return static_pointer_cast(device_); } +string HardwareDevice::display_name( + const DeviceManager &device_manager) const { + const auto hw_dev = hardware_device(); + + // If we can find another device with the same model/vendor then + // we have at least two such devices and need to distinguish them. + const auto &devices = device_manager.devices(); + const bool multiple_dev = hw_dev && any_of( + devices.begin(), devices.end(), + [&](shared_ptr dev) { + return dev->hardware_device()->vendor() == + hw_dev->vendor() && + dev->hardware_device()->model() == + hw_dev->model() && + dev->device_ != device_; + }); + + vector parts = {device_->vendor(), device_->model()}; + + if (multiple_dev) { + parts.push_back(device_->version()); + parts.push_back(device_->serial_number()); + + if ((device_->serial_number().length() == 0) && + (device_->connection_id().length() > 0)) + parts.push_back("(" + device_->connection_id() + ")"); + } + + return join(parts, " "); +} + void HardwareDevice::create() { // Open the device try { @@ -54,6 +107,8 @@ void HardwareDevice::create() { throw QString(e.what()); } + device_open_ = true; + // Set up the session session_ = context_->create_session(); session_->add_device(device_);