/* * 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; } }