2014-04-24 13:09:25 +00:00
|
|
|
#ifndef CSM_DOC_LOADER_H
|
|
|
|
#define CSM_DOC_LOADER_H
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include <QObject>
|
|
|
|
#include <QMutex>
|
|
|
|
#include <QWaitCondition>
|
|
|
|
|
|
|
|
namespace CSMDoc
|
|
|
|
{
|
|
|
|
class Document;
|
|
|
|
|
|
|
|
class Loader : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
2014-05-03 10:07:05 +00:00
|
|
|
struct Stage
|
|
|
|
{
|
|
|
|
int mFile;
|
2014-06-26 09:41:21 +00:00
|
|
|
int mRecordsLoaded;
|
2014-05-03 13:05:02 +00:00
|
|
|
bool mRecordsLeft;
|
2014-05-03 10:07:05 +00:00
|
|
|
|
|
|
|
Stage();
|
|
|
|
};
|
|
|
|
|
2014-04-24 13:09:25 +00:00
|
|
|
QMutex mMutex;
|
|
|
|
QWaitCondition mThingsToDo;
|
2014-05-03 10:07:05 +00:00
|
|
|
std::vector<std::pair<Document *, Stage> > mDocuments;
|
2014-04-24 13:09:25 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
Loader();
|
|
|
|
|
|
|
|
QWaitCondition& hasThingsToDo();
|
|
|
|
|
|
|
|
private slots:
|
|
|
|
|
|
|
|
void load();
|
|
|
|
|
|
|
|
public slots:
|
|
|
|
|
2014-04-29 12:27:44 +00:00
|
|
|
void loadDocument (CSMDoc::Document *document);
|
2014-04-24 13:09:25 +00:00
|
|
|
///< The ownership of \a document is not transferred.
|
|
|
|
|
2014-05-03 14:44:50 +00:00
|
|
|
void abortLoading (CSMDoc::Document *document);
|
2014-04-24 13:09:25 +00:00
|
|
|
///< Abort loading \a docuemnt (ignored if \a document has already finished being
|
|
|
|
/// loaded). Will result in a documentNotLoaded signal, once the Loader has finished
|
|
|
|
/// cleaning up.
|
|
|
|
|
|
|
|
signals:
|
|
|
|
|
|
|
|
void documentLoaded (Document *document);
|
|
|
|
///< The ownership of \a document is not transferred.
|
|
|
|
|
|
|
|
void documentNotLoaded (Document *document, const std::string& error);
|
|
|
|
///< Document load has been interrupted either because of a call to abortLoading
|
|
|
|
/// or a problem during loading). In the former case error will be an empty string.
|
2014-05-03 11:01:29 +00:00
|
|
|
|
2014-06-26 09:41:21 +00:00
|
|
|
void nextStage (CSMDoc::Document *document, const std::string& name,
|
|
|
|
int totalRecords);
|
2014-05-03 13:33:35 +00:00
|
|
|
|
2014-06-26 09:41:21 +00:00
|
|
|
void nextRecord (CSMDoc::Document *document, int records);
|
2014-05-03 13:33:35 +00:00
|
|
|
///< \note This signal is only given once per group of records. The group size is
|
|
|
|
/// approximately the total number of records divided by the steps value of the
|
|
|
|
/// previous nextStage signal.
|
2014-05-10 11:18:40 +00:00
|
|
|
|
|
|
|
void loadMessage (CSMDoc::Document *document, const std::string& message);
|
|
|
|
///< Non-critical load error or warning
|
2014-04-24 13:09:25 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|