Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for the SeratoMarkers_ GEOB tag (Hotcues/Loops/Track Color) #2495

Merged
merged 48 commits into from
Feb 16, 2020
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
b8d84c7
track/serato/markers2: Move Serato Markers2 code into serato directory
Holzhaus Feb 8, 2020
5a2c9ac
track/serato/markers2: Apply clang-format formatting fixes
Holzhaus Feb 8, 2020
054ec17
track/serato/markers: Add parser for "Serato Markers_" tag
Holzhaus Feb 8, 2020
ed9bb38
tests/serato: Move Serato test data into data directory
Holzhaus Feb 9, 2020
5147df7
tests: Add tests for "Serato Markers_" parser
Holzhaus Feb 9, 2020
b8e4ad8
track/trackinfo: Add support for reading "Serato Markers_" tags
Holzhaus Feb 9, 2020
2d65a58
track/serato/markers: Improve QDebug operator<< support
Holzhaus Feb 9, 2020
86902ab
track/serato/markers: Add comment documenting the color format
Holzhaus Feb 10, 2020
ad886ff
track/serato/markers_: Remove unused allocatedSize code
Holzhaus Feb 10, 2020
42491e4
track/serato/markers2: Use one initialization per line
Holzhaus Feb 10, 2020
f4bd9ff
track/serato/markers: Use one initialization per line
Holzhaus Feb 10, 2020
0205ed3
track/serato/markers: Return SeratoMarkersEntryPointer in parse()
Holzhaus Feb 10, 2020
96ab998
track/serato/markers: Use SeratoMarkersEntryPointer for QList
Holzhaus Feb 10, 2020
0ee2787
track/serato/markers: Replace usage of QByteArray::mid() with QDataSt…
Holzhaus Feb 11, 2020
af1f284
track/serato/markers: Improve position parsing and update tests
Holzhaus Feb 11, 2020
56a25fc
tests/seratomarkerstest: Reorder lines to reflect actual byte order
Holzhaus Feb 11, 2020
e63387d
track/serato/markers: Remove obsolete QStringLiteral #include
Holzhaus Feb 11, 2020
f65abf8
track/serato/markers: Use QDataStream also in SeratoMarkers::parse()
Holzhaus Feb 11, 2020
273201f
track/serato/markers: Make sure that QDataStreams were not read past end
Holzhaus Feb 11, 2020
5b327da
Merge branch 'master' of github.com:mixxxdj/mixxx into serato-markers_
Holzhaus Feb 11, 2020
4716b9e
test/seratomarkerstest: Fix formatting and use const references
Holzhaus Feb 11, 2020
035ffa7
track/serato/markers: Use std::move for setEntries()
Holzhaus Feb 11, 2020
ed4aa7d
track/serato/markers2: Break initialization line for unknown entries
Holzhaus Feb 11, 2020
e78de7f
track/serato/markers2: Rename ::data() to ::dump()
Holzhaus Feb 11, 2020
a6e233e
track/serato/markers: Rename ::data() to ::dump()
Holzhaus Feb 11, 2020
b76dc45
track/serato/markers: Rename color* functions to seratoColor*
Holzhaus Feb 11, 2020
46f9549
track/serato/markers2: Use one initialization per line
Holzhaus Feb 12, 2020
51fad8e
track/serato/markers: Add separate bools to determine if position is set
Holzhaus Feb 12, 2020
7274cdb
track/trackmetadatataglib: Add missing write call for "Serato Markers_"
Holzhaus Feb 12, 2020
998bfea
test/seratomarkerstest: Fix tests and add checks for `has<x>Position()`
Holzhaus Feb 12, 2020
849ee75
track/serato/markers: Add check that end of stream is reached
Holzhaus Feb 12, 2020
39ad2a9
track/serato/markers: Rename trackColor to more fitting trackColorMask
Holzhaus Feb 12, 2020
05f9e32
track/serato/markers2: Use QRgb instead of QColor for colors
Holzhaus Feb 12, 2020
b9706ff
track/serato/markers: Add TypeId enum class
Holzhaus Feb 12, 2020
bcc3aa6
track/serato/markers2: Add TypeId enum ordered by entry occurrence
Holzhaus Jan 30, 2020
e5ff804
track/serato/markers: Map type 0 to Cue (for unset cues)
Holzhaus Feb 12, 2020
be24da2
track/serato/markers: Check number of entries and types
Holzhaus Feb 12, 2020
e5b2511
track/serato: Use trackColor naming instead of trackColorMask
Holzhaus Feb 13, 2020
1faeb9d
Merge branch 'master' of github.com:mixxxdj/mixxx into serato-markers_
Holzhaus Feb 13, 2020
4e957b6
track/serato/markers2: Use RgbColor instead of plain QRgb
Holzhaus Feb 15, 2020
016557e
track/serato/markers: Use RgbColor instead of plain QRgb
Holzhaus Feb 15, 2020
1ffdb24
track/serato/markers2: Remove expensive entry length default implemen…
Holzhaus Feb 15, 2020
46a7ac2
track/serato/markers2: Use QDataStream for SeratoMarkers2::dump()
Holzhaus Feb 15, 2020
57ff560
track/serato/markers2: Use QDataStream for parsing CUE/LOOP entries
Holzhaus Feb 15, 2020
0495add
test/seratomarkers2test: Break long lines
Holzhaus Feb 16, 2020
936dd3b
track/serato/markers: Cast quint8 to quint32 before bitshifting
Holzhaus Feb 16, 2020
fef7493
track/serato: Use static_cast if necessary
Holzhaus Feb 16, 2020
c9a38e5
track/serato/markers: Add some comments for typeId values
Holzhaus Feb 16, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 9 additions & 9 deletions src/test/seratomarkerstest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ class SeratoMarkersTest : public testing::Test {
quint32 startPosition,
bool hasEndPosition,
quint32 endPosition,
QRgb color,
mixxx::RgbColor color,
mixxx::SeratoMarkersEntry::TypeId typeId,
bool isLocked) {
const mixxx::SeratoMarkersEntryPointer pEntry = mixxx::SeratoMarkersEntry::parse(inputValue);
Expand Down Expand Up @@ -60,7 +60,7 @@ TEST_F(SeratoMarkersTest, ParseEntry) {
0x7f7f7f7f,
false,
0x7f7f7f7f,
QRgb(0x000000),
mixxx::RgbColor(0x000000),
mixxx::SeratoMarkersEntry::TypeId::Unknown,
false);
parseEntry(
Expand All @@ -70,7 +70,7 @@ TEST_F(SeratoMarkersTest, ParseEntry) {
0,
false,
0x7f7f7f7f,
QRgb(0xcc0000),
mixxx::RgbColor(0xcc0000),
mixxx::SeratoMarkersEntry::TypeId::Cue,
false);
parseEntry(
Expand All @@ -80,7 +80,7 @@ TEST_F(SeratoMarkersTest, ParseEntry) {
862808,
false,
0x7f7f7f7f,
QRgb(0xcc8800),
mixxx::RgbColor(0xcc8800),
mixxx::SeratoMarkersEntry::TypeId::Cue,
false);
parseEntry(
Expand All @@ -90,7 +90,7 @@ TEST_F(SeratoMarkersTest, ParseEntry) {
218212,
false,
0x7f7f7f7f,
QRgb(0x0000cc),
mixxx::RgbColor(0x0000cc),
mixxx::SeratoMarkersEntry::TypeId::Cue,
false);
parseEntry(
Expand All @@ -100,7 +100,7 @@ TEST_F(SeratoMarkersTest, ParseEntry) {
108,
false,
0x7f7f7f7f,
QRgb(0xcccc00),
mixxx::RgbColor(0xcccc00),
mixxx::SeratoMarkersEntry::TypeId::Cue,
false);
parseEntry(
Expand All @@ -110,7 +110,7 @@ TEST_F(SeratoMarkersTest, ParseEntry) {
1911,
false,
0x7f7f7f7f,
QRgb(0x00cc00),
mixxx::RgbColor(0x00cc00),
mixxx::SeratoMarkersEntry::TypeId::Cue,
false);
parseEntry(
Expand All @@ -120,7 +120,7 @@ TEST_F(SeratoMarkersTest, ParseEntry) {
0x7f7f7f7f,
false,
0x7f7f7f7f,
QRgb(0x000000),
mixxx::RgbColor(0x000000),
mixxx::SeratoMarkersEntry::TypeId::Cue,
false);
parseEntry(
Expand All @@ -130,7 +130,7 @@ TEST_F(SeratoMarkersTest, ParseEntry) {
0x7f7f7f7f,
false,
0x7f7f7f7f,
QRgb(0x000000),
mixxx::RgbColor(0x000000),
mixxx::SeratoMarkersEntry::TypeId::Loop,
false);
}
Expand Down
24 changes: 15 additions & 9 deletions src/track/serato/markers.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,18 @@

#include <QtEndian>

#include "util/color/rgbcolor.h"

namespace {

const int kNumEntries = 14;
const int kLoopEntryStartIndex = 5;
const int kEntrySize = 22;
const quint16 kVersion = 0x0205;
constexpr mixxx::RgbColor kDefaultTrackColor = mixxx::RgbColor(0xFF9999);

// These functions conversion between the 4-byte "Serato Markers_" color format
// and QRgb (3-Byte RGB, transparency disabled).
// and RgbColor (3-Byte RGB, transparency disabled).
//
// Serato's custom color format that is used here also represents RGB colors,
// but inserts a single null bit after every 7 payload bits, starting from the
Expand All @@ -29,14 +32,14 @@ const quint16 kVersion = 0x0205;
// See this for details:
// https://github.com/Holzhaus/serato-tags/blob/master/docs/serato_markers_.md#color-format

QRgb seratoColorToRgb(quint8 w, quint8 x, quint8 y, quint8 z) {
mixxx::RgbColor seratoColorToRgb(quint8 w, quint8 x, quint8 y, quint8 z) {
quint8 b = (z & 0x7F) | ((y & 0x01) << 7);
quint8 g = ((y & 0x7F) >> 1) | ((x & 0x03) << 6);
quint8 r = ((x & 0x7F) >> 2) | ((w & 0x07) << 5);
return QRgb(r << 16) | (g << 8) | b;
return mixxx::RgbColor((r << 16) | (g << 8) | b);
Holzhaus marked this conversation as resolved.
Show resolved Hide resolved
}

QRgb seratoColorToRgb(quint32 color) {
mixxx::RgbColor seratoColorToRgb(quint32 color) {
return seratoColorToRgb(
(color >> 24) & 0xFF,
(color >> 16) & 0xFF,
Expand All @@ -52,8 +55,11 @@ quint32 seratoColorFromRgb(quint8 r, quint8 g, quint8 b) {
return (w << 24) | (x << 16) | (y << 8) | z;
Holzhaus marked this conversation as resolved.
Show resolved Hide resolved
}

quint32 seratoColorFromRgb(QRgb rgb) {
return seratoColorFromRgb(qRed(rgb), qGreen(rgb), qBlue(rgb));
quint32 seratoColorFromRgb(mixxx::RgbColor rgb) {
return seratoColorFromRgb(
(rgb >> 16) & 0xFF,
(rgb >> 8) & 0xFF,
rgb & 0xFF);
}
}

Expand Down Expand Up @@ -106,7 +112,7 @@ SeratoMarkersEntryPointer SeratoMarkersEntry::parse(const QByteArray& data) {

stream >> colorRaw >> type >> isLocked;

const QRgb color = seratoColorToRgb(colorRaw);
const RgbColor color = seratoColorToRgb(colorRaw);

// Parse Start Position
bool hasStartPosition = (startPositionStatus != 0x7F);
Expand Down Expand Up @@ -222,7 +228,7 @@ bool SeratoMarkers::parse(SeratoMarkers* seratoMarkers, const QByteArray& data)

quint32 trackColorRaw;
stream >> trackColorRaw;
QRgb trackColor = seratoColorToRgb(trackColorRaw);
RgbColor trackColor = seratoColorToRgb(trackColorRaw);

if (stream.status() != QDataStream::Status::Ok) {
qWarning() << "Parsing SeratoMarkers_ failed:"
Expand Down Expand Up @@ -253,7 +259,7 @@ QByteArray SeratoMarkers::dump() const {
SeratoMarkersEntryPointer pEntry = m_entries.at(i);
stream.writeRawData(pEntry->dump(), kEntrySize);
}
stream << seratoColorFromRgb(m_trackColor);
stream << seratoColorFromRgb(m_trackColor.value_or(kDefaultTrackColor));
return data;
}

Expand Down
15 changes: 8 additions & 7 deletions src/track/serato/markers.h
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
#include <QList>
#include <memory>

#include "util/color/rgbcolor.h"
#include "util/types.h"

namespace mixxx {
Expand All @@ -27,7 +28,7 @@ class SeratoMarkersEntry {
int startPosition,
bool hasEndPosition,
int endPosition,
QRgb color,
RgbColor color,
int type,
bool isLocked)
: m_color(color),
Expand Down Expand Up @@ -61,7 +62,7 @@ class SeratoMarkersEntry {
return typeId;
}

QRgb getColor() const {
RgbColor getColor() const {
return m_color;
}

Expand All @@ -86,7 +87,7 @@ class SeratoMarkersEntry {
}

private:
QRgb m_color;
RgbColor m_color;
bool m_hasStartPosition;
bool m_hasEndPosition;
;
Expand Down Expand Up @@ -138,7 +139,7 @@ class SeratoMarkers final {
QByteArray dump() const;

bool isEmpty() const {
return m_entries.isEmpty();
return m_entries.isEmpty() && !m_trackColor;
}

const QList<SeratoMarkersEntryPointer>& getEntries() const {
Expand All @@ -148,16 +149,16 @@ class SeratoMarkers final {
m_entries = entries;
}

QRgb getTrackColor() const {
RgbColor::optional_t getTrackColor() const {
return m_trackColor;
}
void setTrackColor(QRgb color) {
void setTrackColor(RgbColor::optional_t color) {
m_trackColor = color;
}

private:
QList<SeratoMarkersEntryPointer> m_entries;
QRgb m_trackColor;
RgbColor::optional_t m_trackColor;
};

inline bool operator==(const SeratoMarkers& lhs, const SeratoMarkers& rhs) {
Expand Down