summaryrefslogtreecommitdiff
authorharlekin <harlekin>2003-01-31 17:29:47 (UTC)
committer harlekin <harlekin>2003-01-31 17:29:47 (UTC)
commit22e4e7263314b0ebcafedc2b1d67ecae69a5d10f (patch) (unidiff)
tree0538e1c7d4458348b2187d82e9fae73d780ca804
parent0d5ec3a2162111161fed2022851ebfbc4d6d0333 (diff)
downloadopie-22e4e7263314b0ebcafedc2b1d67ecae69a5d10f.zip
opie-22e4e7263314b0ebcafedc2b1d67ecae69a5d10f.tar.gz
opie-22e4e7263314b0ebcafedc2b1d67ecae69a5d10f.tar.bz2
leaks less now, still one more leak to go
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/today/changelog5
-rw-r--r--core/pim/today/today.cpp7
2 files changed, 10 insertions, 2 deletions
diff --git a/core/pim/today/changelog b/core/pim/today/changelog
index ba3cdbc..ea618c8 100644
--- a/core/pim/today/changelog
+++ b/core/pim/today/changelog
@@ -1,96 +1,101 @@
10.6.1
2
3* datebook plugin now can now also show following days
4* fixed one mem leak
5
10.6 60.6
2 7
3* longer refresh intervals possible 8* longer refresh intervals possible
4* plugins can decide now if they want to take part in refresh cycles 9* plugins can decide now if they want to take part in refresh cycles
5 10
60.5.2 110.5.2
7 12
8* refresh settings 13* refresh settings
9* only launch datebook config when clicked on a date ( opie only ) 14* only launch datebook config when clicked on a date ( opie only )
10* less qcop trouble on sharps retail rom 15* less qcop trouble on sharps retail rom
11 16
120.5.1 170.5.1
13 18
14* icons scalable and clickable again 19* icons scalable and clickable again
15 20
160.5 210.5
17 22
18* now fully plugin based 23* now fully plugin based
19 24
200.3.4 250.3.4
21 26
22* "fill our business card now a clickable label" 27* "fill our business card now a clickable label"
23* Several bugfixes regarding todo section. 28* Several bugfixes regarding todo section.
24 29
250.3.3 300.3.3
26 31
27* Changed the logo so it better scales to bigger display and also 32* Changed the logo so it better scales to bigger display and also
28 made the "Today" string translatable. 33 made the "Today" string translatable.
29* some am/pm fixes 34* some am/pm fixes
30* clickable labels now in libopie 35* clickable labels now in libopie
31 36
320.3.2 370.3.2
33 38
34* Autostart is now more configurable. You can decide how long 39* Autostart is now more configurable. You can decide how long
35 the ipaq has to has been suspended, before autostart is triggered.(Opie 40 the ipaq has to has been suspended, before autostart is triggered.(Opie
36 only) 41 only)
37* am/pm time optinal (autodetect) 42* am/pm time optinal (autodetect)
38 43
390.3.1 440.3.1
40 45
41* fixed the wrong color of the buttons 46* fixed the wrong color of the buttons
42* better translation (thanks carsten and others) 47* better translation (thanks carsten and others)
43* fixes memory leaks 48* fixes memory leaks
44* bugfixes in calendar part, now location and note are working again. 49* bugfixes in calendar part, now location and note are working again.
45 50
460.3.0 510.3.0
47 52
48* today uses now tododb from libopie. So major changes in the todo part: 53* today uses now tododb from libopie. So major changes in the todo part:
49 - overdue items on top 54 - overdue items on top
50 - then sorted by date, then by priority 55 - then sorted by date, then by priority
51* some cleanups 56* some cleanups
52* speed optimisations 57* speed optimisations
53 58
540.2.9 590.2.9
55 60
56* Many bugfixes. 61* Many bugfixes.
57* Today now apparently sorts the dates _allways_ right, i would assume it 62* Today now apparently sorts the dates _allways_ right, i would assume it
58to be a qt bug 63to be a qt bug
59 64
600.2.8 650.2.8
61 66
62* Appointments are now clickable (connection to datebook still missing) 67* Appointments are now clickable (connection to datebook still missing)
63* autostart support (opie only) 68* autostart support (opie only)
64 69
650.2.7 700.2.7
66 71
67* check if todolist.xml was changed before parsing it 72* check if todolist.xml was changed before parsing it
68* check only every 30 sec for changes. 73* check only every 30 sec for changes.
69* some visual stuff 74* some visual stuff
70* as usual many little improvements .-) 75* as usual many little improvements .-)
71 76
720.2.6 770.2.6
73 78
74* added scrollbars to dates and todo 79* added scrollbars to dates and todo
75* all day detection 80* all day detection
76* some smaller bugfixes 81* some smaller bugfixes
77 82
780.2.5 830.2.5
79 84
80* some other minor fixes regarding autoupdate 85* some other minor fixes regarding autoupdate
81* fixed segfault with todolist > 7 entries 86* fixed segfault with todolist > 7 entries
82* fixed the "ugly grey border around buttons" issue 87* fixed the "ugly grey border around buttons" issue
83* fixed the "empty calendar field" "bug" 88* fixed the "empty calendar field" "bug"
84* shown only later appointments as option 89* shown only later appointments as option
85 90
86 91
870.2.4 920.2.4
88 93
89* added support for email 94* added support for email
90* autoupdates after 1 min 95* autoupdates after 1 min
91* QCopEnvelope instead of system() 96* QCopEnvelope instead of system()
92* starting to use qvbox in gui 97* starting to use qvbox in gui
93 98
94 99
950.2.3 1000.2.3
96 101
diff --git a/core/pim/today/today.cpp b/core/pim/today/today.cpp
index 76bd6de..91028c8 100644
--- a/core/pim/today/today.cpp
+++ b/core/pim/today/today.cpp
@@ -59,217 +59,220 @@ Today::Today( QWidget* parent, const char* name, WFlags fl )
59 QObject::connect( (QObject*)OwnerField, SIGNAL( clicked() ), this, SLOT( editCard() ) ); 59 QObject::connect( (QObject*)OwnerField, SIGNAL( clicked() ), this, SLOT( editCard() ) );
60 60
61#if defined(Q_WS_QWS) 61#if defined(Q_WS_QWS)
62#if !defined(QT_NO_COP) 62#if !defined(QT_NO_COP)
63 QCopChannel *todayChannel = new QCopChannel( "QPE/Today" , this ); 63 QCopChannel *todayChannel = new QCopChannel( "QPE/Today" , this );
64 connect ( todayChannel, SIGNAL( received( const QCString &, const QByteArray &) ), 64 connect ( todayChannel, SIGNAL( received( const QCString &, const QByteArray &) ),
65 this, SLOT ( channelReceived( const QCString &, const QByteArray &) ) ); 65 this, SLOT ( channelReceived( const QCString &, const QByteArray &) ) );
66#endif 66#endif
67#endif 67#endif
68 68
69 setOwnerField(); 69 setOwnerField();
70 m_refreshTimer = new QTimer( this ); 70 m_refreshTimer = new QTimer( this );
71 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) ); 71 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
72 m_refreshTimer->start( 15000 ); 72 m_refreshTimer->start( 15000 );
73 refresh(); 73 refresh();
74 showMaximized(); 74 showMaximized();
75} 75}
76 76
77/** 77/**
78 * Qcop receive method. 78 * Qcop receive method.
79 */ 79 */
80void Today::channelReceived( const QCString &msg, const QByteArray & data ) { 80void Today::channelReceived( const QCString &msg, const QByteArray & data ) {
81 QDataStream stream( data, IO_ReadOnly ); 81 QDataStream stream( data, IO_ReadOnly );
82 if ( msg == "message(QString)" ) { 82 if ( msg == "message(QString)" ) {
83 QString message; 83 QString message;
84 stream >> message; 84 stream >> message;
85 setOwnerField( message ); 85 setOwnerField( message );
86 } 86 }
87} 87}
88 88
89void Today::setRefreshTimer( int interval ) { 89void Today::setRefreshTimer( int interval ) {
90 90
91 disconnect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) ); 91 disconnect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
92 92
93 // 0 is "never" case 93 // 0 is "never" case
94 if ( !interval == 0 ) { 94 if ( !interval == 0 ) {
95 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) ); 95 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
96 m_refreshTimer->changeInterval( interval ); 96 m_refreshTimer->changeInterval( interval );
97 } 97 }
98} 98}
99 99
100 100
101/** 101/**
102 * Initialises the owner field with the default value, the username 102 * Initialises the owner field with the default value, the username
103 */ 103 */
104void Today::setOwnerField() { 104void Today::setOwnerField() {
105 QString file = Global::applicationFileName( "addressbook", "businesscard.vcf" ); 105 QString file = Global::applicationFileName( "addressbook", "businesscard.vcf" );
106 if ( QFile::exists( file ) ) { 106 if ( QFile::exists( file ) ) {
107 Contact cont = Contact::readVCard( file )[0]; 107 Contact cont = Contact::readVCard( file )[0];
108 QString returnString = cont.fullName(); 108 QString returnString = cont.fullName();
109 OwnerField->setText( "<b>" + tr ( "Owned by " ) + returnString + "</b>" ); 109 OwnerField->setText( "<b>" + tr ( "Owned by " ) + returnString + "</b>" );
110 } else { 110 } else {
111 OwnerField->setText( "<b>" + tr ( "Please fill out the business card" ) + " </b>" ); 111 OwnerField->setText( "<b>" + tr ( "Please fill out the business card" ) + " </b>" );
112 } 112 }
113} 113}
114 114
115/** 115/**
116 * Set the owner field with a given QString, for example per qcop. 116 * Set the owner field with a given QString, for example per qcop.
117 */ 117 */
118void Today::setOwnerField( QString &message ) { 118void Today::setOwnerField( QString &message ) {
119 if ( !message.isEmpty() ) { 119 if ( !message.isEmpty() ) {
120 OwnerField->setText( "<b>" + message + "</b>" ); 120 OwnerField->setText( "<b>" + message + "</b>" );
121 } 121 }
122} 122}
123 123
124 124
125/** 125/**
126 * Init stuff needed for today. Reads the config file. 126 * Init stuff needed for today. Reads the config file.
127 */ 127 */
128void Today::init() { 128void Today::init() {
129 // read config 129 // read config
130 Config cfg( "today" ); 130 Config cfg( "today" );
131 131
132 cfg.setGroup( "Plugins" ); 132 cfg.setGroup( "Plugins" );
133 m_excludeApplets = cfg.readListEntry( "ExcludeApplets", ',' ); 133 m_excludeApplets = cfg.readListEntry( "ExcludeApplets", ',' );
134 m_allApplets = cfg.readListEntry( "AllApplets", ',' ); 134 m_allApplets = cfg.readListEntry( "AllApplets", ',' );
135 135
136 cfg.setGroup( "General" ); 136 cfg.setGroup( "General" );
137 m_iconSize = cfg.readNumEntry( "IconSize", 18 ); 137 m_iconSize = cfg.readNumEntry( "IconSize", 18 );
138 setRefreshTimer( cfg.readNumEntry( "checkinterval", 15000 ) ); 138 setRefreshTimer( cfg.readNumEntry( "checkinterval", 15000 ) );
139} 139}
140 140
141 141
142/** 142/**
143 * Load the plugins 143 * Load the plugins
144 */ 144 */
145void Today::loadPlugins() { 145void Today::loadPlugins() {
146 146
147 // extra list for plugins that exclude themself from periodic refresh 147 // extra list for plugins that exclude themself from periodic refresh
148 QMap<QString, TodayPlugin> pluginListRefreshExclude; 148 QMap<QString, TodayPlugin> pluginListRefreshExclude;
149 149
150 QValueList<TodayPlugin>::Iterator tit; 150 QValueList<TodayPlugin>::Iterator tit;
151 if ( !pluginList.isEmpty() ) { 151 if ( !pluginList.isEmpty() ) {
152 for ( tit = pluginList.begin(); tit != pluginList.end(); ++tit ) { 152 for ( tit = pluginList.begin(); tit != pluginList.end(); ++tit ) {
153 if ( (*tit).excludeRefresh ) { 153 if ( (*tit).excludeRefresh ) {
154 pluginListRefreshExclude.insert( (*tit).name , (*tit) ); 154 pluginListRefreshExclude.insert( (*tit).name , (*tit) );
155 qDebug( "Found an plugin that does not want refresh feature" ); 155 qDebug( "Found a plugin that does not want refresh feature" );
156 } else { 156 } else {
157 (*tit).guiBox->hide();
158 (*tit).guiBox->reparent( 0, QPoint( 0, 0 ) );
157 (*tit).library->unload(); 159 (*tit).library->unload();
160 delete (*tit).guiBox;
158 delete (*tit).library; 161 delete (*tit).library;
159 } 162 }
160 } 163 }
161 pluginList.clear(); 164 pluginList.clear();
162 } 165 }
163 166
164 QString path = QPEApplication::qpeDir() + "/plugins/today"; 167 QString path = QPEApplication::qpeDir() + "/plugins/today";
165 QDir dir( path, "lib*.so" ); 168 QDir dir( path, "lib*.so" );
166 169
167 QStringList list = dir.entryList(); 170 QStringList list = dir.entryList();
168 QStringList::Iterator it; 171 QStringList::Iterator it;
169 172
170 QMap<QString, TodayPlugin> tempList; 173 QMap<QString, TodayPlugin> tempList;
171 174
172 for ( it = list.begin(); it != list.end(); ++it ) { 175 for ( it = list.begin(); it != list.end(); ++it ) {
173 //TodayPluginInterface *iface = 0; 176 //TodayPluginInterface *iface = 0;
174 QInterfacePtr<TodayPluginInterface> iface; 177 QInterfacePtr<TodayPluginInterface> iface;
175 QLibrary *lib = new QLibrary( path + "/" + *it ); 178 QLibrary *lib = new QLibrary( path + "/" + *it );
176 179
177 qDebug( "querying: %s", QString( path + "/" + *it ).latin1() ); 180 qDebug( "querying: %s", QString( path + "/" + *it ).latin1() );
178 if ( lib->queryInterface( IID_TodayPluginInterface, (QUnknownInterface**)&iface ) == QS_OK ) { 181 if ( lib->queryInterface( IID_TodayPluginInterface, (QUnknownInterface**)&iface ) == QS_OK ) {
179 qDebug( "loading: %s", QString( path + "/" + *it ).latin1() ); 182 qDebug( "accepted: %s", QString( path + "/" + *it ).latin1() );
180 qDebug( QString(*it) ); 183 qDebug( QString(*it) );
181 184
182 // If plugin is exludes from refresh, get it in the list again here. 185 // If plugin is exludes from refresh, get it in the list again here.
183 186
184 if ( pluginListRefreshExclude.contains( (*it) ) ) { 187 if ( pluginListRefreshExclude.contains( (*it) ) ) {
185 // if its not in allApplets list, add it to a layout 188 // if its not in allApplets list, add it to a layout
186 if ( !m_allApplets.contains( pluginListRefreshExclude[(*it)].name ) ) { 189 if ( !m_allApplets.contains( pluginListRefreshExclude[(*it)].name ) ) {
187 layout->addWidget( pluginListRefreshExclude[(*it)].guiBox ); 190 layout->addWidget( pluginListRefreshExclude[(*it)].guiBox );
188 pluginList.append( pluginListRefreshExclude[(*it)] ); 191 pluginList.append( pluginListRefreshExclude[(*it)] );
189 } else { 192 } else {
190 tempList.insert( pluginListRefreshExclude[(*it)].name, pluginListRefreshExclude[(*it)] ); 193 tempList.insert( pluginListRefreshExclude[(*it)].name, pluginListRefreshExclude[(*it)] );
191 } 194 }
192 } else { 195 } else {
193 196
194 TodayPlugin plugin; 197 TodayPlugin plugin;
195 plugin.library = lib; 198 plugin.library = lib;
196 plugin.iface = iface; 199 plugin.iface = iface;
197 plugin.name = QString(*it); 200 plugin.name = QString(*it);
198 201
199 // find out if plugins should be shown 202 // find out if plugins should be shown
200 if ( m_excludeApplets.grep( *it ).isEmpty() ) { 203 if ( m_excludeApplets.grep( *it ).isEmpty() ) {
201 plugin.active = true; 204 plugin.active = true;
202 } else { 205 } else {
203 plugin.active = false; 206 plugin.active = false;
204 } 207 }
205 208
206 plugin.guiPart = plugin.iface->guiPart(); 209 plugin.guiPart = plugin.iface->guiPart();
207 plugin.excludeRefresh = plugin.guiPart->excludeFromRefresh(); 210 plugin.excludeRefresh = plugin.guiPart->excludeFromRefresh();
208 211
209 // package the whole thing into a qwidget so it can be shown and hidden 212 // package the whole thing into a qwidget so it can be shown and hidden
210 plugin.guiBox = new QWidget( this ); 213 plugin.guiBox = new QWidget( this );
211 QHBoxLayout *boxLayout = new QHBoxLayout( plugin.guiBox ); 214 QHBoxLayout *boxLayout = new QHBoxLayout( plugin.guiBox );
212 QPixmap plugPix; 215 QPixmap plugPix;
213 plugPix.convertFromImage( Resource::loadImage( plugin.guiPart->pixmapNameWidget() ).smoothScale( m_iconSize, m_iconSize ), 0 ); 216 plugPix.convertFromImage( Resource::loadImage( plugin.guiPart->pixmapNameWidget() ).smoothScale( m_iconSize, m_iconSize ), 0 );
214 OClickableLabel* plugIcon = new OClickableLabel( plugin.guiBox ); 217 OClickableLabel* plugIcon = new OClickableLabel( plugin.guiBox );
215 plugIcon->setPixmap( plugPix ); 218 plugIcon->setPixmap( plugPix );
216 QWhatsThis::add( plugIcon, tr("Click here to launch the associated app") ); 219 QWhatsThis::add( plugIcon, tr("Click here to launch the associated app") );
217 plugIcon->setName( plugin.guiPart->appName() ); 220 plugIcon->setName( plugin.guiPart->appName() );
218 connect( plugIcon, SIGNAL( clicked() ), this, SLOT( startApplication() ) ); 221 connect( plugIcon, SIGNAL( clicked() ), this, SLOT( startApplication() ) );
219 // a scrollview for each plugin 222 // a scrollview for each plugin
220 QScrollView* sv = new QScrollView( plugin.guiBox ); 223 QScrollView* sv = new QScrollView( plugin.guiBox );
221 QWidget *plugWidget = plugin.guiPart->widget( sv->viewport() ); 224 QWidget *plugWidget = plugin.guiPart->widget( sv->viewport() );
222 // not sure if that is good .-) 225 // not sure if that is good .-)
223 sv->setMinimumHeight( 10 ); 226 sv->setMinimumHeight( 10 );
224 sv->setResizePolicy( QScrollView::AutoOneFit ); 227 sv->setResizePolicy( QScrollView::AutoOneFit );
225 sv->setHScrollBarMode( QScrollView::AlwaysOff ); 228 sv->setHScrollBarMode( QScrollView::AlwaysOff );
226 sv->setFrameShape( QFrame::NoFrame ); 229 sv->setFrameShape( QFrame::NoFrame );
227 sv->addChild( plugWidget ); 230 sv->addChild( plugWidget );
228 // make sure the icon is on the top alligned 231 // make sure the icon is on the top alligned
229 boxLayout->addWidget( plugIcon, 0, AlignTop ); 232 boxLayout->addWidget( plugIcon, 0, AlignTop );
230 boxLayout->addWidget( sv, 0, AlignTop ); 233 boxLayout->addWidget( sv, 0, AlignTop );
231 boxLayout->setStretchFactor( plugIcon, 1 ); 234 boxLayout->setStretchFactor( plugIcon, 1 );
232 boxLayout->setStretchFactor( sv, 9 ); 235 boxLayout->setStretchFactor( sv, 9 );
233 // "prebuffer" it in one more list, to get the sorting done 236 // "prebuffer" it in one more list, to get the sorting done
234 tempList.insert( plugin.name, plugin ); 237 tempList.insert( plugin.name, plugin );
235 238
236 // on first start the list is off course empty 239 // on first start the list is off course empty
237 if ( m_allApplets.isEmpty() ) { 240 if ( m_allApplets.isEmpty() ) {
238 layout->addWidget( plugin.guiBox ); 241 layout->addWidget( plugin.guiBox );
239 pluginList.append( plugin ); 242 pluginList.append( plugin );
240 } 243 }
241 244
242 // if plugin is not yet in the list, add it to the layout too 245 // if plugin is not yet in the list, add it to the layout too
243 else if ( !m_allApplets.contains( plugin.name ) ) { 246 else if ( !m_allApplets.contains( plugin.name ) ) {
244 layout->addWidget( plugin.guiBox ); 247 layout->addWidget( plugin.guiBox );
245 pluginList.append( plugin ); 248 pluginList.append( plugin );
246 } 249 }
247 } 250 }
248 } else { 251 } else {
249 qDebug( "could not recognize %s", QString( path + "/" + *it ).latin1() ); 252 qDebug( "could not recognize %s", QString( path + "/" + *it ).latin1() );
250 delete lib; 253 delete lib;
251 } 254 }
252 } 255 }
253 256
254 if ( !m_allApplets.isEmpty() ) { 257 if ( !m_allApplets.isEmpty() ) {
255 TodayPlugin tempPlugin; 258 TodayPlugin tempPlugin;
256 QStringList::Iterator stringit; 259 QStringList::Iterator stringit;
257 260
258 for( stringit = m_allApplets.begin(); stringit != m_allApplets.end(); ++stringit ) { 261 for( stringit = m_allApplets.begin(); stringit != m_allApplets.end(); ++stringit ) {
259 tempPlugin = ( tempList.find( *stringit ) ).data(); 262 tempPlugin = ( tempList.find( *stringit ) ).data();
260 if ( !( (tempPlugin.name).isEmpty() ) ) { 263 if ( !( (tempPlugin.name).isEmpty() ) ) {
261 layout->addWidget( tempPlugin.guiBox ); 264 layout->addWidget( tempPlugin.guiBox );
262 pluginList.append( tempPlugin ); 265 pluginList.append( tempPlugin );
263 } 266 }
264 } 267 }
265 } 268 }
266} 269}
267 270
268 271
269/** 272/**
270 * Repaint method. Reread all fields. 273 * Repaint method. Reread all fields.
271 */ 274 */
272void Today::draw() { 275void Today::draw() {
273 276
274 if ( pluginList.count() == 0 ) { 277 if ( pluginList.count() == 0 ) {
275 QLabel *noPlugins = new QLabel( this ); 278 QLabel *noPlugins = new QLabel( this );