/* * Copyright (C) 2005-2018 Team Kodi * This file is part of Kodi - https://kodi.tv * * SPDX-License-Identifier: GPL-2.0-or-later * See LICENSES/README.md for more information. */ #pragma once /*! \file Album.h \brief */ #include "Artist.h" #include "Song.h" #include "XBDateTime.h" #include "utils/ScraperUrl.h" #include #include class TiXmlNode; class CFileItem; class CAlbum { public: explicit CAlbum(const CFileItem& item); CAlbum() = default; bool operator<(const CAlbum &a) const; void MergeScrapedAlbum(const CAlbum& album, bool override = true); void Reset() { idAlbum = -1; strAlbum.clear(); strMusicBrainzAlbumID.clear(); strReleaseGroupMBID.clear(); artistCredits.clear(); strArtistDesc.clear(); strArtistSort.clear(); genre.clear(); thumbURL.Clear(); moods.clear(); styles.clear(); themes.clear(); art.clear(); strReview.clear(); strLabel.clear(); strType.clear(); strReleaseStatus.clear(); strPath.clear(); fRating = -1; iUserrating = -1; iVotes = -1; strOrigReleaseDate.clear(); strReleaseDate.clear(); bCompilation = false; bBoxedSet = false; iTimesPlayed = 0; dateAdded.Reset(); dateUpdated.Reset(); dateNew.Reset(); lastPlayed.Reset(); iTotalDiscs = -1; songs.clear(); releaseType = Album; strLastScraped.clear(); bScrapedMBID = false; bArtistSongMerge = false; iAlbumDuration = 0; } /*! \brief Get album artist names from the vector of artistcredits objects \return album artist names as a vector of strings */ const std::vector GetAlbumArtist() const; /*! \brief Get album artist MusicBrainz IDs from the vector of artistcredits objects \return album artist MusicBrainz IDs as a vector of strings */ const std::vector GetMusicBrainzAlbumArtistID() const; std::string GetGenreString() const; /*! \brief Get album artist names from the artist description string (if it exists) or concatenated from the vector of artistcredits objects \return album artist names as a single string */ const std::string GetAlbumArtistString() const; /*! \brief Get album artist sort name from the artist sort string (if it exists) or concatenated from the vector of artistcredits objects \return album artist sort names as a single string */ const std::string GetAlbumArtistSort() const; /*! \brief Get album artist IDs (for json rpc) from the vector of artistcredits objects \return album artist IDs as a vector of integers */ const std::vector GetArtistIDArray() const; typedef enum ReleaseType { Album = 0, Single } ReleaseType; std::string GetReleaseType() const; void SetReleaseType(const std::string& strReleaseType); void SetDateAdded(const std::string& strDateAdded); void SetDateUpdated(const std::string& strDateUpdated); void SetDateNew(const std::string& strDateNew); void SetLastPlayed(const std::string& strLastPlayed); static std::string ReleaseTypeToString(ReleaseType releaseType); static ReleaseType ReleaseTypeFromString(const std::string& strReleaseType); /*! \brief Set album artist credits using the arrays of tag values. If strArtistSort (as from ALBUMARTISTSORT tag) is already set then individual artist sort names are also processed. \param names String vector of albumartist names (as from ALBUMARTIST tag) \param hints String vector of albumartist name hints (as from ALBUMARTISTS tag) \param mbids String vector of albumartist Musicbrainz IDs (as from MUSICBRAINZABUMARTISTID tag) \param artistnames String vector of artist names (as from ARTIST tag) \param artisthints String vector of artist name hints (as from ARTISTS tag) \param artistmbids String vector of artist Musicbrainz IDs (as from MUSICBRAINZARTISTID tag) */ void SetArtistCredits(const std::vector& names, const std::vector& hints, const std::vector& mbids, const std::vector& artistnames = std::vector(), const std::vector& artisthints = std::vector(), const std::vector& artistmbids = std::vector()); /*! \brief Load album information from an XML file. See CVideoInfoTag::Load for a description of the types of elements we load. \param element the root XML element to parse. \param append whether information should be added to the existing tag, or whether it should be reset first. \param prioritise if appending, whether additive tags should be prioritised (i.e. replace or prepend) over existing values. Defaults to false. \sa CVideoInfoTag::Load */ bool Load(const TiXmlElement *element, bool append = false, bool prioritise = false); bool Save(TiXmlNode *node, const std::string &tag, const std::string& strPath); int idAlbum = -1; std::string strAlbum; std::string strMusicBrainzAlbumID; std::string strReleaseGroupMBID; std::string strArtistDesc; std::string strArtistSort; VECARTISTCREDITS artistCredits; std::vector genre; CScraperUrl thumbURL; std::vector moods; std::vector styles; std::vector themes; std::map art; std::string strReview; std::string strLabel; std::string strType; std::string strReleaseStatus; std::string strPath; float fRating = -1; int iUserrating = -1; int iVotes = -1; std::string strReleaseDate; std::string strOrigReleaseDate; bool bBoxedSet = false; bool bCompilation = false; int iTimesPlayed = 0; CDateTime dateAdded; // From related file creation or modification times, or when (re-)scanned CDateTime dateUpdated; // Time db record Last modified CDateTime dateNew; // Time db record created CDateTime lastPlayed; int iTotalDiscs = -1; VECSONGS songs; ///< Local songs ReleaseType releaseType = Album; std::string strLastScraped; bool bScrapedMBID = false; bool bArtistSongMerge = false; int iAlbumDuration = 0; }; typedef std::vector VECALBUMS;