projects
/
pulseview.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix #1089 by updating the signal labels and group labels
[pulseview.git]
/
pv
/
widgets
/
devicetoolbutton.cpp
diff --git
a/pv/widgets/devicetoolbutton.cpp
b/pv/widgets/devicetoolbutton.cpp
index 723542b9fd9d3c6f874e4494004ee1b64eb383f1..bb18b792788cd3592eba4b46ddcb967cd17e89a7 100644
(file)
--- a/
pv/widgets/devicetoolbutton.cpp
+++ b/
pv/widgets/devicetoolbutton.cpp
@@
-14,8
+14,7
@@
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ * along with this program; if not, see <http://www.gnu.org/licenses/>.
*/
#include <cassert>
*/
#include <cassert>
@@
-72,12
+71,19
@@
void DeviceToolButton::set_device_list(
const list< shared_ptr<Device> > &devices, shared_ptr<Device> selected)
{
selected_device_ = selected;
const list< shared_ptr<Device> > &devices, shared_ptr<Device> selected)
{
selected_device_ = selected;
- setText(QString::fromStdString(
- selected->display_name(device_manager_)));
+ setText(
selected ?
QString::fromStdString(
+ selected->display_name(device_manager_))
: tr("<No Device>")
);
devices_ = vector< weak_ptr<Device> >(devices.begin(), devices.end());
update_device_list();
}
devices_ = vector< weak_ptr<Device> >(devices.begin(), devices.end());
update_device_list();
}
+void DeviceToolButton::reset()
+{
+ setText(tr("<No Device>"));
+ selected_device_.reset();
+ update_device_list();
+}
+
void DeviceToolButton::update_device_list()
{
menu_.clear();
void DeviceToolButton::update_device_list()
{
menu_.clear();
@@
-86,7
+92,7
@@
void DeviceToolButton::update_device_list()
menu_.addSeparator();
for (weak_ptr<Device> dev_weak_ptr : devices_) {
menu_.addSeparator();
for (weak_ptr<Device> dev_weak_ptr : devices_) {
- shared_ptr<Device> dev(dev_weak_ptr);
+ shared_ptr<Device> dev(dev_weak_ptr
.lock()
);
if (!dev)
continue;
if (!dev)
continue;
@@
-108,6
+114,8
@@
void DeviceToolButton::on_action(QObject *action)
{
assert(action);
{
assert(action);
+ selected_device_.reset();
+
Device *const dev = (Device*)((QAction*)action)->data().value<void*>();
for (weak_ptr<Device> dev_weak_ptr : devices_) {
shared_ptr<Device> dev_ptr(dev_weak_ptr);
Device *const dev = (Device*)((QAction*)action)->data().value<void*>();
for (weak_ptr<Device> dev_weak_ptr : devices_) {
shared_ptr<Device> dev_ptr(dev_weak_ptr);
@@
-149,5
+157,5
@@
void DeviceToolButton::on_menu_hover_timeout()
QToolTip::showText(QCursor::pos(), device_tooltip_);
}
QToolTip::showText(QCursor::pos(), device_tooltip_);
}
-}
//
widgets
-}
//
pv
+}
// namespace
widgets
+}
// namespace
pv