File: BatchFile.h

package info (click to toggle)
amarok 3.3.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 112,344 kB
  • sloc: cpp: 195,053; xml: 4,329; ansic: 2,634; javascript: 673; ruby: 528; python: 507; sh: 252; makefile: 12
file content (69 lines) | stat: -rw-r--r-- 2,620 bytes parent folder | download | duplicates (2)
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
/***************************************************************************
 *   Copyright (C) 2010 Ralf Engels <ralf-engels@gmx.de>                   *
 *                                                                         *
 *   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 COLLECTIONSCANNER_BATCHFILE_H
#define COLLECTIONSCANNER_BATCHFILE_H

#include "amarokshared_export.h"

#include <QString>
#include <QStringList>
#include <QPair>
#include <QList>

namespace CollectionScanner
{


/**
 * @class BatchFile
 * @short This class can be used to read and write batch files for the collection scanner.
 */

class AMAROKSHARED_EXPORT BatchFile
{
public:
    /** Constructs and empty BatchFile */
    BatchFile();

    /** Reads the BatchFile from the disk */
    explicit BatchFile( const QString &path );

    /** This type is a pair of directory path and modification time */
    typedef QPair<QString, uint> TimeDefinition;

    /** Those are the directories that should be added to the scanning list */
    const QStringList &directories() const;
    void setDirectories( const QStringList &value );

    const QList<TimeDefinition> &timeDefinitions() const;
    void setTimeDefinitions( const QList<TimeDefinition> &value );

    /** Writes the BatchFile to the disk.
        @returns true if writing was successful.
    */
    bool write( const QString &path );

private:
    QStringList m_directories;
    QList<TimeDefinition> m_timeDefinitions;
};

}
#endif // COLLECTIONSCANNER_BATCHFILE_H