projects
/
pulseview.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Moved form generation into Binding
[pulseview.git]
/
pv
/
data
/
decoder.h
diff --git
a/pv/data/decoder.h
b/pv/data/decoder.h
index dcf12fe1d4b5d2b8c6696442682bc9f5217ea2e6..4cae427ea95813e842be6aaa25fb93641ee0de1d 100644
(file)
--- a/
pv/data/decoder.h
+++ b/
pv/data/decoder.h
@@
-28,6
+28,8
@@
#include <boost/shared_ptr.hpp>
#include <boost/thread.hpp>
#include <boost/shared_ptr.hpp>
#include <boost/thread.hpp>
+#include <QObject>
+
struct srd_decoder;
struct srd_decoder_inst;
struct srd_probe;
struct srd_decoder;
struct srd_decoder_inst;
struct srd_probe;
@@
-36,14
+38,26
@@
namespace pv {
namespace view {
class Signal;
namespace view {
class Signal;
+
+namespace decode {
+class Annotation;
+}
+
}
namespace data {
class Logic;
}
namespace data {
class Logic;
-class Decoder : public SignalData
+class Decoder : public
QObject, public
SignalData
{
{
+ Q_OBJECT
+
+private:
+ static const double DecodeMargin;
+ static const double DecodeThreshold;
+ static const int64_t DecodeChunkLength;
+
public:
Decoder(const srd_decoder *const decoder,
std::map<const srd_probe*,
public:
Decoder(const srd_decoder *const decoder,
std::map<const srd_probe*,
@@
-53,15
+67,21
@@
public:
const srd_decoder* get_decoder() const;
const srd_decoder* get_decoder() const;
- void begin_decode();
+ const std::vector< boost::shared_ptr<pv::view::decode::Annotation> >
+ annotations() const;
void clear_snapshots();
private:
void clear_snapshots();
private:
+ void begin_decode();
+
void init_decoder();
void decode_proc(boost::shared_ptr<data::Logic> data);
void init_decoder();
void decode_proc(boost::shared_ptr<data::Logic> data);
+ static void annotation_callback(srd_proto_data *pdata,
+ void *decoder);
+
private:
const srd_decoder *const _decoder;
std::map<const srd_probe*, boost::shared_ptr<view::Signal> >
private:
const srd_decoder *const _decoder;
std::map<const srd_probe*, boost::shared_ptr<view::Signal> >
@@
-69,6
+89,10
@@
private:
srd_decoder_inst *_decoder_inst;
srd_decoder_inst *_decoder_inst;
+ mutable boost::mutex _annotations_mutex;
+ std::vector< boost::shared_ptr<pv::view::decode::Annotation> >
+ _annotations;
+
boost::thread _decode_thread;
};
boost::thread _decode_thread;
};