/usr/include/qmmpui/metadataformatter.h is in qmmp 1.0.5-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 | /***************************************************************************
* 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 <QString>
#include <QMap>
#include <QList>
#include <qmmpui/playlisttrack.h>
#include <qmmp/qmmp.h>
/*! @brief The MetaDataFormatter formats metadata using templates.
* @author Ilya Kotov <forkotov02@hotmail.ru>
*/
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,
* %I - track index,
* %if(A,B,C) or %if(A&B&C,D,E) - condition.
*/
MetaDataFormatter(const QString &pattern = QString());
/*!
* Setups metadata template.
* @param pattern Metadata template string.
*/
void setPattern(const QString &pattern);
/*!
* Returns metadata template.
*/
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.
* @param track Index of track.
*/
QString format(const QMap<Qmmp::MetaData, QString> &metaData, qint64 length = 0, int track = 0) const;
/*!
* Returns formatted length (example: 05:02:03).
* \param length Length in seconds.
*/
static QString formatLength(qint64 length);
private:
struct Node;
struct Param;
struct Node
{
enum {
PRINT_TEXT = 0,
IF_KEYWORD,
OR_OPERATOR,
AND_OPERATOR
} command;
QList<Param> params;
};
struct Param
{
enum {
FIELD = 0,
TEXT,
NODES
} type;
//extra fields
enum
{
TWO_DIGIT_TRACK = Qmmp::URL + 1,
DURATION,
FILE_NAME,
TRACK_INDEX
};
int field;
QString text;
QList<Node> children;
};
bool parseField(QList<Node> *nodes, QString::const_iterator *i, QString::const_iterator end);
bool parseIf(QList<Node> *nodes, QString::const_iterator *i, QString::const_iterator end);
void parseText(QList<Node> *nodes, QString::const_iterator *i, QString::const_iterator end);
void parseEscape(QList<Node> *nodes, QString::const_iterator *i, QString::const_iterator end);
QString evalute(const QList<Node> *nodes, const QMap<Qmmp::MetaData, QString> *metaData, qint64 length, int track) const;
QString printParam(Param *p, const QMap<Qmmp::MetaData, QString> *metaData, qint64 length, int track) const;
QString printField(int field, const QMap<Qmmp::MetaData, QString> *metaData, qint64 length, int track) const;
QString dumpNode(Node node) const;
QList<MetaDataFormatter::Node> compile(const QString &expr);
QString m_pattern;
QList<MetaDataFormatter::Node> m_nodes;
QMap<QString, int> m_fieldNames;
};
#endif // METADATAFORMATTER2_H
|