/*
* Copyright (C) 2022, KylinSoft Co., Ltd.
*
* 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 3 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, see .
*
* Authors: iaom
*
*/
#include "monitor.h"
#include
#include "file-indexer-config.h"
using namespace UkuiSearch;
Monitor::Monitor(IndexScheduler *scheduler, QObject *parent) : MonitorSource(parent),
m_scheduler(scheduler),
m_basicDatabase(DataBaseType::Basic),
m_contentDatabase(DataBaseType::Content),
m_ocrContentDatabase(DataBaseType::OcrContent)
{
connect(scheduler, &IndexScheduler::stateChange, this, &Monitor::onIndexStateChanged);
connect(scheduler, &IndexScheduler::process, this, &Monitor::processUpdate);
connect(scheduler, &IndexScheduler::basicIndexDone, this, &Monitor::basicIndexDone);
connect(scheduler, &IndexScheduler::contentIndexDone, this, &Monitor::contentIndexDone);
connect(scheduler, &IndexScheduler::ocrContentIndexDone, this, &Monitor::ocrContentIndexDone);
connect(scheduler, &IndexScheduler::basicIndexStart, this, &Monitor::basicIndexStart);
connect(scheduler, &IndexScheduler::contentIndexStart, this, &Monitor::contentIndexStart);
connect(scheduler, &IndexScheduler::ocrContentIndexStart, this, &Monitor::ocrContentIndexStart);
connect(FileIndexerConfig::getInstance(), &FileIndexerConfig::appendIndexDir, this, [&](){
m_currentIndexPaths = FileIndexerConfig::getInstance()->currentIndexableDir();
Q_EMIT currentIndexPathsChanged(m_currentIndexPaths);
});
connect(FileIndexerConfig::getInstance(), &FileIndexerConfig::removeIndexDir, this, [&](){
m_currentIndexPaths = FileIndexerConfig::getInstance()->currentIndexableDir();
Q_EMIT currentIndexPathsChanged(m_currentIndexPaths);
});
}
QStringList Monitor::currentIndexPaths() const
{
return FileIndexerConfig::getInstance()->currentIndexableDir();
}
QString Monitor::indexState() const
{
QMetaEnum metaEnum = QMetaEnum::fromType();
return QString::fromLocal8Bit(metaEnum.valueToKey(m_scheduler->getIndexState()));
}
uint Monitor::basicIndexSize() const
{
return m_basicIndexSize;
}
uint Monitor::contentIndexSize() const
{
return m_contentIndexSize;
}
uint Monitor::ocrContentIndexSize() const
{
return m_ocrIndexSize;
}
uint Monitor::basicIndexProgress() const
{
return m_basicIndexProgress;
}
uint Monitor::contentIndexProgress() const
{
return m_contentIndexProgress;
}
uint Monitor::ocrContentIndexProgress() const
{
return m_ocrIndexProgress;
}
uint Monitor::basicIndexDocNum() const
{
return m_basicIndexDocNum;
}
uint Monitor::contentIndexDocNum() const
{
return m_contentIndexDocNum;
}
uint Monitor::ocrContentIndexDocNum() const
{
return m_ocrContentIndexDocNum;
}
void Monitor::onIndexStateChanged(IndexScheduler::IndexerState state)
{
if(state == IndexScheduler::IndexerState::Idle || state == IndexScheduler::IndexerState::Stop) {
m_basicIndexDocNum = m_basicDatabase.getIndexDocCount();
Q_EMIT basicIndexDocNumChanged(m_basicIndexDocNum);
m_contentIndexDocNum = m_contentDatabase.getIndexDocCount();
Q_EMIT contentIndexDocNumChanged(m_contentIndexDocNum);
m_ocrContentIndexDocNum = m_ocrContentDatabase.getIndexDocCount();
Q_EMIT ocrContentIndexDocNumChanged(m_ocrContentDatabase.getIndexDocCount());
}
QMetaEnum metaEnum = QMetaEnum::fromType();
Q_EMIT indexStateChanged(QString::fromLocal8Bit(metaEnum.valueToKey(state)));
}
void Monitor::processUpdate(IndexType type, uint all, uint finished)
{
switch (type) {
case IndexType::Basic: {
if(m_basicIndexSize != all) {
m_basicIndexSize = all;
Q_EMIT basicIndexSizeChanged(m_basicIndexSize);
}
if(m_basicIndexProgress != finished) {
m_basicIndexProgress = finished;
Q_EMIT basicIndexProgressChanged(m_basicIndexProgress);
}
uint count = m_basicDatabase.getIndexDocCount();
if(m_basicIndexDocNum != count) {
m_basicIndexDocNum = count;
Q_EMIT basicIndexDocNumChanged(m_basicIndexDocNum);
}
break;
}
case IndexType::Contents: {
if(m_contentIndexSize != all) {
m_contentIndexSize = all;
Q_EMIT contentIndexSizeChanged(m_contentIndexSize);
}
if(m_contentIndexProgress != finished) {
m_contentIndexProgress = finished;
Q_EMIT contentIndexProgressChanged(m_contentIndexProgress);
}
uint count = m_contentDatabase.getIndexDocCount();
if(m_contentIndexDocNum != count) {
m_contentIndexDocNum = count;
Q_EMIT contentIndexDocNumChanged(m_contentIndexDocNum);
}
break;
}
case IndexType::OCR: {
if(m_ocrIndexSize != all) {
m_ocrIndexSize = all;
Q_EMIT ocrContentIndexSizeChanged(m_ocrIndexSize);
}
if(m_ocrIndexProgress != finished) {
m_ocrIndexProgress = finished;
Q_EMIT ocrContentIndexProgressChanged(m_ocrIndexProgress);
}
uint count = m_contentDatabase.getIndexDocCount();
if(m_ocrContentIndexDocNum != count) {
m_ocrContentIndexDocNum = count;
Q_EMIT ocrContentIndexDocNumChanged(m_ocrContentDatabase.getIndexDocCount());
}
break;
}
default:
break;
}
}