]> git.sur5r.net Git - minitube/blobdiff - src/videodefinition.cpp
Update upstream source from tag 'upstream/3.8'
[minitube] / src / videodefinition.cpp
index 443f1710334c1e13826f486740992372207b2cb1..360817f99963db0b7033d672b930afab3a8bbf0c 100644 (file)
@@ -21,53 +21,56 @@ $END_LICENSE */
 #include "videodefinition.h"
 
 namespace {
-static const int kEmptyDefinitionCode = -1;
-
-static const VideoDefinition kEmptyDefinition(QString(), kEmptyDefinitionCode);
+const int kEmptyDefinitionCode = -1;
 
 template <typename T, T (VideoDefinition::*Getter)() const>
-const VideoDefinition& getDefinitionForImpl(T matchValue) {
-    const QList<VideoDefinition>& definitions = VideoDefinition::getDefinitions();
-    const int size = definitions.size();
-    for (int ii = 0; ii < size; ++ii) {
-        const VideoDefinition& def = definitions.at(ii);
-        if ((def.*Getter)() == matchValue)
-            return def;
-    }
+const VideoDefinition &getDefinitionForImpl(T matchValue) {
+    const auto &defs = VideoDefinition::getDefinitions();
 
+    for (auto i = defs.rbegin(); i != defs.rend(); ++i) {
+        if ((*i.*Getter)() == matchValue) return *i;
+    }
+    /*
+    for (const VideoDefinition &def : defs) {
+        if ((def.*Getter)() == matchValue) return def;
+    }
+    */
+    static const VideoDefinition kEmptyDefinition(QString(), kEmptyDefinitionCode);
     return kEmptyDefinition;
 }
-}
-
-// static
-const QList<VideoDefinition>& VideoDefinition::getDefinitions() {
-    static QList<VideoDefinition> definitions = QList<VideoDefinition>()
-        << VideoDefinition(QLatin1String("360p"), 18)
-        << VideoDefinition(QLatin1String("720p"), 22)
-        << VideoDefinition(QLatin1String("1080p"), 37);
+} // namespace
+
+const QVector<VideoDefinition> &VideoDefinition::getDefinitions() {
+    // List preferred equivalent format last:
+    // algo selects the last format with same name first
+    static const QVector<VideoDefinition> definitions = {
+            VideoDefinition("240p", 242),      VideoDefinition("240p", 133),
+            VideoDefinition("360p", 243),      VideoDefinition("360p", 396),
+            VideoDefinition("360p", 18, true), VideoDefinition("480p", 244),
+            VideoDefinition("480p", 135),      VideoDefinition("720p", 247),
+            VideoDefinition("720p", 136),      VideoDefinition("720p", 22, true),
+            VideoDefinition("1080p", 248),     VideoDefinition("1080p", 137),
+            VideoDefinition("1440p", 271),     VideoDefinition("2160p", 313),
+    };
     return definitions;
 }
 
-// static
-const VideoDefinition& VideoDefinition::getDefinitionFor(const QString& name) {
-    return getDefinitionForImpl<const QString&, &VideoDefinition::getName>(name);
+const QVector<QString> &VideoDefinition::getDefinitionNames() {
+    static const QVector<QString> names = {"480p", "720p", "1080p", "1440p", "2160p"};
+    return names;
 }
 
-// static
-const VideoDefinition& VideoDefinition::getDefinitionFor(int code) {
-    return getDefinitionForImpl<int, &VideoDefinition::getCode>(code);
+const VideoDefinition &VideoDefinition::forName(const QString &name) {
+    return getDefinitionForImpl<const QString &, &VideoDefinition::getName>(name);
 }
 
-VideoDefinition::VideoDefinition(const QString& name, int code) :
-    m_name(name),
-    m_code(code) {
+const VideoDefinition &VideoDefinition::forCode(int code) {
+    return getDefinitionForImpl<int, &VideoDefinition::getCode>(code);
 }
 
-VideoDefinition::VideoDefinition(const VideoDefinition& other) :
-    m_name(other.m_name),
-    m_code(other.m_code) {
-}
+VideoDefinition::VideoDefinition(const QString &name, int code, bool hasAudioStream)
+    : name(name), code(code), hasAudioStream(hasAudioStream) {}
 
 bool VideoDefinition::isEmpty() const {
-    return m_code == kEmptyDefinitionCode && m_name.isEmpty();
+    return code == kEmptyDefinitionCode && name.isEmpty();
 }