You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdepim/kandy/src/commandscheduler.cpp

141 lines
3.6 KiB

/*
This file is part of Kandy.
Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
As a special exception, permission is given to link this program
with any edition of TQt, and distribute the resulting executable,
without including the source code for TQt in the source distribution.
*/
#include <kdebug.h>
#include <klocale.h>
#include "modem.h"
#include "commandscheduler.h"
#include "commandscheduler.moc"
CommandScheduler::CommandScheduler(Modem *modem,TQObject *parent,
const char *name) :
TQObject(parent,name),
mModem(modem)
{
connect(mModem,TQT_SIGNAL(gotLine(const char *)),
TQT_SLOT(processOutput(const char *)));
}
void CommandScheduler::execute(ATCommand *command)
{
if (!mModem->isOpen()) {
kdDebug(5960) << "Warning! Modem not open." << endl;
return;
}
mCommandQueue.append(command);
// if (mCommandQueue.count() == 1) sendCommand(command->cmdString());
if (mCommandQueue.count() == 1) sendCommand(command->cmd());
}
void CommandScheduler::execute(const TQString &command)
{
ATCommand *cmd = new ATCommand("",command);
cmd->setAutoDelete(true);
execute(cmd);
}
void CommandScheduler::executeId(const TQString &id)
{
TQPtrList<ATCommand> *cmds = mCommandSet.commandList();
for(uint i=0;i<cmds->count();++i) {
if (cmds->at(i)->id() == id) {
execute(cmds->at(i));
return;
}
}
kdDebug(5960) << "CommandScheduler::executeId(): Id '" << id << "' not found" << endl;
}
void CommandScheduler::sendCommand(const TQString &command)
{
if (command.isEmpty()) {
kdDebug(5960) << "CommandScheduler::sendCommand(): Warning! Empty command."
<< endl;
return;
}
kdDebug(5960) << "CommandScheduler:sendCommand(): " << command << endl;
mModem->writeLine(command.latin1());
}
void CommandScheduler::processOutput(const char *line)
{
TQString l = line;
ATCommand *cmd = mCommandQueue.first();
if (l == "OK") {
mState = WAITING;
emit result(mResult);
cmd->setResultString(mResult);
emit commandProcessed(cmd);
nextCommand();
} else if (l == "ERROR") {
mState = WAITING;
emit result(i18n("Error"));
nextCommand();
} else {
if (mState == WAITING) {
mState = PROCESSING;
mResult = "";
} else if (mState == PROCESSING) {
if (!l.isEmpty()) {
mResult += l;
mResult += "\n";
}
}
}
}
void CommandScheduler::nextCommand()
{
if (mCommandQueue.first()->autoDelete()) delete mCommandQueue.first();
mCommandQueue.removeFirst();
if (mCommandQueue.count() > 0) {
sendCommand(mCommandQueue.first()->cmd());
}
}
bool CommandScheduler::loadProfile(const TQString& filename)
{
mCommandSet.clear();
if (!mCommandSet.loadFile(filename)) return false;
return true;
}
bool CommandScheduler::saveProfile(const TQString& filename)
{
if (!mCommandSet.saveFile(filename)) return false;
return true;
}