pv::data::DecoderStack: Set _row for each annotation.
authorUwe Hermann <uwe@hermann-uwe.de>
Fri, 31 Jan 2014 20:24:18 +0000 (21:24 +0100)
committerUwe Hermann <uwe@hermann-uwe.de>
Sat, 1 Feb 2014 14:08:05 +0000 (15:08 +0100)
For each annotation, keep track of the "annotation row" it belongs to.

pv/data/decoderstack.cpp

index f08e349240571cabf18f64259ca205daaef8bcb1..d209e1a9b19e1f783f46baa0b8b9bb5a9320dd65 100644 (file)
@@ -241,13 +241,35 @@ void DecoderStack::annotation_callback(srd_proto_data *pdata, void *decoder)
 {
        using pv::data::decode::Annotation;
 
+       GSList *l, *ll;
+       int row, ann_class;
+       struct srd_decoder_annotation_row *ann_row;
+
        assert(pdata);
        assert(decoder);
 
        DecoderStack *const d = (DecoderStack*)decoder;
 
        lock_guard<mutex> lock(d->_mutex);
-       d->_annotations.push_back(Annotation(pdata));
+
+       Annotation a = Annotation(pdata);
+
+       const shared_ptr<decode::Decoder> &dec = *d->stack().begin();
+
+       for (l = dec->decoder()->annotation_rows, row = 0; l;
+                       l = l->next, row++)
+       {
+               ann_row = (struct srd_decoder_annotation_row *)l->data;
+
+               for (ll = ann_row->ann_classes, ann_class = 0; ll;
+                                       ll = ll->next, ann_class++)
+               {
+                       if (GPOINTER_TO_INT(ll->data) == a.format())
+                               a.set_row(row);
+               }
+       }
+
+       d->_annotations.push_back(a);
 
        d->new_decode_data();
 }