9
|
1 |
/*
|
|
2 |
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
|
|
3 |
* All rights reserved.
|
|
4 |
*
|
|
5 |
* This program is free software: you can redistribute it and/or modify
|
|
6 |
* it under the terms of the GNU Lesser General Public License as published by
|
|
7 |
* the Free Software Foundation, version 2.1 of the License.
|
|
8 |
*
|
|
9 |
* This program is distributed in the hope that it will be useful,
|
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
12 |
* GNU Lesser General Public License for more details.
|
|
13 |
*
|
|
14 |
* You should have received a copy of the GNU Lesser General Public License
|
|
15 |
* along with this program. If not,
|
|
16 |
* see "http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html/".
|
|
17 |
*
|
|
18 |
*/
|
|
19 |
#ifndef XBELWRITER_H
|
|
20 |
#define XBELWRITER_H
|
|
21 |
|
|
22 |
class BookmarksManager;
|
|
23 |
class BookmarkFav;
|
|
24 |
class QXmlStreamWriter;
|
|
25 |
class QIODevice;
|
|
26 |
|
|
27 |
/*
|
|
28 |
* This will export all bookmarks
|
|
29 |
* Each tag will be treated as a folder, so the bookmarks will be output by tag
|
|
30 |
* (there will be duplicates if a bookmark has more than one tag)
|
|
31 |
* Then any bookmarks that don't have tags will be written out into the top level
|
|
32 |
*/
|
|
33 |
class XbelWriter
|
|
34 |
{
|
|
35 |
public: // ctor/dtor
|
|
36 |
XbelWriter(BookmarksManager *bmgr);
|
|
37 |
virtual ~XbelWriter();
|
|
38 |
|
|
39 |
public: // members
|
|
40 |
bool writeFile(QIODevice *device);
|
|
41 |
|
|
42 |
private:
|
|
43 |
void writeBookmark(BookmarkFav * bm);
|
|
44 |
void writeTags(int bmId);
|
|
45 |
|
|
46 |
QXmlStreamWriter *m_xml;
|
|
47 |
BookmarksManager *m_bmgr;
|
|
48 |
};
|
|
49 |
|
|
50 |
#endif
|