/*************************************************************************** * Copyright (C) 2015 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * * (at your option) any later version. * * * * This program 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 General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ #ifndef METADATAFORMATTER_H #define METADATAFORMATTER_H #include #include #include #include #include /*! @brief The MetaDataFormatter formats metadata using templates. * @author Ilya Kotov */ class MetaDataFormatter { public: /*! * Constructor. * @param pattern Metadata template. * Syntax: * %p - artist, * %a - album, * %aa - album artist, * %t - title, * %n - track number, * %NN - 2-digit track number, * %g - genre, * %c - comment, * %C - composer, * %D - disc number, * %f - file name, * %F - full path, * %y - year, * %l - duration, * %if(A,B,C) or %if(A&B&C,D,E) - condition. */ MetaDataFormatter(const QString &pattern = QString()); void setPattern(const QString &pattern); const QString pattern() const; /*! * Converts metadata of item \b item to one string using template. */ QString format(const PlayListTrack *item) const; /*! * Converts metadata to one string using template. * @param metaData Metadata array. * @param length Length in seconds. */ QString format(const QMap &metaData, qint64 length = 0) const; /*! * Returns formatted length (example: 05:02:03). * \param length Length in seconds. */ QString formatLength(qint64 length) const; private: struct Node; struct Param; struct Node { enum { PRINT_TEXT = 0, IF_KEYWORD, OR_OPERATOR, AND_OPERATOR } command; QList params; }; struct Param { enum { FIELD = 0, TEXT, NODES } type; //extra fields enum { TWO_DIGIT_TRACK = Qmmp::URL + 1, DURATION, FILE_NAME }; int field; QString text; QList children; }; bool parseField(QList *nodes, QString::const_iterator *i, QString::const_iterator end); bool parseIf(QList *nodes, QString::const_iterator *i, QString::const_iterator end); void parseText(QList *nodes, QString::const_iterator *i, QString::const_iterator end); void parseEscape(QList *nodes, QString::const_iterator *i, QString::const_iterator end); QString evalute(const QList *nodes, const QMap *metaData, qint64 length) const; QString printParam(Param *p, const QMap *metaData, qint64 length) const; QString printField(int field, const QMap *metaData, qint64 length) const; QString dumpNode(Node node) const; QList compile(const QString &expr); QString m_pattern; QList m_nodes; QMap m_fieldNames; }; #endif // METADATAFORMATTER2_H