delay a few things on startup, such as setting the visibility mode, which ensures...
[personal-kdebase.git] / runtime / knotify / notifybylogfile.cpp
blob3386281eb349f3352c1f13ea935945786988fbe4
1 /*
2 Copyright (C) 2005-2006 by Olivier Goffart <ogoffart at kde.org>
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2, or (at your option)
8 any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
22 #include "notifybylogfile.h"
23 #include "knotifyconfig.h"
25 #include <kdebug.h>
26 #include <KUrl>
27 #include <QDateTime>
28 #include <QFile>
29 #include <QTextStream>
31 NotifyByLogfile::NotifyByLogfile(QObject *parent) : KNotifyPlugin(parent)
36 NotifyByLogfile::~NotifyByLogfile()
42 void NotifyByLogfile::notify( int id, KNotifyConfig * config )
44 QString file=config->readEntry( "Logfile" );
46 // kDebug(300) << file << KUrl(file).path();
48 // ignore empty messages
49 if ( config->text.isEmpty() || file.isEmpty() )
51 finish( id );
52 return;
55 // open file in append mode
56 QFile logFile(KUrl(file).path());
57 if ( !logFile.open(QIODevice::WriteOnly | QIODevice::Append) )
59 finish( id );
60 return;
63 // append msg
64 QTextStream strm( &logFile );
65 strm << "- KNotify " << QDateTime::currentDateTime().toString() << ": ";
66 strm << config->text << endl;
68 // close file
69 logFile.close();
71 finish( id );
74 #include "notifybylogfile.moc"