QDBusConnection CallListener::systemBus_ = QDBusConnection::systemBus();
-CallListener::CallListener(): eniro_(0), contactManager_(0), box_(0), label_(0), retries_(-1)
+CallListener::CallListener(): eniro_(0), contactManager_(0),
+connectionManager_(0), closeConnection_(false), box_(0), label_(0),
+retries_(-1)
{
}
SLOT(callTerminate()));
contactManager_ = new ContactManager;
+ connectionManager_ = new ConnectionManager;
eniro_ = new Eniro(Eniro::stringToSite(Settings::instance()->get("site")));
this,
SLOT(callTerminate()));
+ delete contactManager_;
+ contactManager_ = 0;
+ delete connectionManager_;
+ connectionManager_ = 0;
delete eniro_;
eniro_ = 0;
delete box_;
void CallListener::search(Eniro::SearchDetails const& details)
{
- qDebug() << "Search called";
+ qDebug() << "Search called";
Eniro::Result result;
showResult(tr("Searching..."));
retries_ = 0;
currentSearch_ = details;
+
+ if(!connectionManager_->isConnected())
+ {
+ connectionManager_->connect();
+ closeConnection_ = true;
+ }
+ else
+ {
+ closeConnection_ = false;
+ }
+
eniro_->search(details);
}
if(retries_ < NUMBER_OF_RETRIES && retries_ >= 0)
{
- retries_++;
- eniro_->search(currentSearch_);
- return;
+ retries_++;
+ eniro_->search(currentSearch_);
+ return;
}
else
{
- message = tr("Search failed:") + " " + eniro_->errorString() + ".";
+ message = tr("Search failed:") + " " + eniro_->errorString() + ".";
}
}
else if(results.size() == 0)
retries_ = -1;
+ if(closeConnection_)
+ {
+ connectionManager_->disconnect();
+ closeConnection_ = false;
+ }
+
timedMessage_ = message;
- // Show banner after small delay
- showDelayedResult(message, BANNER_DELAY);
+ showResult(message);
}
if(!contactManager_->numberExists(number))
{
- qDebug() << "Number doesn't exist";
+ qDebug() << "Number doesn't exist";
systemBus_.connect(CALL_SERVICE_NAME,
path.path(),
}
else
{
- qDebug() << "Number exists";
+ qDebug() << "Number exists";
}
}
void CallListener::callTerminate()
{
- if(box_->isVisible())
- {
- box_->hide();
- }
+ if(box_->isVisible())
+ {
+ box_->hide();
+ }
+
+ if(closeConnection_)
+ {
+ connectionManager_->disconnect();
+ closeConnection_ = false;
+ }
}
void CallListener::showDelayedResult(QString const& text, int delay)
{
- timedMessage_ = text;
- QTimer::singleShot(delay, this, SLOT(showTimedMessage()));
+ timedMessage_ = text;
+ QTimer::singleShot(delay, this, SLOT(showTimedMessage()));
}
void CallListener::showTimedMessage()
{
- if(timedMessage_.size() == 0)
- {
- return;
- }
+ if(timedMessage_.size() == 0)
+ {
+ return;
+ }
- showResult(timedMessage_);
+ showResult(timedMessage_);
- timedMessage_ = "";
+ timedMessage_ = "";
}