mirror of
https://bitbucket.org/smil3y/kdelibs.git
synced 2025-02-24 10:52:49 +00:00
212 lines
6.1 KiB
C++
212 lines
6.1 KiB
C++
/*
|
|
Copyright (C) 2002 Rik Hemsley (rikkus) <rik@kde.org>
|
|
Copyright (C) 2002-2005 Benjamin Meyer <ben-devel@meyerhome.net>
|
|
Copyright (C) 2002-2004 Nadeem Hasan <nhasan@nadmm.com>
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Library General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2 of the License, or (at your option) any later version.
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Library General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public License
|
|
along with this library; see the file COPYING.LIB. If not, write to
|
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
Boston, MA 02110-1301, USA.
|
|
*/
|
|
|
|
#ifndef KCDDB_CDINFO_H
|
|
#define KCDDB_CDINFO_H
|
|
|
|
#include <QtCore/QStringList>
|
|
#include <QtCore/QVariant>
|
|
#include <libkcddb/kcddb_export.h>
|
|
|
|
namespace KCDDB
|
|
{
|
|
/**
|
|
* The most common types
|
|
*/
|
|
enum Type
|
|
{
|
|
Title, /**< The title of the track or CD */
|
|
Comment, /**< A comment for the track or CD */
|
|
Artist, /**< The artist of the track or CD */
|
|
Genre, /**< The genre of the track or CD */
|
|
Year, /**< The year the cd or track was produced
|
|
By default, the year of the track is the
|
|
same as for the whole cd
|
|
@todo Doesn't do that for tracks right now.*/
|
|
Length, /**< The length of a track or a full CD
|
|
@todo In what unit? */
|
|
Category /**< The freedb category of the entry.
|
|
Needs to be one of: blues, classical,
|
|
country, data, fold, jazz, misc, newage,
|
|
reggae, rock, soundtrack */
|
|
};
|
|
|
|
/**
|
|
* Information about a sepecific track in a cd.
|
|
*/
|
|
class KCDDB_EXPORT TrackInfo
|
|
{
|
|
public:
|
|
|
|
TrackInfo();
|
|
virtual ~TrackInfo();
|
|
TrackInfo(const TrackInfo& clone);
|
|
TrackInfo& operator=(const TrackInfo& clone);
|
|
|
|
bool operator==(const TrackInfo&) const;
|
|
bool operator!=(const TrackInfo&) const;
|
|
|
|
/**
|
|
* Get data for type that has been assigned to this track.
|
|
* @p type is case insensitive.
|
|
* For example <code>get("title")</code>
|
|
*/
|
|
QVariant get(const QString &type) const;
|
|
/**
|
|
* Helper function that calls type with the common name
|
|
*/
|
|
QVariant get(Type type) const;
|
|
|
|
/**
|
|
* Set any data from this track.
|
|
* @p type is case insensitive.
|
|
* For example <code>set("title", "Rock this world")</code>
|
|
* Useful for atributes that other apps want to add.
|
|
* Data will be stored in the local cddb cache, but not sent to the cddb server
|
|
*/
|
|
void set(const QString &type, const QVariant &data);
|
|
/**
|
|
* Helper function that calls type with the common name
|
|
*/
|
|
void set(Type type, const QVariant &data);
|
|
|
|
/**
|
|
* @return a CDDB compatible string of all the data assigned to this track
|
|
* tracknumber must be assigned before calling this.
|
|
*/
|
|
QString toString() const;
|
|
|
|
/**
|
|
* internal
|
|
*/
|
|
void clear();
|
|
|
|
private:
|
|
class TrackInfoPrivate *d;
|
|
|
|
};
|
|
|
|
typedef QList<TrackInfo> TrackInfoList;
|
|
|
|
/**
|
|
* Information about a CD
|
|
*
|
|
* Typically CDInfo is obtained from the client such as:
|
|
* <code>KCDDB::Client *cddb = new KCDDB::Client();
|
|
* cddb->lookup(discSignature);
|
|
* CDInfo info = cddb->lookupResponse().first();</code>
|
|
*/
|
|
class KCDDB_EXPORT CDInfo
|
|
{
|
|
public:
|
|
CDInfo();
|
|
virtual ~CDInfo();
|
|
|
|
CDInfo(const CDInfo& clone);
|
|
CDInfo& operator=(const CDInfo& clone);
|
|
|
|
bool operator==(const CDInfo&) const;
|
|
bool operator!=(const CDInfo&) const;
|
|
|
|
/**
|
|
* Load CDInfo from a string that is CDDB compatible
|
|
* @return true if successful
|
|
*/
|
|
bool load(const QString &string);
|
|
/**
|
|
* Load CDInfo from a stringList that is CDDB compatible
|
|
* @return true if successful
|
|
*/
|
|
bool load(const QStringList &stringList);
|
|
|
|
/**
|
|
* Clear all information, setting this to invalid
|
|
* internal
|
|
*/
|
|
void clear();
|
|
|
|
/**
|
|
* @return true if the cd information is valid
|
|
*/
|
|
bool isValid() const;
|
|
|
|
/**
|
|
* @param submit If submit is true only returns CDDB compatible information
|
|
* @return a string containing all of the CD's information.
|
|
*/
|
|
QString toString(bool submit=false) const;
|
|
|
|
/**
|
|
* Get data for type that has been assigned to this disc.
|
|
* @p type is case insensitive.
|
|
* For example <code>get("title")</code>
|
|
*/
|
|
QVariant get(const QString &type) const;
|
|
/**
|
|
* Helper function that calls type with the common name
|
|
*/
|
|
QVariant get(Type type) const;
|
|
|
|
/**
|
|
* Set any data from this disc.
|
|
* @p type is case insensitive.
|
|
* For example <code>set("title", "Rock this world")</code>
|
|
* Useful for atributes that other apps want to add.
|
|
* Data will be stored in the local cddb cache, but not sent to the cddb server
|
|
*/
|
|
void set(const QString &type, const QVariant &data);
|
|
/**
|
|
* Helper function that calls type with the common name
|
|
*/
|
|
void set(Type type, const QVariant &data);
|
|
|
|
/**
|
|
* Returns track with nr @p trackNumber and adds it to
|
|
* the track list if it doesn't exist (first track is 0)
|
|
*/
|
|
TrackInfo & track( int trackNumber );
|
|
|
|
/**
|
|
* Returns a const track with nr @p trackNumber
|
|
* or a new if it doesn't exist (first track is 0)
|
|
*/
|
|
TrackInfo track( int trackNumber ) const;
|
|
|
|
/**
|
|
* Returns number of tracks on CD
|
|
*/
|
|
int numberOfTracks() const;
|
|
|
|
protected:
|
|
/**
|
|
* Checks to make sure that trackNumber exists
|
|
*/
|
|
void checkTrack( int trackNumber );
|
|
|
|
private:
|
|
class CDInfoPrivate * const d;
|
|
};
|
|
|
|
typedef QList<CDInfo> CDInfoList;
|
|
}
|
|
|
|
#endif // KCDDB_CDINFO_H
|
|
// vim:tabstop=2:shiftwidth=2:expandtab:cinoptions=(s,U1,m1
|