blob: 0e516ee090bda7af228825d509c4c8a0899b1415 (
plain)
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
|
/*********
*
* This file is part of BibleTime's source code, http://www.bibletime.info/.
*
* Copyright 1999-2006 by the BibleTime developers.
* The BibleTime source code is licensed under the GNU General Public License version 2.0.
*
**********/
#include "cprofilemgr.h"
//Qt includes
#include <tqdir.h>
#include <tqfile.h>
#include <tqptrlist.h>
//KDE includes
#include <kstandarddirs.h>
namespace Profile {
CProfileMgr::CProfileMgr() : m_startupProfile(0) {
m_profiles.setAutoDelete(true);
KStandardDirs stdDirs;
m_profilePath = stdDirs.saveLocation("data", "bibletime/sessions/");
TQDir d( m_profilePath );
TQStringList files = d.entryList("*.xml");
for ( TQStringList::Iterator it = files.begin(); it != files.end(); ++it ) {
if ((*it) != "_startup_.xml") {
m_profiles.append(new CProfile(m_profilePath + *it));
}
else {
m_startupProfile = new CProfile(m_profilePath + *it);
}
}
}
CProfileMgr::~CProfileMgr() {
m_profiles.clear(); // autoDelete is enabled, so all profiles are deleted
delete m_startupProfile;
}
/** Returns a list of available profiles. */
const TQPtrList<CProfile>& CProfileMgr::profiles() {
return m_profiles;
}
/** Creates a new profile with the name "name" (first parameter). @return The profile object */
CProfile* CProfileMgr::create( const TQString name ) {
CProfile* p = new CProfile(TQString::null, name);
m_profiles.append(p);
return p;
}
/** Removes the profile from the list and from the directory containg the profile files. */
const bool CProfileMgr::remove
( CProfile* p ) {
bool ret = false;
TQFile f( p->filename() );
if (f.exists())
f.remove();
if(m_profiles.remove(p))
; //auto delete is enabled
ret = true;
return ret;
}
const bool CProfileMgr::remove
( const TQString& profile) {
bool ret = false;
for (CProfile* p = m_profiles.first(); p; p = m_profiles.next()) {
if (p->name() == profile) {
remove
(p);
ret = true;
}
}
return ret;
}
/** Returns the profile with the desired name. If there's no such profile 0 is returned. */
CProfile* CProfileMgr::profile(const TQString& name) {
for (m_profiles.first(); m_profiles.current(); m_profiles.next()) {
if (m_profiles.current()->name() == name) {
return m_profiles.current();
}
}
return 0;
}
/** Returns the startup profile if it exists, otherwise return 0. */
CProfile* CProfileMgr::startupProfile() {
if (!m_startupProfile) {
m_startupProfile = new CProfile(TQString::null, "_startup_");
}
return m_startupProfile;
}
/** Refreshes the profiles available on disk. Use this function to update the list of profiles after another instance of CProfileMgr created a new profile. */
void CProfileMgr::refresh() {
m_profiles.clear(); //delete all profiles
TQDir d( m_profilePath );
TQStringList files = d.entryList("*.xml");
for ( TQStringList::Iterator it = files.begin(); it != files.end(); ++it ) {
CProfile p(m_profilePath + *it);
if (p.name() == "_startup_") { //new startup profile
if (!m_startupProfile) { //don't put this in the if clause above,it doesn't work!
m_startupProfile = new CProfile(m_profilePath + *it);
}
}
else if (!profile(p.name())) { //don't have it already
m_profiles.append(new CProfile(m_profilePath + *it));
}
}
}
} //end of namespace Profile
|