#include <libsigrokcxx/libsigrokcxx.hpp>
+#include "segment.hpp"
+
using std::atomic;
using std::condition_variable;
using std::map;
class DecoderStack;
class Logic;
class LogicSegment;
+class Segment;
class SignalData;
class SignalBase : public QObject
public:
/**
* Returns the underlying SR channel.
+ * Generated channels don't have a SR channel.
*/
shared_ptr<sigrok::Channel> channel() const;
*/
unsigned int index() const;
+ /**
+ * Sets the index number of this channel, i.e. a unique ID assigned by
+ * the device driver or the logic bit index (see below).
+ * Only use immediately after creating the signal and leave it untouched after.
+ */
+ void set_index(unsigned int index);
+
/**
* Returns which bit of a given sample for this signal represents the
* signal itself. This is relevant for compound signals like logic,
QString name() const;
/**
- * Gets the internal name of this signal, i.e. how the device calls it.
+ * Gets the internal name of this signal, i.e. how the device/generator calls it.
*/
QString internal_name() const;
+ /**
+ * Sets the internal name of this signal, i.e. how the device/generator calls it.
+ * Only use immediately after creating the signal and leave it untouched after.
+ */
+ void set_internal_name(QString internal_name);
+
/**
* Produces a string for this signal that can be used for display,
* i.e. it contains one or both of the signal/internal names.
private Q_SLOTS:
void on_samples_cleared();
- void on_samples_added(QObject* segment, uint64_t start_sample,
+ void on_samples_added(SharedPtrToSegment segment, uint64_t start_sample,
uint64_t end_sample);
void on_min_max_changed(float min, float max);
QString internal_name_, name_;
QColor color_, bgcolor_;
+ unsigned int index_;
};
} // namespace data