/* KPilot ** ** Copyright (C) 2000-2001 by Adriaan de Groot ** ** This file is part of the NULL conduit, a conduit for KPilot that ** does nothing except add a log message to the Pilot's HotSync log. ** It is also intended as a programming example. ** ** This file does the actual conduit work. */ /* ** This program is free software; you can redistribute it and/or modify ** it under the terms of the GNU Lesser General Public License as published by ** the Free Software Foundation; either version 2.1 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 Lesser General Public License for more details. ** ** You should have received a copy of the GNU Lesser General Public License ** along with this program in a file called COPYING; if not, write to ** the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, ** MA 02110-1301, USA. */ /* ** Bug reports and questions can be sent to kde-pim@kde.org */ #include "options.h" // Only include what we really need: // First UNIX system stuff, then std C++, // then Qt, then KDE, then local includes. // // #include #include #include #include "pilotSerialDatabase.h" #include "null-factory.h" #include "null-conduit.h" #include "nullSettings.h" // A conduit that does nothing has a very // simple constructor and destructor. // // NullConduit::NullConduit(KPilotLink *d, const char *n, const TQStringList &l) : ConduitAction(d,n,l), fDatabase(0L), fFailImmediately( l.contains( CSL1("--fail") )) { FUNCTIONSETUP; fConduitName=i18n("Null"); } NullConduit::~NullConduit() { FUNCTIONSETUP; KPILOT_DELETE(fDatabase); } /* virtual */ bool NullConduit::exec() { FUNCTIONSETUP; DEBUGKPILOT << fname << ": Mode " << syncMode().name() << endl; if ( fFailImmediately ) { DEBUGKPILOT << fname << ": Config says to fail now." << endl; emit logError(i18n("NULL conduit is programmed to fail.")); return false; } TQString m(NullConduitSettings::logMessage()); if (!m.isEmpty()) { addSyncLogEntry(m); } DEBUGKPILOT << fname << ": Message from null-conduit: " << m << endl; emit syncDone(this); return true; }