2012-03-23 20:34:39 +00:00
|
|
|
#include "PageLoadingCommand.h"
|
|
|
|
#include "Command.h"
|
|
|
|
#include "WebPage.h"
|
2012-05-15 01:59:28 +00:00
|
|
|
#include "WebPageManager.h"
|
2012-03-23 20:34:39 +00:00
|
|
|
|
2012-05-15 01:59:28 +00:00
|
|
|
PageLoadingCommand::PageLoadingCommand(Command *command, WebPageManager *manager, QObject *parent) : QObject(parent) {
|
|
|
|
m_manager = manager;
|
2012-03-23 20:34:39 +00:00
|
|
|
m_command = command;
|
|
|
|
m_pageLoadingFromCommand = false;
|
|
|
|
m_pageSuccess = true;
|
|
|
|
m_pendingResponse = NULL;
|
2012-05-15 01:59:28 +00:00
|
|
|
connect(m_manager, SIGNAL(loadStarted()), this, SLOT(pageLoadingFromCommand()));
|
|
|
|
connect(m_manager, SIGNAL(pageFinished(bool)), this, SLOT(pendingLoadFinished(bool)));
|
2012-03-23 20:34:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void PageLoadingCommand::start() {
|
2012-06-29 16:14:22 +00:00
|
|
|
m_manager->logger() << "Started" << m_command->toString();
|
2012-03-23 20:34:39 +00:00
|
|
|
connect(m_command, SIGNAL(finished(Response *)), this, SLOT(commandFinished(Response *)));
|
|
|
|
m_command->start();
|
|
|
|
};
|
|
|
|
|
|
|
|
void PageLoadingCommand::pendingLoadFinished(bool success) {
|
|
|
|
m_pageSuccess = success;
|
|
|
|
if (m_pageLoadingFromCommand) {
|
|
|
|
m_pageLoadingFromCommand = false;
|
|
|
|
if (m_pendingResponse) {
|
2012-06-29 16:14:22 +00:00
|
|
|
m_manager->logger() << "Page load from command finished";
|
2012-03-23 20:34:39 +00:00
|
|
|
if (m_pageSuccess) {
|
|
|
|
emit finished(m_pendingResponse);
|
|
|
|
} else {
|
2012-05-15 01:59:28 +00:00
|
|
|
QString message = m_manager->currentPage()->failureString();
|
2012-03-23 20:34:39 +00:00
|
|
|
emit finished(new Response(false, message));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void PageLoadingCommand::pageLoadingFromCommand() {
|
2012-06-29 16:14:22 +00:00
|
|
|
m_manager->logger() << m_command->toString() << "started page load";
|
2012-03-23 20:34:39 +00:00
|
|
|
m_pageLoadingFromCommand = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void PageLoadingCommand::commandFinished(Response *response) {
|
2012-05-15 01:59:28 +00:00
|
|
|
disconnect(m_manager, SIGNAL(loadStarted()), this, SLOT(pageLoadingFromCommand()));
|
2012-06-29 16:14:22 +00:00
|
|
|
m_manager->logger() << "Finished" << m_command->toString();
|
2012-03-23 20:34:39 +00:00
|
|
|
m_command->deleteLater();
|
|
|
|
if (m_pageLoadingFromCommand)
|
|
|
|
m_pendingResponse = response;
|
|
|
|
else
|
|
|
|
emit finished(response);
|
|
|
|
}
|