]> sigrok.org Git - pulseview.git/blame - pv/prop/int.cpp
Session: Don't process packets without sample data
[pulseview.git] / pv / prop / int.cpp
CommitLineData
a2b92157
JH
1/*
2 * This file is part of the PulseView project.
3 *
4 * Copyright (C) 2013 Joel Holdsworth <joel@airwebreathe.org.uk>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
efdec55a 17 * along with this program; if not, see <http://www.gnu.org/licenses/>.
a2b92157
JH
18 */
19
eb8269e3 20#include <cassert>
aca9aa83 21#include <cstdint>
a2b92157
JH
22
23#include <QSpinBox>
24
2acdb232 25#include "int.hpp"
a2b92157 26
819f4c25
JH
27using boost::optional;
28using std::max;
29using std::min;
30using std::pair;
a2b92157
JH
31
32namespace pv {
33namespace prop {
34
35Int::Int(QString name,
9a267f8d 36 QString desc,
a2b92157
JH
37 QString suffix,
38 optional< pair<int64_t, int64_t> > range,
39 Getter getter,
40 Setter setter) :
9a267f8d 41 Property(name, desc, getter, setter),
8dbbc7f0
JH
42 suffix_(suffix),
43 range_(range),
4c60462b 44 spin_box_(nullptr)
a2b92157
JH
45{
46}
47
b1fe148e 48QWidget* Int::get_widget(QWidget *parent, bool auto_commit)
a2b92157 49{
765e7d33
SA
50 int64_t int_val = 0, range_min = 0;
51 uint64_t range_max = 0;
ac223c1e 52
8dbbc7f0
JH
53 if (spin_box_)
54 return spin_box_;
a2b92157 55
8dbbc7f0 56 if (!getter_)
4c60462b 57 return nullptr;
e8d00928 58
8dbbc7f0 59 value_ = getter_();
ac223c1e 60
8dbbc7f0 61 GVariant *value = value_.gobj();
e8d00928 62 if (!value)
4c60462b 63 return nullptr;
ac223c1e 64
8dbbc7f0
JH
65 spin_box_ = new QSpinBox(parent);
66 spin_box_->setSuffix(suffix_);
ac223c1e 67
e8d00928 68 const GVariantType *const type = g_variant_get_type(value);
ac223c1e
JH
69 assert(type);
70
2ad82c2e 71 if (g_variant_type_equal(type, G_VARIANT_TYPE_BYTE)) {
e8d00928 72 int_val = g_variant_get_byte(value);
ac223c1e 73 range_min = 0, range_max = UINT8_MAX;
2ad82c2e 74 } else if (g_variant_type_equal(type, G_VARIANT_TYPE_INT16)) {
e8d00928 75 int_val = g_variant_get_int16(value);
ac223c1e 76 range_min = INT16_MIN, range_max = INT16_MAX;
2ad82c2e 77 } else if (g_variant_type_equal(type, G_VARIANT_TYPE_UINT16)) {
e8d00928 78 int_val = g_variant_get_uint16(value);
ac223c1e 79 range_min = 0, range_max = UINT16_MAX;
2ad82c2e 80 } else if (g_variant_type_equal(type, G_VARIANT_TYPE_INT32)) {
e8d00928 81 int_val = g_variant_get_int32(value);
ac223c1e 82 range_min = INT32_MIN, range_max = INT32_MAX;
2ad82c2e 83 } else if (g_variant_type_equal(type, G_VARIANT_TYPE_UINT32)) {
e8d00928 84 int_val = g_variant_get_uint32(value);
ac223c1e 85 range_min = 0, range_max = UINT32_MAX;
2ad82c2e 86 } else if (g_variant_type_equal(type, G_VARIANT_TYPE_INT64)) {
e8d00928 87 int_val = g_variant_get_int64(value);
ac223c1e 88 range_min = INT64_MIN, range_max = INT64_MAX;
2ad82c2e 89 } else if (g_variant_type_equal(type, G_VARIANT_TYPE_UINT64)) {
e8d00928 90 int_val = g_variant_get_uint64(value);
ac223c1e 91 range_min = 0, range_max = UINT64_MAX;
2ad82c2e 92 } else {
ac223c1e 93 // Unexpected value type.
0402d7a3 94 assert(false);
ac223c1e
JH
95 }
96
b0e15aa2 97 // @todo sigrok supports 64-bit quantities, but Qt does not have a
ac223c1e
JH
98 // standard widget to allow the values to be modified over the full
99 // 64-bit range on 32-bit machines. To solve the issue we need a
100 // custom widget.
101
102 range_min = max(range_min, (int64_t)INT_MIN);
765e7d33 103 range_max = min(range_max, (uint64_t)INT_MAX);
ac223c1e 104
8dbbc7f0
JH
105 if (range_)
106 spin_box_->setRange((int)range_->first, (int)range_->second);
a915c6a3 107 else
8dbbc7f0 108 spin_box_->setRange((int)range_min, (int)range_max);
a2b92157 109
8dbbc7f0 110 spin_box_->setValue((int)int_val);
a2b92157 111
b1fe148e 112 if (auto_commit)
8dbbc7f0 113 connect(spin_box_, SIGNAL(valueChanged(int)),
b1fe148e
JH
114 this, SLOT(on_value_changed(int)));
115
8dbbc7f0 116 return spin_box_;
a2b92157
JH
117}
118
119void Int::commit()
120{
8dbbc7f0 121 assert(setter_);
a2b92157 122
8dbbc7f0 123 if (!spin_box_)
a2b92157
JH
124 return;
125
4c60462b 126 GVariant *new_value = nullptr;
8dbbc7f0 127 const GVariantType *const type = g_variant_get_type(value_.gobj());
ac223c1e
JH
128 assert(type);
129
130 if (g_variant_type_equal(type, G_VARIANT_TYPE_BYTE))
8dbbc7f0 131 new_value = g_variant_new_byte(spin_box_->value());
ac223c1e 132 else if (g_variant_type_equal(type, G_VARIANT_TYPE_INT16))
8dbbc7f0 133 new_value = g_variant_new_int16(spin_box_->value());
ac223c1e 134 else if (g_variant_type_equal(type, G_VARIANT_TYPE_UINT16))
8dbbc7f0 135 new_value = g_variant_new_uint16(spin_box_->value());
ac223c1e 136 else if (g_variant_type_equal(type, G_VARIANT_TYPE_INT32))
8dbbc7f0 137 new_value = g_variant_new_int32(spin_box_->value());
ac223c1e 138 else if (g_variant_type_equal(type, G_VARIANT_TYPE_UINT32))
79118fe5 139 new_value = g_variant_new_uint32(spin_box_->value());
ac223c1e 140 else if (g_variant_type_equal(type, G_VARIANT_TYPE_INT64))
8dbbc7f0 141 new_value = g_variant_new_int64(spin_box_->value());
ac223c1e 142 else if (g_variant_type_equal(type, G_VARIANT_TYPE_UINT64))
8dbbc7f0 143 new_value = g_variant_new_uint64(spin_box_->value());
c063290a 144 else {
ac223c1e 145 // Unexpected value type.
0402d7a3 146 assert(false);
ac223c1e
JH
147 }
148
149 assert(new_value);
150
8dbbc7f0 151 value_ = Glib::VariantBase(new_value);
ac223c1e 152
8dbbc7f0 153 setter_(value_);
a2b92157
JH
154}
155
b1fe148e
JH
156void Int::on_value_changed(int)
157{
158 commit();
159}
160
870ea3db
UH
161} // namespace prop
162} // namespace pv