/** * @file * Copyright 2014 (c) Anna Schumaker. */ #ifndef OCARINA_CORE_TAGS_ALBUM_H #define OCARINA_CORE_TAGS_ALBUM_H #include /** * The Album tag is used to store the name and year of albums * added to the tag database. * * When writing an Album tag to disk, write out the _year field and * then call GenericTag to write anything else. * * ... << year1 << GenericTag::write() * ... << year2 << GenericTag::write() * ... << year3 << GenericTag::write() */ class Album : public GenericTag { private: unsigned int _year; /**< The year associated with this Album. */ public: Album(); /**< Album tag constructor */ /** * Album tag constructor * * @param name Album name * @param year Album year */ Album(const std::string &, unsigned int); /** * The album's primary key is the concatenation of year * and name, allowing for multiple albums with the same * name but released at different times. * * @return Album::_year / GenericTag::primary_key() (Example: "1998/Hyrule Symphony") */ const std::string primary_key() const; /** * Read album information from file. * * @param file The file to read from. */ void read(File &); /** * Write album information to file. * * @param file The file to write to. */ void write(File &); /** * Called to access the year associated with this album. * * @return Album::_year. */ unsigned int year(); }; #endif /* OCARINA_CORE_TAGS_ALBUM_H */