* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ * along with this program; if not, see <http://www.gnu.org/licenses/>.
*/
-#include "row.h"
+#include "decoder.hpp"
+#include "row.hpp"
#include <libsigrokdecode/libsigrokdecode.h>
namespace decode {
Row::Row() :
- decoder_(NULL),
- row_(NULL)
+ decoder_(nullptr),
+ row_(nullptr)
{
}
-Row::Row(const srd_decoder *decoder, const srd_decoder_annotation_row *row) :
+Row::Row(int index, const Decoder* decoder, const srd_decoder_annotation_row* row) :
+ index_(index),
decoder_(decoder),
row_(row)
{
}
-const srd_decoder* Row::decoder() const
+const Decoder* Row::decoder() const
{
return decoder_;
}
-const srd_decoder_annotation_row* Row::row() const
+const srd_decoder_annotation_row* Row::srd_row() const
{
return row_;
}
const QString Row::title() const
{
- if (decoder_ && decoder_->name && row_ && row_->desc)
+ if (decoder_ && decoder_->name() && row_ && row_->desc)
return QString("%1: %2")
- .arg(QString::fromUtf8(decoder_->name))
- .arg(QString::fromUtf8(row_->desc));
- if (decoder_ && decoder_->name)
- return QString::fromUtf8(decoder_->name);
+ .arg(QString::fromUtf8(decoder_->name()),
+ QString::fromUtf8(row_->desc));
+ if (decoder_ && decoder_->name())
+ return QString::fromUtf8(decoder_->name());
if (row_ && row_->desc)
return QString::fromUtf8(row_->desc);
return QString();
}
-bool Row::operator<(const Row &other) const
+const QString Row::class_name() const
+{
+ if (row_ && row_->desc)
+ return QString::fromUtf8(row_->desc);
+ return QString();
+}
+
+int Row::index() const
+{
+ return index_;
+}
+
+bool Row::operator<(const Row& other) const
{
return (decoder_ < other.decoder_) ||
(decoder_ == other.decoder_ && row_ < other.row_);
}
-} // decode
-} // data
-} // pv
+bool Row::operator==(const Row& other) const
+{
+ return ((decoder_ == other.decoder()) && (row_ == other.srd_row()));
+}
+
+} // namespace decode
+} // namespace data
+} // namespace pv