Compare commits

...

31 Commits

Author SHA1 Message Date
Clementine Buildbot 650bd81508 Automatic merge of translations from Transifex 2024-05-17 02:32:22 +00:00
Clementine Buildbot 7607ddcb96 Automatic merge of translations from Transifex 2024-05-12 02:33:06 +00:00
Clementine Buildbot e249911937 Automatic merge of translations from Transifex 2024-05-05 02:32:03 +00:00
Clementine Buildbot 4ae57a4b5d Automatic merge of translations from Transifex 2024-05-03 02:32:14 +00:00
Clementine Buildbot 2f3464403b Automatic merge of translations from Transifex 2024-04-25 02:31:15 +00:00
Clementine Buildbot f76dbffa6b Automatic merge of translations from Transifex 2024-03-24 02:30:19 +00:00
Clementine Buildbot fbb266adc2 Automatic merge of translations from Transifex 2024-03-15 02:29:14 +00:00
Clementine Buildbot 9638ac70b3 Automatic merge of translations from Transifex 2024-03-13 02:29:55 +00:00
Clementine Buildbot c93b4e1149 Automatic merge of translations from Transifex 2024-02-27 02:27:58 +00:00
Clementine Buildbot d014a315c9 Automatic merge of translations from Transifex 2024-02-23 02:28:36 +00:00
Isaiah W df4181940d oops (:
this is what I meant lol
2024-02-08 14:04:03 +00:00
Isaiah W ebe3c45476 Fix Instructions™
uses all of your cores if you have more than 8, or doesn't try to use more than you have if you have less (:
2024-02-08 14:04:03 +00:00
Clementine Buildbot 634910238d Automatic merge of translations from Transifex 2024-01-03 02:31:14 +00:00
Clementine Buildbot 62ed69fa3d Automatic merge of translations from Transifex 2023-12-19 02:32:39 +00:00
Clementine Buildbot dd0a94e8a6 Automatic merge of translations from Transifex 2023-12-09 02:30:35 +00:00
Clementine Buildbot 1566148c50 Automatic merge of translations from Transifex 2023-11-29 02:32:39 +00:00
Clementine Buildbot 98a520552b Automatic merge of translations from Transifex 2023-11-26 02:32:33 +00:00
Clementine Buildbot 5968648aa1 Automatic merge of translations from Transifex 2023-11-01 02:31:10 +00:00
Clementine Buildbot f3ddd7eee4 Automatic merge of translations from Transifex 2023-10-22 02:30:09 +00:00
Clementine Buildbot 19b44fb831 Automatic merge of translations from Transifex 2023-10-16 02:30:12 +00:00
Robert-André Mauchin 994d16effa Fix missing QTSINGLECOREAPPLICATION_LIBRARIES
In f3837f95db, QTSINGLECOREAPPLICATION_LIBRARIES was mistakenly removed, which prevents building with USE_SYSTEM_QTSINGLEAPPLICATION enabled.
2023-10-15 13:40:14 +01:00
xoza 4768cb9efb Skip subsonic multi-genre tags 2023-10-12 12:27:43 +01:00
Clementine Buildbot 7b678f26e0 Automatic merge of translations from Transifex 2023-10-02 02:29:29 +00:00
Marcus Müller 3f572a4139 RPM & CI: Build rpm packages against native qtsingleapplication
Signed-off-by: Marcus Müller <marcus_clementine@baseband.digital>
2023-09-20 17:52:55 +01:00
Marcus Müller f3837f95db CMake: Re-enable usability of system QtSingleApplication
This seem to have gone broken over time.
As far as I can tell, upstream QtSingleApplication works fine!

Signed-off-by: Marcus Müller <marcus_clementine@baseband.digital>
2023-09-20 17:52:55 +01:00
Marcus Müller 6820a0a58d 3rdparty: remove unused libmygpo-qt
The -qt5 library is still there, and seems to be used.

Signed-off-by: Marcus Müller <marcus_clementine@baseband.digital>
2023-09-17 16:41:15 +01:00
Marcus Müller cfcddf7c0f src: remove unused variable
Signed-off-by: Marcus Müller <marcus_clementine@baseband.digital>
2023-09-17 12:43:13 +01:00
Marcus Müller 98e24f626b library: use boolean, not bitwise, operator on bools
Signed-off-by: Marcus Müller <marcus_clementine@baseband.digital>
2023-09-17 12:43:13 +01:00
Marcus Müller 8e47ab59e5 internet services: consistently use 'override'
Signed-off-by: Marcus Müller <marcus_clementine@baseband.digital>
2023-09-17 12:43:13 +01:00
Marcus Müller 63208b4e1f core/organisefmt: use same visibility for fwd decl as in def
Signed-off-by: Marcus Müller <marcus_clementine@baseband.digital>
2023-09-17 12:43:13 +01:00
Marcus Müller 20773dee29 CMake: Check for minimum version before setting the project name
Signed-off-by: Marcus Müller <marcus_clementine@baseband.digital>
2023-09-17 12:43:13 +01:00
38 changed files with 998 additions and 1149 deletions

View File

@ -231,6 +231,8 @@ jobs:
qt5-qtbase-devel
qt5-qtx11extras-devel
qt5-rpm-macros
qtsingleapplication-qt5-devel
qtsinglecoreapplication-qt5-devel
rpmdevtools
sha2-devel
sparsehash-devel
@ -242,7 +244,7 @@ jobs:
run: git config --global --add safe.directory ${GITHUB_WORKSPACE}
- name: cmake
working-directory: bin
run: cmake ..
run: cmake -DUSE_SYSTEM_QTSINGLEAPPLICATION=On ..
- name: Build source tarball
working-directory: bin
run: ../dist/maketarball.sh
@ -303,6 +305,8 @@ jobs:
qt5-qtbase-devel
qt5-qtx11extras-devel
qt5-rpm-macros
qtsingleapplication-qt5-devel
qtsinglecoreapplication-qt5-devel
rpmdevtools
sha2-devel
sparsehash-devel
@ -314,7 +318,7 @@ jobs:
run: git config --global --add safe.directory ${GITHUB_WORKSPACE}
- name: cmake
working-directory: bin
run: cmake ..
run: cmake -DUSE_SYSTEM_QTSINGLEAPPLICATION=On ..
- name: Build source tarball
working-directory: bin
run: ../dist/maketarball.sh
@ -375,6 +379,8 @@ jobs:
qt5-qtbase-devel
qt5-qtx11extras-devel
qt5-rpm-macros
qtsingleapplication-qt5-devel
qtsinglecoreapplication-qt5-devel
rpmdevtools
sha2-devel
sparsehash-devel
@ -386,7 +392,7 @@ jobs:
run: git config --global --add safe.directory ${GITHUB_WORKSPACE}
- name: cmake
working-directory: bin
run: cmake ..
run: cmake -DUSE_SYSTEM_QTSINGLEAPPLICATION=On ..
- name: Build source tarball
working-directory: bin
run: ../dist/maketarball.sh

View File

@ -1,128 +0,0 @@
/* Copyright 2014, Uwe L. Korn <uwelk@xhochy.com>
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
#include "Json.h"
// Qt version specific includes
#if QT_VERSION >= QT_VERSION_CHECK( 5, 0, 0 )
#include <QJsonDocument>
#include <QMetaProperty>
#else
#include <qjson/parser.h>
#include <qjson/qobjecthelper.h>
#include <qjson/serializer.h>
#endif
namespace QJsonWrapper
{
QVariantMap
qobject2qvariant( const QObject* object )
{
#if QT_VERSION >= QT_VERSION_CHECK( 5, 0, 0 )
QVariantMap map;
if ( object == NULL )
{
return map;
}
const QMetaObject* metaObject = object->metaObject();
for ( int i = 0; i < metaObject->propertyCount(); ++i )
{
QMetaProperty metaproperty = metaObject->property( i );
if ( metaproperty.isReadable() )
{
map[ QLatin1String( metaproperty.name() ) ] = object->property( metaproperty.name() );
}
}
return map;
#else
return QJson::QObjectHelper::qobject2qvariant( object );
#endif
}
void
qvariant2qobject( const QVariantMap& variant, QObject* object )
{
#if QT_VERSION >= QT_VERSION_CHECK( 5, 0, 0 )
for ( QVariantMap::const_iterator iter = variant.begin(); iter != variant.end(); ++iter )
{
QVariant property = object->property( iter.key().toLatin1() );
Q_ASSERT( property.isValid() );
if ( property.isValid() )
{
QVariant value = iter.value();
if ( value.canConvert( property.type() ) )
{
value.convert( property.type() );
object->setProperty( iter.key().toLatin1(), value );
} else if ( QString( QLatin1String("QVariant") ).compare( QLatin1String( property.typeName() ) ) == 0 ) {
object->setProperty( iter.key().toLatin1(), value );
}
}
}
#else
QJson::QObjectHelper::qvariant2qobject( variant, object );
#endif
}
QVariant
parseJson( const QByteArray& jsonData, bool* ok )
{
#if QT_VERSION >= QT_VERSION_CHECK( 5, 0, 0 )
QJsonParseError error;
QJsonDocument doc = QJsonDocument::fromJson( jsonData, &error );
if ( ok != NULL )
{
*ok = ( error.error == QJsonParseError::NoError );
}
return doc.toVariant();
#else
QJson::Parser p;
return p.parse( jsonData, ok );
#endif
}
QByteArray
toJson( const QVariant &variant, bool* ok )
{
#if QT_VERSION >= QT_VERSION_CHECK( 5, 0, 0 )
QJsonDocument doc = QJsonDocument::fromVariant( variant );
if ( ok != NULL )
{
*ok = !doc.isNull();
}
return doc.toJson( QJsonDocument::Compact );
#else
QJson::Serializer serializer;
QByteArray ret = serializer.serialize(variant);
if ( ok != NULL )
{
*ok = !ret.isNull();
}
return ret;
#endif
}
}

View File

@ -1,36 +0,0 @@
/* Copyright 2014, Uwe L. Korn <uwelk@xhochy.com>
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
#pragma once
#ifndef QJSONWRAPPER_JSON_H
#define QJSONWRAPPER_JSON_H
#include <QVariant>
namespace QJsonWrapper
{
QVariantMap qobject2qvariant( const QObject* object );
void qvariant2qobject( const QVariantMap& variant, QObject* object );
QVariant parseJson( const QByteArray& jsonData, bool* ok = 0 );
QByteArray toJson( const QVariant &variant, bool* ok = 0 );
}
#endif // QJSONWRAPPER_JSON_H

View File

@ -1,6 +1,6 @@
cmake_minimum_required(VERSION 3.0.0)
project(clementine)
cmake_minimum_required(VERSION 3.0.0)
cmake_policy(SET CMP0053 OLD)
include(CheckCXXCompilerFlag)
@ -347,11 +347,18 @@ include_directories("3rdparty/qsqlite")
# When/if upstream accepts our patches then these options can be used to link
# to system installed qtsingleapplication instead.
option(USE_SYSTEM_QTSINGLEAPPLICATION "Don't set this option unless your system QtSingleApplication library has been compiled with the Clementine patches in 3rdparty" OFF)
option(USE_SYSTEM_QTSINGLEAPPLICATION "Use the system-provided QtSingleApplication library (needs to have clementine patches, but these seem to be in Qt5)" OFF)
if(USE_SYSTEM_QTSINGLEAPPLICATION)
find_path(QTSINGLEAPPLICATION_INCLUDE_DIRS qtsingleapplication.h PATH_SUFFIXES qt5/QtSolutions)
find_library(QTSINGLEAPPLICATION_LIBRARIES Qt5Solutions_SingleApplication-2.6)
find_library(QTSINGLECOREAPPLICATION_LIBRARIES Qt5Solutions_SingleCoreApplication-2.6)
find_path(QTSINGLEAPPLICATION_INCLUDE_DIRS qtsingleapplication.h PATH_SUFFIXES qt5/QtSolutions REQUIRED)
find_library(QTSINGLEAPPLICATION_LIBRARIES Qt5Solutions_SingleApplication-2.6 REQUIRED)
add_library(qtsingleapplication INTERFACE)
target_link_libraries(qtsingleapplication INTERFACE QTSINGLEAPPLICATION_LIBRARIES)
target_include_directories(qtsingleapplication INTERFACE QTSINGLEAPPLICATION_INCLUDE_DIRS)
find_path(QTSINGLECOREAPPLICATION_INCLUDE_DIRS qtsinglecoreapplication.h PATH_SUFFIXES qt5/QtSolutions REQUIRED)
find_library(QTSINGLECOREAPPLICATION_LIBRARIES Qt5Solutions_SingleCoreApplication-2.6 REQUIRED)
add_library(qtsinglecoreapplication INTERFACE)
target_link_libraries(qtsinglecoreapplication INTERFACE QTSINGLECOREAPPLICATION_LIBRARIES)
target_include_directories(qtsinglecoreapplication INTERFACE QTSINGLECOREAPPLICATION_INCLUDE_DIRS)
else(USE_SYSTEM_QTSINGLEAPPLICATION)
add_subdirectory(3rdparty/qtsingleapplication)
set(QTSINGLEAPPLICATION_INCLUDE_DIRS ${CMAKE_CURRENT_SOURCE_DIR}/3rdparty/qtsingleapplication)

View File

@ -41,7 +41,7 @@ Compile and install:
cd bin
cmake ..
make -j8
make -j$(nproc)
sudo make install
See the Wiki for more instructions and a list of dependencies:

View File

@ -18,6 +18,7 @@ BuildRequires: liblastfm-qt5-devel
BuildRequires: desktop-file-utils
BuildRequires: hicolor-icon-theme
BuildRequires: libappstream-glib
BuildRequires: qtsingleapplication-qt5-devel
BuildRequires: pkgconfig
BuildRequires: pkgconfig(glib-2.0)
BuildRequires: pkgconfig(gio-2.0)

View File

@ -27,7 +27,7 @@
#include "core/song.h"
class TranscoderPreset;
struct TranscoderPreset;
class OrganiseFormat {
public:

View File

@ -41,16 +41,16 @@ class DigitallyImportedServiceBase : public InternetService {
const QString& api_service_name,
Application* app, InternetModel* model,
bool has_premium, QObject* parent = nullptr);
~DigitallyImportedServiceBase();
~DigitallyImportedServiceBase() override;
static const char* kSettingsGroup;
static const int kStreamsCacheDurationSecs;
QStandardItem* CreateRootItem();
void LazyPopulate(QStandardItem* parent);
void ShowContextMenu(const QPoint& global_pos);
QStandardItem* CreateRootItem() override;
void LazyPopulate(QStandardItem* parent) override;
void ShowContextMenu(const QPoint& global_pos) override;
void ReloadSettings();
void ReloadSettings() override;
bool is_premium_account() const;

View File

@ -40,7 +40,7 @@ class IcecastService : public InternetService {
public:
IcecastService(Application* app, InternetModel* parent);
~IcecastService();
~IcecastService() override;
static const char* kServiceName;
static const char* kDirectoryUrl;
@ -51,12 +51,12 @@ class IcecastService : public InternetService {
Type_Genre,
};
QStandardItem* CreateRootItem();
void LazyPopulate(QStandardItem* item);
QStandardItem* CreateRootItem() override;
void LazyPopulate(QStandardItem* item) override;
void ShowContextMenu(const QPoint& global_pos);
void ShowContextMenu(const QPoint& global_pos) override;
QWidget* HeaderWidget() const;
QWidget* HeaderWidget() const override;
private slots:
void LoadDirectory();

View File

@ -39,7 +39,7 @@ class IntergalacticFMServiceBase : public InternetService {
const QString& name, const QUrl& channel_list_url,
const QUrl& homepage_url,
const QUrl& donate_page_url, const QIcon& icon);
~IntergalacticFMServiceBase();
~IntergalacticFMServiceBase() override;
enum ItemType {
Type_Stream = 2000,
@ -59,14 +59,14 @@ class IntergalacticFMServiceBase : public InternetService {
const QString& url_scheme() const { return url_scheme_; }
const QIcon& icon() const { return icon_; }
QStandardItem* CreateRootItem();
void LazyPopulate(QStandardItem* item);
void ShowContextMenu(const QPoint& global_pos);
QStandardItem* CreateRootItem() override;
void LazyPopulate(QStandardItem* item) override;
void ShowContextMenu(const QPoint& global_pos) override;
PlaylistItem::Options playlistitem_options() const;
PlaylistItem::Options playlistitem_options() const override;
QNetworkAccessManager* network() const { return network_; }
void ReloadSettings();
void ReloadSettings() override;
bool IsStreamListStale() const { return streams_.IsStale(); }
StreamList Streams();

View File

@ -34,7 +34,7 @@ class SavedRadio : public InternetService {
public:
SavedRadio(Application* app, InternetModel* parent);
~SavedRadio();
~SavedRadio() override;
enum ItemType {
Type_Stream = 2000,
@ -57,10 +57,10 @@ class SavedRadio : public InternetService {
static const char* kServiceName;
static const char* kSettingsGroup;
QStandardItem* CreateRootItem();
void LazyPopulate(QStandardItem* item);
QStandardItem* CreateRootItem() override;
void LazyPopulate(QStandardItem* item) override;
void ShowContextMenu(const QPoint& global_pos);
void ShowContextMenu(const QPoint& global_pos) override;
void Add(const QUrl& url, const QString& name = QString(),
const QUrl& url_logo = QUrl());

View File

@ -43,14 +43,14 @@ class JamendoService : public InternetService {
public:
JamendoService(Application* app, InternetModel* parent);
~JamendoService();
~JamendoService() override;
QStandardItem* CreateRootItem();
void LazyPopulate(QStandardItem* item);
QStandardItem* CreateRootItem() override;
void LazyPopulate(QStandardItem* item) override;
void ShowContextMenu(const QPoint& global_pos);
void ShowContextMenu(const QPoint& global_pos) override;
QWidget* HeaderWidget() const;
QWidget* HeaderWidget() const override;
LibraryBackend* library_backend() const { return library_backend_.get(); }

View File

@ -38,7 +38,7 @@ class MagnatuneService : public InternetService {
public:
MagnatuneService(Application* app, InternetModel* parent);
~MagnatuneService();
~MagnatuneService() override;
// Values are saved in QSettings and are indices into the combo box in
// MagnatuneConfig
@ -71,14 +71,14 @@ class MagnatuneService : public InternetService {
static QString ReadElementText(QXmlStreamReader& reader);
QStandardItem* CreateRootItem();
void LazyPopulate(QStandardItem* item);
QStandardItem* CreateRootItem() override;
void LazyPopulate(QStandardItem* item) override;
void ShowContextMenu(const QPoint& global_pos);
void ShowContextMenu(const QPoint& global_pos) override;
QWidget* HeaderWidget() const;
QWidget* HeaderWidget() const override;
void ReloadSettings();
void ReloadSettings() override;
// Magnatune specific stuff
MembershipType membership_type() const { return membership_; }
@ -99,7 +99,7 @@ class MagnatuneService : public InternetService {
void Download();
void Homepage();
void ShowConfig();
void ShowConfig() override;
private:
void EnsureMenuCreated();

View File

@ -44,7 +44,7 @@ class PodcastService : public InternetService {
public:
PodcastService(Application* app, InternetModel* parent);
~PodcastService();
~PodcastService() override;
static const char* kServiceName;
static const char* kSettingsGroup;
@ -57,12 +57,12 @@ class PodcastService : public InternetService {
enum Role { Role_Podcast = InternetModel::RoleCount, Role_Episode };
QStandardItem* CreateRootItem();
void LazyPopulate(QStandardItem* parent);
bool has_initial_load_settings() const { return true; }
void ShowContextMenu(const QPoint& global_pos);
void ReloadSettings();
void InitialLoadSettings();
QStandardItem* CreateRootItem() override;
void LazyPopulate(QStandardItem* parent) override;
bool has_initial_load_settings() const override { return true; }
void ShowContextMenu(const QPoint& global_pos) override;
void ReloadSettings() override;
void InitialLoadSettings() override;
// Called by SongLoader when the user adds a Podcast URL directly. Adds a
// subscription to the podcast and displays it in the UI. If the QVariant
// contains an OPML file then this displays it in the Add Podcast dialog.
@ -81,7 +81,7 @@ class PodcastService : public InternetService {
void DeleteDownloadedData();
void SetNew();
void SetListened();
void ShowConfig();
void ShowConfig() override;
void SubscriptionAdded(const Podcast& podcast);
void SubscriptionRemoved(const Podcast& podcast);

View File

@ -35,7 +35,7 @@ class RadioBrowserService : public InternetService {
public:
RadioBrowserService(Application* app, InternetModel* parent);
~RadioBrowserService(){};
~RadioBrowserService() override{};
enum ItemType {
Type_Stream = 2000,

View File

@ -39,7 +39,7 @@ class SomaFMServiceBase : public InternetService {
const QString& name, const QUrl& channel_list_url,
const QUrl& homepage_url, const QUrl& donate_page_url,
const QIcon& icon);
~SomaFMServiceBase();
~SomaFMServiceBase() override;
enum ItemType {
Type_Stream = 2000,
@ -59,14 +59,14 @@ class SomaFMServiceBase : public InternetService {
const QString& url_scheme() const { return url_scheme_; }
const QIcon& icon() const { return icon_; }
QStandardItem* CreateRootItem();
void LazyPopulate(QStandardItem* item);
void ShowContextMenu(const QPoint& global_pos);
QStandardItem* CreateRootItem() override;
void LazyPopulate(QStandardItem* item) override;
void ShowContextMenu(const QPoint& global_pos) override;
PlaylistItem::Options playlistitem_options() const;
PlaylistItem::Options playlistitem_options() const override;
QNetworkAccessManager* network() const { return network_; }
void ReloadSettings();
void ReloadSettings() override;
bool IsStreamListStale() const { return streams_.IsStale(); }
StreamList Streams();

View File

@ -530,6 +530,11 @@ void SubsonicLibraryScanner::OnGetAlbumFinished(QNetworkReply* reply) {
// Read song information
while (reader.readNextStartElement()) {
// skip multi-artist and multi-genre tags
if ((reader.name() == "artists") || (reader.name() == "genres")) {
reader.skipCurrentElement();
continue;
}
if (reader.name() != "song") {
ParsingError("song tag expected. Aborting scan.");
return;

View File

@ -42,7 +42,7 @@ class SubsonicService : public InternetService {
public:
SubsonicService(Application* app, InternetModel* parent);
~SubsonicService();
~SubsonicService() override;
enum LoginState {
LoginState_Loggedin,
@ -90,11 +90,11 @@ class SubsonicService : public InternetService {
bool IsConfigured() const;
bool IsAmpache() const;
QStandardItem* CreateRootItem();
void LazyPopulate(QStandardItem* item);
void ShowContextMenu(const QPoint& global_pos);
QWidget* HeaderWidget() const;
void ReloadSettings();
QStandardItem* CreateRootItem() override;
void LazyPopulate(QStandardItem* item) override;
void ShowContextMenu(const QPoint& global_pos) override;
QWidget* HeaderWidget() const override;
void ReloadSettings() override;
void Login();
void Login(const QString& server, const QString& username,
@ -175,7 +175,7 @@ class SubsonicService : public InternetService {
void OnLoginStateChanged(SubsonicService::LoginState newstate);
void OnPingFinished(QNetworkReply* reply);
void ShowConfig();
void ShowConfig() override;
};
class SubsonicLibraryScanner : public QObject {
@ -184,7 +184,7 @@ class SubsonicLibraryScanner : public QObject {
public:
explicit SubsonicLibraryScanner(SubsonicService* service,
QObject* parent = nullptr);
~SubsonicLibraryScanner();
~SubsonicLibraryScanner() override;
void Scan();
const SongList& GetSongs() const { return songs_; }

View File

@ -896,7 +896,7 @@ LibraryBackend::AlbumList LibraryBackend::GetAlbums(const QString& artist,
QString last_artist;
QString last_album_artist;
while (query.Next()) {
bool compilation = query.Value(3).toBool() | query.Value(4).toBool();
bool compilation = query.Value(3).toBool() || query.Value(4).toBool();
Album info;
info.artist = compilation ? QString() : query.Value(1).toString();

View File

@ -92,12 +92,10 @@ void MoodbarBuilder::Normalize(QList<Rgb>* vals, double Rgb::*member) {
}
double avg = 0;
int t = 0;
for (const Rgb& rgb : *vals) {
const double value = rgb.*member;
if (value != mini && value != maxi) {
avg += value / vals->count();
t++;
}
}

View File

@ -1729,13 +1729,11 @@ PlaylistItemList Playlist::RemoveItemsWithoutUndo(int row, int count) {
endRemoveRows();
QList<int>::iterator it = virtual_items_.begin();
int i = 0;
while (it != virtual_items_.end()) {
if (*it >= items_.count())
it = virtual_items_.erase(it);
else
++it;
++i;
}
// Reset current_virtual_index_

View File

@ -34,12 +34,6 @@
#undef AddJob
#endif
namespace {
const char kWavHeaderRiffMarker[] = "RIFF";
const char kWavFileTypeFormatChunk[] = "WAVEfmt ";
const char kWavDataString[] = "data";
} // namespace
Ripper::Ripper(int track_count, QObject* parent)
: QObject(parent),
track_count_(track_count),

File diff suppressed because it is too large Load Diff

View File

@ -3,12 +3,12 @@
# This file is distributed under the same license as the Clementine package.
#
# Translators:
# Adolfo Jayme-Barrientos, 2014-2015
# Adolfo Jayme-Barrientos, 2012-2013,2018
# Adolfo Jayme-Barrientos, 2016,2018-2021
# Adolfo Jayme-Barrientos, 2015-2016
# Adolfo Jayme-Barrientos, 2013
# Adolfo Jayme-Barrientos, 2014
# Adolfo Jayme Barrientos, 2014-2015
# Adolfo Jayme Barrientos, 2012-2013,2018
# Adolfo Jayme Barrientos, 2016,2018-2021
# Adolfo Jayme Barrientos, 2015-2016
# Adolfo Jayme Barrientos, 2013
# Adolfo Jayme Barrientos, 2014
# FIRST AUTHOR <EMAIL@ADDRESS>, 2010
# Juanjo, 2016-2023
# davidsansome <me@davidsansome.com>, 2013

View File

@ -42,6 +42,7 @@
# Martin Brodbeck <martin@brodbeck-online.de>, 2013
# Martin Herkt <lachs0r@hong-mailing.de>, 2011
# Martin Herkt <luck3r@phicode.de>, 2010
# Michael Kohler, 2024
# MCMicS, 2020
# Mohamed Sakhri, 2013
# Mohamed Sakhri, 2013
@ -70,7 +71,7 @@ msgstr ""
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2011-04-09 10:24+0000\n"
"PO-Revision-Date: 2011-10-27 18:53+0000\n"
"Last-Translator: 6543 <6543@obermui.de>, 2020\n"
"Last-Translator: Michael Kohler, 2024\n"
"Language-Team: German (http://app.transifex.com/davidsansome/clementine/language/de/)\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
@ -219,7 +220,7 @@ msgid "1 track"
msgstr "1 Titel"
msgid "128K MP3"
msgstr ""
msgstr "128K MP3"
msgid "128k MP3"
msgstr "128k MP3"
@ -240,7 +241,7 @@ msgid "A Grooveshark Anywhere account is required."
msgstr ""
msgid "A Spotify Premium account is required."
msgstr ""
msgstr "Spotify Premium Zugang wird benötigt."
msgid ""
"A smart playlist is a dynamic list of songs that come from your library. "
@ -293,7 +294,7 @@ msgid "Action"
msgstr "Aktion"
msgid "Active/deactive Wiiremote"
msgstr ""
msgstr "Aktivieren/deaktivieren Wiiremote"
msgid "Add Stream"
msgstr "Datenstrom hinzufügen"
@ -326,7 +327,7 @@ msgid "Add folder..."
msgstr "Ordner hinzufügen …"
msgid "Add media"
msgstr ""
msgstr "Medien hinzufügen ..."
msgid "Add new folder..."
msgstr "Neuen Ordner hinzufügen …"
@ -386,7 +387,7 @@ msgid "Add wiimotedev action"
msgstr "Aktion für Wii-Fernbedienung hinzufügen"
msgid "Add..."
msgstr ""
msgstr "Hinzufügen …"
msgid "Added this month"
msgstr "Diesen Monat hinzugefügt"
@ -422,7 +423,7 @@ msgid "Album info on jamendo.com..."
msgstr "Albuminformationen auf jamendo.com …"
msgid "Albumartist"
msgstr ""
msgstr "Albumkünstler"
msgid "Albums with covers"
msgstr "Alben mit Titelbildern"
@ -633,7 +634,7 @@ msgid "CUE sheet support"
msgstr "Unterstützung von Cuesheets"
msgid "Cancel"
msgstr ""
msgstr "Abbrechen"
msgid "Change cover art"
msgstr "Titelbilder ändern"

View File

@ -3,10 +3,10 @@
# This file is distributed under the same license as the Clementine package.
#
# Translators:
# Adolfo Jayme-Barrientos, 2014
# Adolfo Jayme-Barrientos, 2018-2022
# Adolfo Jayme-Barrientos, 2015-2016
# Adolfo Jayme-Barrientos, 2014
# Adolfo Jayme Barrientos, 2014
# Adolfo Jayme Barrientos, 2018-2022
# Adolfo Jayme Barrientos, 2015-2016
# Adolfo Jayme Barrientos, 2014
# FIRST AUTHOR <EMAIL@ADDRESS>, 2010
msgid ""
msgstr ""
@ -14,7 +14,7 @@ msgstr ""
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2011-04-09 10:24+0000\n"
"PO-Revision-Date: 2011-10-27 18:53+0000\n"
"Last-Translator: Adolfo Jayme-Barrientos, 2018-2022\n"
"Last-Translator: Adolfo Jayme Barrientos, 2018-2022\n"
"Language-Team: Esperanto (http://app.transifex.com/davidsansome/clementine/language/eo/)\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"

View File

@ -4,12 +4,12 @@
#
# Translators:
# Coroccotta <adiazubierna@gmail.com>, 2012
# Adolfo Jayme-Barrientos, 2014
# Adolfo Jayme-Barrientos, 2012-2013,2018,2021
# Adolfo Jayme-Barrientos, 2016-2022
# Adolfo Jayme-Barrientos, 2015-2016
# Adolfo Jayme-Barrientos, 2013
# Adolfo Jayme-Barrientos, 2014
# Adolfo Jayme Barrientos, 2014
# Adolfo Jayme Barrientos, 2012-2013,2018,2021
# Adolfo Jayme Barrientos, 2016-2022
# Adolfo Jayme Barrientos, 2015-2016
# Adolfo Jayme Barrientos, 2013
# Adolfo Jayme Barrientos, 2014
# Adrián Prado Castro <adrian.prado@gmail.com>, 2013
# Adrián Ramirez Escalante <buried.prophet@gmail.com>, 2012
# Amaury Ortega <amauryocortega@gmail.com>, 2018

View File

@ -1245,7 +1245,7 @@ msgid "File name"
msgstr "Faili nimi"
msgid "File name (without path)"
msgstr "Failinimi (ilma rajata)"
msgstr "Failinimi (ilma asukohata)"
msgid "File size"
msgstr "Faili suurus"
@ -2606,7 +2606,7 @@ msgid "Skip backwards in playlist"
msgstr "Samm lugude nimekirjas tagasi"
msgid "Skip count"
msgstr "Vahelejätmiskorrad"
msgstr "Vahelejätmiskordi"
msgid "Skip forwards in playlist"
msgstr "Samm lugude nimekirjas edasi"

View File

@ -180,7 +180,7 @@ msgid ""
"<p>Tokens start with %, for example: %artist %album %title </p>\n"
"\n"
"<p>If you surround sections of text that contain a token with curly-braces, that section will be hidden if the token is empty.</p>"
msgstr "<p>Tietueet alkavat %-merkillä, esimerkiksi: %artist %album %title </p>\n\n<p>Jos ympäröit tietueen sisältävän tekstin aaltosulkeilla, se piilotetaan, jos tietue on tyhjä.</p>"
msgstr "<p>Tietueet alkavat % merkillä, esim: %artist %album %title </p>\n\n<p>Jos ympäröit sisältävän tekstin sulkeilla, se piilotetaan, jos tietue on tyhjä.</p>"
msgid "A Grooveshark Anywhere account is required."
msgstr "Edellyttää Grooveshark Anywhere tiliä."
@ -278,16 +278,16 @@ msgid "Add new folder..."
msgstr "Lisää uusi kansio..."
msgid "Add search term"
msgstr "Lisää hakutermi"
msgstr "Lisää hakuehto"
msgid "Add song album tag"
msgstr "Lisää tunniste levyn nimi"
msgid "Add song albumartist tag"
msgstr "Lisää tunniste levyn esittäjä"
msgstr "Lisää kappaleen levyn tunniste"
msgid "Add song artist tag"
msgstr "Lisää tunniste kappaleen esittäjä"
msgstr "Lisää kappaleen esittäjä tunniste"
msgid "Add song composer tag"
msgstr "Lisää tunniste kappaleen säveltäjä"
@ -362,7 +362,7 @@ msgid "Album (ideal loudness for all tracks)"
msgstr "Albumi (ihanteellinen voimakkuus kaikille kappaleille)"
msgid "Album artist"
msgstr "Albumin esittäjä"
msgstr "Levyn esittäjä"
msgid "Album info on jamendo.com..."
msgstr "Albumin tiedot jamendo.comissa..."
@ -425,7 +425,7 @@ msgid "An error occurred copying the iTunes database from the device"
msgstr "iTunes-tietokantaa kopioitaessa laitteesta tapahtui virhe"
msgid "An error occurred copying the iTunes database onto the device"
msgstr "iTunes-tietokannan kopiointi laitteeseen päättyi virheeseen"
msgstr "iTunes-tietokannan kopiointi päättyi virheeseen"
msgid "An error occurred loading the iTunes database"
msgstr "iTunes-tietokantaa ladatessa tapahtui virhe"
@ -479,7 +479,7 @@ msgid "Artist's initial"
msgstr "Esittäjän nimen ensimmäinen kirjain"
msgid "Audio format"
msgstr "Äänimuoto"
msgstr "Audio formaatti"
msgid "Audio type"
msgstr "Audio tyyppi"
@ -603,7 +603,7 @@ msgid "Check for updates..."
msgstr "Tarkista päivitykset..."
msgid "Choose a name for your smart playlist"
msgstr "Anna nimi älykkäälle soittolistalle"
msgstr "Anna nimi soittolistalle"
msgid "Choose automatically"
msgstr "Valitse automaattisesti"
@ -728,7 +728,7 @@ msgid "Configure Magnatune..."
msgstr "Magnatune-asetukset..."
msgid "Configure Shortcuts"
msgstr "Pikanäppäinten asetukset"
msgstr "Pikanäppäimet"
msgid "Configure Spotify..."
msgstr "Spotify asetukset..."
@ -792,7 +792,7 @@ msgid "Couldn't open output file %1"
msgstr "Ei voitu avata kohdetiedostoa %1"
msgid "Cover Manager"
msgstr "Kansikuvaselain"
msgstr "Kansikuvat"
msgid "Cover art from embedded image"
msgstr "Kansikuva sulautetusta kuvasta"
@ -1026,10 +1026,10 @@ msgid "Don't stop!"
msgstr "Älä lopeta!"
msgid "Double click to open"
msgstr "Kaksoisnapsauta avataksesi"
msgstr "Avaa painamalla kahdesti"
msgid "Double clicking a song will..."
msgstr "Kappaleen kaksoisnapsautus..."
msgstr "Kappaleen painaminen kahdesti..."
msgid "Download directory"
msgstr "Latauskansio"
@ -1130,13 +1130,13 @@ msgstr "Anna uusi nimi tälle soittolistalle"
msgid ""
"Enter an <b>artist</b> or <b>tag</b> to start listening to Last.fm radio."
msgstr "Anna <b>esittäjä</b> tai <b>tunniste</b> ja aloita Last.fm radion kuuntelu."
msgstr "Anna <b>artisti</b> tai <b>tunniste</b> ja kuuntele Last.fm radiota."
msgid "Enter search terms here"
msgstr "Etsi tästä"
msgid "Enter the URL of an internet radio stream:"
msgstr "Anna suoratoiston osoite:"
msgstr "Anna url-osoite:"
msgid "Entire collection"
msgstr "Koko kokoelma"
@ -1387,16 +1387,16 @@ msgid "Group by Artist"
msgstr "Järjestä esittäjän mukaan"
msgid "Group by Artist/Album"
msgstr "Järjestä esittäjän/albumin mukaan"
msgstr "Järjestä esittäjän/levyn mukaan"
msgid "Group by Artist/Year - Album"
msgstr "Järjestä esittäjän/vuoden - albumin mukaan"
msgstr "Järjestä esittäjän/vuoden mukaan"
msgid "Group by Genre/Album"
msgstr "Järjestä tyylin/albumin mukaan"
msgid "Group by Genre/Artist/Album"
msgstr "Järjestä tyylin/esittäjän/albumin mukaan"
msgstr "Järjestä tyylin/esittäjän/levyn mukaan"
msgid "HTTP proxy"
msgstr "HTTP-välityspalvelin"
@ -1449,7 +1449,7 @@ msgid ""
msgstr "Jos käytät ohjainta useammassa kuin yhdessä tietokoneessa, tämä nimi auttaa sinua valitsemaan puhelimen, johon haluat muodostaa yhteyden."
msgid "Ignore \"The\" in artist names"
msgstr "Älä huomioi sanaa \"The\" esiintyjien nimissä"
msgstr "Älä huomioi sanaa \"The\" esittäjän nimissä"
msgid "Images (*.png *.jpg *.jpeg *.bmp *.gif *.xpm *.pbm *.pgm *.ppm *.xbm)"
msgstr "Kuvat (*.png *.jpg *.jpeg *.bmp *.gif *.xpm *.pbm *.pgm *.ppm *.xbm)"
@ -1538,7 +1538,7 @@ msgid "Jamendo database"
msgstr "Jamendo-tietokanta"
msgid "Jump to the currently playing track"
msgstr "Näytä parhaillaan soiva kappale"
msgstr "Näytä soiva kappale"
#, qt-format
msgid "Keep buttons for %1 second..."
@ -1643,7 +1643,7 @@ msgid "Library rescan notice"
msgstr "Ilmoitus kirjaston läpikäynnistä"
msgid "Library search"
msgstr "Kirjastohaku"
msgstr "Haku kirjastosta"
msgid "Limits"
msgstr "Rajat"
@ -1771,7 +1771,7 @@ msgid "Manufacturer"
msgstr "Valmistaja"
msgid "Match every search term (AND)"
msgstr "Täyttää jokaisen hakuehdon (AND)"
msgstr "Täsmää jokaiseen hakuehtoon (AND)"
msgid "Match one or more search terms (OR)"
msgstr "Täyttää yhden tai useampia hakuehtoja (OR)"
@ -1917,7 +1917,7 @@ msgstr "Ei pitkiä lohkoja"
msgid ""
"No matches found. Clear the search box to show the whole playlist again."
msgstr "Ei osumia haulle. Tyhjennä hakukenttä näyttääksesi koko soittolistan uudelleen."
msgstr "Ei osumia. Tyhjennä hakukenttä ja koko soittolista näytetään uudelleen."
msgid "No short blocks"
msgstr "Ei lyhyitä lohkoja"
@ -1953,7 +1953,7 @@ msgid "Not installed"
msgstr "Ei asennettu"
msgid "Not mounted - double click to mount"
msgstr "Ei liitetty - kaksoisnapsauta liittääksesi"
msgstr "Ei liitetty - paina kahdesti ja yhdistä"
msgid "Notification type"
msgstr "Ilmoituksen tyyppi"
@ -1984,7 +1984,7 @@ msgid "Open %1 in browser"
msgstr "Avaa %1 selaimessa"
msgid "Open &audio CD..."
msgstr "Avaa &ääni-CD..."
msgstr "Avaa &audio CD..."
msgid "Open device"
msgstr "Avaa laite"
@ -2083,7 +2083,7 @@ msgid "Play Artist or Tag"
msgstr "Toista esittäjä tai tunniste"
msgid "Play artist radio..."
msgstr "Toista esittäjä radiota..."
msgstr "Toista esittäjää radiosta..."
msgid "Play count"
msgstr "Soittokertoja"
@ -2101,7 +2101,7 @@ msgid "Play if there is nothing already playing"
msgstr "Aloita toisto, jos mikään ei soi parhaillaan"
msgid "Play last.fm artist radio"
msgstr "Toista last.fm esittäjä radiota"
msgstr "Toista esittäjää last.fm radiosta"
msgid "Play last.fm tag radio"
msgstr "Toista last.fm tunniste radiota"
@ -2164,7 +2164,7 @@ msgid "Preferred album art filenames (comma separated)"
msgstr "Ensisijainen tiedostonimi albumikuvitukselle (pilkuin eroteltu)"
msgid "Preferred audio format"
msgstr "Ensisijainen äänimuoto"
msgstr "Ensisijainen audio formaatti"
msgid "Preferred format"
msgstr "Ensisijainen muoto"
@ -2204,7 +2204,7 @@ msgid "Progress"
msgstr "Edistyminen"
msgid "Push Wiiremote button"
msgstr "Paina Wii Remoten nappia"
msgstr "Paina Wii Remote nappia"
msgid "Put songs in a random order"
msgstr "Aseta kappaleet satunnaiseen järjestykseen"
@ -2555,7 +2555,7 @@ msgid "Show in various artists"
msgstr "Näytä kohdassa \"Useita esittäjiä\""
msgid "Show only duplicates"
msgstr "Näytä vain kaksoiskappaleet"
msgstr "Näytä kaksoiskappaleet"
msgid "Show only untagged"
msgstr "Näytä vain vailla tunnistetta olevat"
@ -2643,10 +2643,10 @@ msgid "Sorry"
msgstr "Pahoittelut"
msgid "Sort by genre (alphabetically)"
msgstr "Järjestä tyylin mukaan (aakkosjärjestyksessä)"
msgstr "Järjestä tyyli (aakkosjen mukaan)"
msgid "Sort by genre (by popularity)"
msgstr "Järjestä tyylin mukaan (Järjestä suosion mukaan)"
msgstr "Järjestä tyyli (suosion mukaan)"
msgid "Sort by station name"
msgstr "Järjestä aseman nimen mukaan"
@ -2682,13 +2682,13 @@ msgid "Start the playlist currently playing"
msgstr "Käynnistä toistettava soittolista"
msgid "Start transcoding"
msgstr "Aloita muunnos"
msgstr "Aloita muuntaminen"
msgid "Start typing in the search box above to find music on Grooveshark."
msgstr "Kirjoita yllä olevaan hakukenttään ja löydät musiikkia Grooveshark:sta."
msgstr "Kirjoita hakukenttään ja löydät musiikkia Grooveshark:sta."
msgid "Start typing in the search box above to find music on Spotify."
msgstr "Kirjoita yllä olevaan hakukenttään ja löydät musiikkia Spotify:sta."
msgstr "Kirjoita hakukenttään ja löydät musiikkia Spotify:sta."
#, qt-format
msgid "Starting %1"
@ -2742,7 +2742,7 @@ msgid "Supported formats"
msgstr "Tuetut muodot"
msgid "Switch provider"
msgstr "Vaihda palveluntarjoajaa"
msgstr "Vaihda palvelua"
msgid "Syncing Spotify inbox"
msgstr "Synkronoi Spotify saapuneet"
@ -2839,7 +2839,7 @@ msgstr "Kolmas taso"
msgid ""
"This action will create a database which could be as big as 150 MB.\n"
"Do you want to continue anyway?"
msgstr "Tämä toiminto luo tietokannan, jonka koko voi olla jopa 150 megatavua.\nHaluatko silti jatkaa?"
msgstr "Tämä luo tietokannan, jonka koko voi olla jopa 150 megatavua.\nHaluatko jatkaa?"
msgid "This album is not available in the requested format"
msgstr "Tämä albumi ei ole saatavilla haluamassasi muodossa"
@ -2922,7 +2922,7 @@ msgid "Transcoder Log"
msgstr "Muunnosloki"
msgid "Transcoding"
msgstr "Muunnos"
msgstr "Muuntaminen"
#, qt-format
msgid "Transcoding %1 files using %2 threads"
@ -3132,7 +3132,7 @@ msgid "Windows Media 64k (Premium only)"
msgstr "Windows Media 64k (vain Premium)"
msgid "Windows Media audio"
msgstr "Windows Media -ääni"
msgstr "Windows Media audio"
msgid "Would you like to run a full rescan right now?"
msgstr "Haluatko suorittaa kirjaston läpikäynnin nyt?"
@ -3176,7 +3176,7 @@ msgid ""
msgstr "Voit kuunnella Magnatune-kappaleita ilmaiseksi ilman tunnusta. Jäsenyyden osto poistaa viestit kappaleiden lopusta."
msgid "You can listen to background streams at the same time as other music."
msgstr "Voit kuunnella taustaääniä samalla kun kuuntelet haluamaasi kappaletta."
msgstr "Voit kuulla taustaääniä samanaikaisesti muun musiikin kanssa."
msgid ""
"You can scrobble tracks for free, but only <span style=\" font-"

View File

@ -24,7 +24,7 @@ msgstr ""
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Language: he\n"
"Plural-Forms: nplurals=4; plural=(n == 1 && n % 1 == 0) ? 0 : (n == 2 && n % 1 == 0) ? 1: (n % 10 == 0 && n % 1 == 0 && n > 10) ? 2 : 3;\n"
"Plural-Forms: nplurals=3; plural=(n == 1 && n % 1 == 0) ? 0 : (n == 2 && n % 1 == 0) ? 1: 2;\n"
"X-Generator: Launchpad (build 13168)\n"
"X-Launchpad-Export-Date: 2011-06-27 04:53+0000\n"

View File

@ -15,7 +15,7 @@ msgstr ""
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Language: he_IL\n"
"Plural-Forms: nplurals=4; plural=(n == 1 && n % 1 == 0) ? 0 : (n == 2 && n % 1 == 0) ? 1: (n % 10 == 0 && n % 1 == 0 && n > 10) ? 2 : 3;\n"
"Plural-Forms: nplurals=3; plural=(n == 1 && n % 1 == 0) ? 0 : (n == 2 && n % 1 == 0) ? 1: 2;\n"
"X-Generator: Launchpad (build 13168)\n"
"X-Launchpad-Export-Date: 2011-06-27 04:53+0000\n"

File diff suppressed because it is too large Load Diff

View File

@ -4,7 +4,7 @@
#
# Translators:
# Baiba Bērziņa <baibabeerzinnaa@gmail.com>, 2015
# Eduards 963, 2023
# Eduards Lasmanis, 2023
# FIRST AUTHOR <EMAIL@ADDRESS>, 2011
# Gatis Kalniņš <>, 2014
# Kristaps, 2012
@ -16,7 +16,7 @@ msgstr ""
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2011-04-09 10:24+0000\n"
"PO-Revision-Date: 2011-10-27 18:53+0000\n"
"Last-Translator: Eduards 963, 2023\n"
"Last-Translator: Eduards Lasmanis, 2023\n"
"Language-Team: Latvian (http://app.transifex.com/davidsansome/clementine/language/lv/)\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"

View File

@ -7,7 +7,7 @@
# arnaudbienner <arnaud.bienner@gmail.com>, 2011
# arnaudbienner <arnaud.bienner@gmail.com>, 2011
# FIRST AUTHOR <EMAIL@ADDRESS>, 2010
# Hugo Carvalho <hugokarvalho@hotmail.com>, 2015,2020-2023
# Hugo Carvalho <hugokarvalho@hotmail.com>, 2015,2020-2024
# João Santos <joaoopsantos@gmail.com>, 2015
# Rui <xymarior@yandex.com>, 2019
# Alexandro Casanova <shorterfire@gmail.com>, 2013
@ -18,7 +18,7 @@ msgstr ""
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2011-04-09 10:24+0000\n"
"PO-Revision-Date: 2011-10-27 18:53+0000\n"
"Last-Translator: Hugo Carvalho <hugokarvalho@hotmail.com>, 2015,2020-2023\n"
"Last-Translator: Hugo Carvalho <hugokarvalho@hotmail.com>, 2015,2020-2024\n"
"Language-Team: Portuguese (http://app.transifex.com/davidsansome/clementine/language/pt/)\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
@ -61,7 +61,7 @@ msgstr "%1 listas de reprodução (%2)"
#, qt-format
msgid "%1 selected of"
msgstr ""
msgstr "%1 selecionada(s) de"
#, qt-format
msgid "%1 song"
@ -185,10 +185,10 @@ msgid ""
msgstr "<p>Os \"tokens\" iniciam com %, por exemplo: %artist %album %title </p>\n\n<p>Ao colocar parênteses entre as secções de texto que contêm \"tokens\", essa secção será ocultada se o \"token\" estiver vazio</p>"
msgid "A Grooveshark Anywhere account is required."
msgstr ""
msgstr "Requer uma conta Grooveshark Anywhere"
msgid "A Spotify Premium account is required."
msgstr ""
msgstr "Requer uma conta Spotify Premium."
msgid ""
"A smart playlist is a dynamic list of songs that come from your library. "
@ -207,13 +207,13 @@ msgid "AAC"
msgstr "AAC"
msgid "AAC 128k (Premium only)"
msgstr ""
msgstr "AAC 128k (Premium)"
msgid "AAC 32k"
msgstr "AAC 32k"
msgid "AAC 64k (Premium only)"
msgstr ""
msgstr "AAC 64k (Premium)"
msgid "AIFF"
msgstr "AIFF"
@ -241,7 +241,7 @@ msgid "Action"
msgstr "Ação"
msgid "Active/deactive Wiiremote"
msgstr ""
msgstr "Ativar/desativar Wiiremote"
msgid "Add Stream"
msgstr "Adicionar emissão"
@ -253,7 +253,7 @@ msgid "Add action"
msgstr "Adicionar uma ação"
msgid "Add and play now"
msgstr ""
msgstr "Adicionar e reproduzir"
msgid "Add another stream..."
msgstr "Adicionar outra emissão..."
@ -274,7 +274,7 @@ msgid "Add folder..."
msgstr "Adicionar diretório..."
msgid "Add media"
msgstr ""
msgstr "Adicionar ficheiros"
msgid "Add new folder..."
msgstr "Adicionar novo diretório..."
@ -334,7 +334,7 @@ msgid "Add wiimotedev action"
msgstr "Adicionar uma ação wiimotedev"
msgid "Add..."
msgstr ""
msgstr "Adicionar..."
msgid "Added this month"
msgstr "Adicionadas este mês"
@ -370,7 +370,7 @@ msgid "Album info on jamendo.com..."
msgstr "Informações do álbum em jamendo.com..."
msgid "Albumartist"
msgstr ""
msgstr "Álbum - artista"
msgid "Albums with covers"
msgstr "Álbuns com capas"

View File

@ -8,7 +8,7 @@
# Iavael, 2012
# Alexander Vysotskiy <loki13gm@gmail.com>, 2012
# Andrei Demin <Andrei.Demin1996@gmail.com>, 2014
# Andrei Stepanov, 2014-2023
# Andrei Stepanov, 2014-2024
# Andy Dufrane <>, 2012
# arnaudbienner <arnaud.bienner@gmail.com>, 2011
# Camellan <camellan@yandex.ru>, 2018
@ -39,7 +39,7 @@ msgstr ""
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2011-04-09 10:24+0000\n"
"PO-Revision-Date: 2011-10-27 18:53+0000\n"
"Last-Translator: Andrei Stepanov, 2014-2023\n"
"Last-Translator: Andrei Stepanov, 2014-2024\n"
"Language-Team: Russian (http://app.transifex.com/davidsansome/clementine/language/ru/)\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
@ -481,10 +481,10 @@ msgstr "Применять сжатие для предотвращения ис
#, qt-format
msgid "Are you sure you want to delete the \"%1\" preset?"
msgstr "Вы действительно хотите удалить предустановку «%1»?"
msgstr "Уверены, что хотите удалить предустановку «%1»?"
msgid "Are you sure you want to reset this song's statistics?"
msgstr "Вы действительно хотите сбросить статистику этой песни?"
msgstr "Уверены, что хотите сбросить статистику этой песни?"
msgid "Artist"
msgstr "Артист"
@ -1209,7 +1209,7 @@ msgid "Except between tracks on the same album or in the same CUE sheet"
msgstr "Кроме треков с одних и тех же альбома или CUE-файла"
msgid "&Extras"
msgstr "&Дополнения"
msgstr "&Фон"
msgid "F1"
msgstr "F1"
@ -2416,7 +2416,7 @@ msgid "Save this stream in the Internet tab"
msgstr "Сохранить этот поток во вкладке Интернет"
msgid "Saving tracks"
msgstr "Сохранение треков"
msgstr "Сохраняются треки"
msgid "Scalable sampling rate profile (SSR)"
msgstr "Профиль Scalable sampling rate (SSR)"
@ -2846,7 +2846,7 @@ msgstr "Эти файлы будут удалены с диска. Хотите
msgid ""
"These files will be deleted from the device, are you sure you want to "
"continue?"
msgstr "Эти файлы будут удалены с устройства. Вы действительно хотите продолжить?"
msgstr "Эти файлы будут удалены с устройства. Хотите продолжить?"
msgid "These folders will be scanned for music to make up your library"
msgstr "В этих папках происходит поиск музыки для создания вашей фонотеки"

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -321,7 +321,7 @@ msgid "Add song length tag"
msgstr "Lägg till tagg för låtens längd"
msgid "Add song play count"
msgstr "Lägg till spelningsantal"
msgstr "Lägg till antal spelningar av låtar"
msgid "Add song skip count"
msgstr "Lägg till antal överhoppningar"
@ -2367,7 +2367,7 @@ msgid "Reset"
msgstr "Återställ"
msgid "Reset play counts"
msgstr "Återställ spelningsantal"
msgstr "Återställ antal spelningar"
msgid "Restrict to ASCII characters"
msgstr "Begränsa till ASCII-tecken"