#include <cassert>
#include <vector>
-#include "annotation.hpp"
+#include <pv/data/decode/annotation.hpp>
+#include <pv/data/decode/decoder.hpp>
using std::vector;
namespace data {
namespace decode {
-Annotation::Annotation(const srd_proto_data *const pdata) :
+Annotation::Annotation(const srd_proto_data *const pdata, const Row *row) :
start_sample_(pdata->start_sample),
- end_sample_(pdata->end_sample)
+ end_sample_(pdata->end_sample),
+ row_(row)
{
assert(pdata);
const srd_proto_data_annotation *const pda =
(const srd_proto_data_annotation*)pdata->data;
assert(pda);
- format_ = pda->ann_class;
+ ann_class_id_ = (Class)(pda->ann_class);
+
+ annotations_ = new vector<QString>();
const char *const *annotations = (char**)pda->ann_text;
while (*annotations) {
- annotations_.push_back(QString::fromUtf8(*annotations));
+ annotations_->push_back(QString::fromUtf8(*annotations));
annotations++;
}
+
+ annotations_->shrink_to_fit();
+}
+
+Annotation::Annotation(Annotation&& a) :
+ start_sample_(a.start_sample_),
+ end_sample_(a.end_sample_),
+ annotations_(a.annotations_),
+ row_(a.row_),
+ ann_class_id_(a.ann_class_id_)
+{
+ a.annotations_ = nullptr;
+}
+
+Annotation& Annotation::operator=(Annotation&& a)
+{
+ if (&a != this) {
+ if (annotations_)
+ delete annotations_;
+
+ start_sample_ = a.start_sample_;
+ end_sample_ = a.end_sample_;
+ annotations_ = a.annotations_;
+ row_ = a.row_;
+ ann_class_id_ = a.ann_class_id_;
+
+ a.annotations_ = nullptr;
+ }
+
+ return *this;
+}
+
+Annotation::~Annotation()
+{
+ if (annotations_)
+ delete annotations_;
}
uint64_t Annotation::start_sample() const
return end_sample_;
}
-int Annotation::format() const
+Annotation::Class Annotation::ann_class_id() const
+{
+ return ann_class_id_;
+}
+
+const QString Annotation::ann_class_name() const
{
- return format_;
+ const AnnotationClass* ann_class =
+ row_->decoder()->get_ann_class_by_id(ann_class_id_);
+
+ return QString(ann_class->name);
}
-const vector<QString>& Annotation::annotations() const
+const vector<QString>* Annotation::annotations() const
{
return annotations_;
}
+const Row* Annotation::row() const
+{
+ return row_;
+}
+
+bool Annotation::operator<(const Annotation &other) const
+{
+ return (start_sample_ < other.start_sample_);
+}
+
} // namespace decode
} // namespace data
} // namespace pv