From ab0ea90b5589c013ba4a99a978661aff8914e2ec Mon Sep 17 00:00:00 2001 From: "T. van der Zwan" Date: Tue, 7 Jan 2014 13:20:53 +0000 Subject: [PATCH] Fixed the open of device until device is available Former-commit-id: b8700368fadb53784c5838ab046431a7f58f108c --- libsrc/leddevice/LedDevicePiBlaster.cpp | 38 +++++++++++++++++++++++-- libsrc/leddevice/LedDevicePiBlaster.h | 2 +- 2 files changed, 36 insertions(+), 4 deletions(-) diff --git a/libsrc/leddevice/LedDevicePiBlaster.cpp b/libsrc/leddevice/LedDevicePiBlaster.cpp index d494ca0b..6bdcf726 100644 --- a/libsrc/leddevice/LedDevicePiBlaster.cpp +++ b/libsrc/leddevice/LedDevicePiBlaster.cpp @@ -3,6 +3,9 @@ #include #include +// QT includes +#include + // Local LedDevice includes #include "LedDevicePiBlaster.h" @@ -24,22 +27,39 @@ LedDevicePiBlaster::~LedDevicePiBlaster() } } -int LedDevicePiBlaster::open() +int LedDevicePiBlaster::open(bool report) { if (_fid != nullptr) { // The file pointer is already open - std::cerr << "Attempt to open allready opened device (" << _deviceName << ")" << std::endl; + if (report) + { + std::cerr << "Attempt to open allready opened device (" << _deviceName << ")" << std::endl; + } + return -1; + } + + if (!QFile::exists(_deviceName.c_str())) + { + if (report) + { + std::cerr << "The device(" << _deviceName << ") does not yet exist, can not connect (yet)." << std::endl; + } return -1; } _fid = fopen(_deviceName.c_str(), "w"); if (_fid == nullptr) { - std::cerr << "Failed to open device (" << _deviceName << "). Error message: " << strerror(errno) << std::endl; + if (report) + { + std::cerr << "Failed to open device (" << _deviceName << "). Error message: " << strerror(errno) << std::endl; + } return -1; } + std::cout << "Connect to device(" << _deviceName << ")" << std::endl; + return 0; } @@ -54,6 +74,12 @@ int LedDevicePiBlaster::open() // 7 25 P1-22 int LedDevicePiBlaster::write(const std::vector & ledValues) { + // Attempt to open if not yet opened + if (_fid == nullptr && open(false) < 0) + { + return -1; + } + unsigned colorIdx = 0; for (unsigned iChannel=0; iChannel<8; ++iChannel) { @@ -85,6 +111,12 @@ int LedDevicePiBlaster::write(const std::vector & ledValues) int LedDevicePiBlaster::switchOff() { + // Attempt to open if not yet opened + if (_fid == nullptr && open(false) < 0) + { + return -1; + } + for (unsigned iChannel=0; iChannel<8; ++iChannel) { if (_channelAssignment[iChannel] != ' ') diff --git a/libsrc/leddevice/LedDevicePiBlaster.h b/libsrc/leddevice/LedDevicePiBlaster.h index 4a0be50c..94869788 100644 --- a/libsrc/leddevice/LedDevicePiBlaster.h +++ b/libsrc/leddevice/LedDevicePiBlaster.h @@ -20,7 +20,7 @@ public: virtual ~LedDevicePiBlaster(); - int open(); + int open(bool report = true); /// /// Writes the colors to the PiBlaster device