mirror of
https://github.com/nextcloud/desktop.git
synced 2024-11-26 23:28:14 +03:00
SyncEngine: no need to use QAtomicInt
This was done because the propagator jobs where running in a thread a long time ago, but this is no longer the case. (Also QAtomicInt::load is marked as deprecated now)
This commit is contained in:
parent
f81f96915f
commit
1c10fceacc
12 changed files with 28 additions and 32 deletions
|
@ -53,8 +53,8 @@ BandwidthManager::BandwidthManager(OwncloudPropagator *p)
|
||||||
, _relativeLimitCurrentMeasuredJob(nullptr)
|
, _relativeLimitCurrentMeasuredJob(nullptr)
|
||||||
, _currentDownloadLimit(0)
|
, _currentDownloadLimit(0)
|
||||||
{
|
{
|
||||||
_currentUploadLimit = _propagator->_uploadLimit.fetchAndAddAcquire(0);
|
_currentUploadLimit = _propagator->_uploadLimit;
|
||||||
_currentDownloadLimit = _propagator->_downloadLimit.fetchAndAddAcquire(0);
|
_currentDownloadLimit = _propagator->_downloadLimit;
|
||||||
|
|
||||||
QObject::connect(&_switchingTimer, &QTimer::timeout, this, &BandwidthManager::switchingTimerExpired);
|
QObject::connect(&_switchingTimer, &QTimer::timeout, this, &BandwidthManager::switchingTimerExpired);
|
||||||
_switchingTimer.setInterval(10 * 1000);
|
_switchingTimer.setInterval(10 * 1000);
|
||||||
|
@ -337,7 +337,7 @@ void BandwidthManager::relativeDownloadDelayTimerExpired()
|
||||||
|
|
||||||
void BandwidthManager::switchingTimerExpired()
|
void BandwidthManager::switchingTimerExpired()
|
||||||
{
|
{
|
||||||
qint64 newUploadLimit = _propagator->_uploadLimit.fetchAndAddAcquire(0);
|
qint64 newUploadLimit = _propagator->_uploadLimit;
|
||||||
if (newUploadLimit != _currentUploadLimit) {
|
if (newUploadLimit != _currentUploadLimit) {
|
||||||
qCInfo(lcBandwidthManager) << "Upload Bandwidth limit changed" << _currentUploadLimit << newUploadLimit;
|
qCInfo(lcBandwidthManager) << "Upload Bandwidth limit changed" << _currentUploadLimit << newUploadLimit;
|
||||||
_currentUploadLimit = newUploadLimit;
|
_currentUploadLimit = newUploadLimit;
|
||||||
|
@ -354,7 +354,7 @@ void BandwidthManager::switchingTimerExpired()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
qint64 newDownloadLimit = _propagator->_downloadLimit.fetchAndAddAcquire(0);
|
qint64 newDownloadLimit = _propagator->_downloadLimit;
|
||||||
if (newDownloadLimit != _currentDownloadLimit) {
|
if (newDownloadLimit != _currentDownloadLimit) {
|
||||||
qCInfo(lcBandwidthManager) << "Download Bandwidth limit changed" << _currentDownloadLimit << newDownloadLimit;
|
qCInfo(lcBandwidthManager) << "Download Bandwidth limit changed" << _currentDownloadLimit << newDownloadLimit;
|
||||||
_currentDownloadLimit = newDownloadLimit;
|
_currentDownloadLimit = newDownloadLimit;
|
||||||
|
|
|
@ -79,8 +79,8 @@ OwncloudPropagator::~OwncloudPropagator() = default;
|
||||||
|
|
||||||
int OwncloudPropagator::maximumActiveTransferJob()
|
int OwncloudPropagator::maximumActiveTransferJob()
|
||||||
{
|
{
|
||||||
if (_downloadLimit.fetchAndAddAcquire(0) != 0
|
if (_downloadLimit != 0
|
||||||
|| _uploadLimit.fetchAndAddAcquire(0) != 0
|
|| _uploadLimit != 0
|
||||||
|| !_syncOptions._parallelNetworkJobs) {
|
|| !_syncOptions._parallelNetworkJobs) {
|
||||||
// disable parallelism when there is a network limit.
|
// disable parallelism when there is a network limit.
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -237,8 +237,8 @@ void PropagateItemJob::done(SyncFileItem::Status statusArg, const QString &error
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0) && (_item->_status == SyncFileItem::NormalError
|
if (propagator()->_abortRequested && (_item->_status == SyncFileItem::NormalError
|
||||||
|| _item->_status == SyncFileItem::FatalError)) {
|
|| _item->_status == SyncFileItem::FatalError)) {
|
||||||
// an abort request is ongoing. Change the status to Soft-Error
|
// an abort request is ongoing. Change the status to Soft-Error
|
||||||
_item->_status = SyncFileItem::SoftError;
|
_item->_status = SyncFileItem::SoftError;
|
||||||
}
|
}
|
||||||
|
|
|
@ -419,11 +419,11 @@ public:
|
||||||
const SyncOptions &syncOptions() const;
|
const SyncOptions &syncOptions() const;
|
||||||
void setSyncOptions(const SyncOptions &syncOptions);
|
void setSyncOptions(const SyncOptions &syncOptions);
|
||||||
|
|
||||||
QAtomicInt _downloadLimit;
|
int _downloadLimit = 0;
|
||||||
QAtomicInt _uploadLimit;
|
int _uploadLimit = 0;
|
||||||
BandwidthManager _bandwidthManager;
|
BandwidthManager _bandwidthManager;
|
||||||
|
|
||||||
QAtomicInt _abortRequested; // boolean set by the main thread to abort.
|
bool _abortRequested = false;
|
||||||
|
|
||||||
/** The list of currently active jobs.
|
/** The list of currently active jobs.
|
||||||
This list contains the jobs that are currently using ressources and is used purely to
|
This list contains the jobs that are currently using ressources and is used purely to
|
||||||
|
@ -492,8 +492,7 @@ public:
|
||||||
|
|
||||||
void abort()
|
void abort()
|
||||||
{
|
{
|
||||||
bool alreadyAborting = _abortRequested.fetchAndStoreOrdered(true);
|
if (_abortRequested)
|
||||||
if (alreadyAborting)
|
|
||||||
return;
|
return;
|
||||||
if (_rootJob) {
|
if (_rootJob) {
|
||||||
// Connect to abortFinished which signals that abort has been asynchronously finished
|
// Connect to abortFinished which signals that abort has been asynchronously finished
|
||||||
|
|
|
@ -361,7 +361,7 @@ QString GETFileJob::errorString() const
|
||||||
|
|
||||||
void PropagateDownloadFile::start()
|
void PropagateDownloadFile::start()
|
||||||
{
|
{
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
_isEncrypted = false;
|
_isEncrypted = false;
|
||||||
|
|
||||||
|
@ -503,7 +503,7 @@ void PropagateDownloadFile::conflictChecksumComputed(const QByteArray &checksumT
|
||||||
|
|
||||||
void PropagateDownloadFile::startDownload()
|
void PropagateDownloadFile::startDownload()
|
||||||
{
|
{
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// do a klaas' case clash check.
|
// do a klaas' case clash check.
|
||||||
|
|
|
@ -81,7 +81,7 @@ PropagatorJob::JobParallelism PropagateRemoteDelete::parallelism()
|
||||||
|
|
||||||
void PropagateRemoteDelete::start()
|
void PropagateRemoteDelete::start()
|
||||||
{
|
{
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (!_item->_encryptedFileName.isEmpty()) {
|
if (!_item->_encryptedFileName.isEmpty()) {
|
||||||
|
|
|
@ -69,7 +69,7 @@ PropagatorJob::JobParallelism PropagateRemoteMkdir::parallelism()
|
||||||
|
|
||||||
void PropagateRemoteMkdir::start()
|
void PropagateRemoteMkdir::start()
|
||||||
{
|
{
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
qCDebug(lcPropagateRemoteMkdir) << _item->_file;
|
qCDebug(lcPropagateRemoteMkdir) << _item->_file;
|
||||||
|
@ -91,7 +91,7 @@ void PropagateRemoteMkdir::start()
|
||||||
|
|
||||||
void PropagateRemoteMkdir::slotStartMkcolJob()
|
void PropagateRemoteMkdir::slotStartMkcolJob()
|
||||||
{
|
{
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
qCDebug(lcPropagateRemoteMkdir) << _item->_file;
|
qCDebug(lcPropagateRemoteMkdir) << _item->_file;
|
||||||
|
@ -108,7 +108,7 @@ void PropagateRemoteMkdir::slotStartEncryptedMkcolJob(const QString &path, const
|
||||||
Q_UNUSED(path)
|
Q_UNUSED(path)
|
||||||
Q_UNUSED(size)
|
Q_UNUSED(size)
|
||||||
|
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
qDebug() << filename;
|
qDebug() << filename;
|
||||||
|
|
|
@ -75,7 +75,7 @@ bool MoveJob::finished()
|
||||||
|
|
||||||
void PropagateRemoteMove::start()
|
void PropagateRemoteMove::start()
|
||||||
{
|
{
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
QString origin = propagator()->adjustRenamedPath(_item->_file);
|
QString origin = propagator()->adjustRenamedPath(_item->_file);
|
||||||
|
|
|
@ -293,7 +293,7 @@ void PropagateUploadFileCommon::setupUnencryptedFile()
|
||||||
}
|
}
|
||||||
|
|
||||||
void PropagateUploadFileCommon::startUploadFile() {
|
void PropagateUploadFileCommon::startUploadFile() {
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0)) {
|
if (propagator()->_abortRequested) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -335,7 +335,7 @@ void PropagateUploadFileCommon::slotComputeContentChecksum()
|
||||||
{
|
{
|
||||||
qDebug() << "Trying to compute the checksum of the file";
|
qDebug() << "Trying to compute the checksum of the file";
|
||||||
qDebug() << "Still trying to understand if this is the local file or the uploaded one";
|
qDebug() << "Still trying to understand if this is the local file or the uploaded one";
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0)) {
|
if (propagator()->_abortRequested) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -275,7 +275,7 @@ void PropagateUploadFileNG::slotMkColFinished(QNetworkReply::NetworkError)
|
||||||
|
|
||||||
void PropagateUploadFileNG::startNextChunk()
|
void PropagateUploadFileNG::startNextChunk()
|
||||||
{
|
{
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
qint64 fileSize = _fileToUpload._size;
|
qint64 fileSize = _fileToUpload._size;
|
||||||
|
|
|
@ -72,7 +72,7 @@ void PropagateUploadFileV1::doStartUpload()
|
||||||
|
|
||||||
void PropagateUploadFileV1::startNextChunk()
|
void PropagateUploadFileV1::startNextChunk()
|
||||||
{
|
{
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (!_jobs.isEmpty() && _currentChunk + _startChunk >= _chunkCount - 1) {
|
if (!_jobs.isEmpty() && _currentChunk + _startChunk >= _chunkCount - 1) {
|
||||||
|
|
|
@ -92,7 +92,7 @@ void PropagateLocalRemove::start()
|
||||||
{
|
{
|
||||||
_moveToTrash = propagator()->syncOptions()._moveFilesToTrash;
|
_moveToTrash = propagator()->syncOptions()._moveFilesToTrash;
|
||||||
|
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
QString filename = propagator()->_localDir + _item->_file;
|
QString filename = propagator()->_localDir + _item->_file;
|
||||||
|
@ -132,7 +132,7 @@ void PropagateLocalRemove::start()
|
||||||
|
|
||||||
void PropagateLocalMkdir::start()
|
void PropagateLocalMkdir::start()
|
||||||
{
|
{
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
const auto rootPath = [=]() {
|
const auto rootPath = [=]() {
|
||||||
|
@ -244,7 +244,7 @@ void PropagateLocalMkdir::startDemanglingName(const QString &parentPath)
|
||||||
|
|
||||||
void PropagateLocalRename::start()
|
void PropagateLocalRename::start()
|
||||||
{
|
{
|
||||||
if (propagator()->_abortRequested.fetchAndAddRelaxed(0))
|
if (propagator()->_abortRequested)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
QString existingFile = propagator()->getFilePath(propagator()->adjustRenamedPath(_item->_file));
|
QString existingFile = propagator()->getFilePath(propagator()->adjustRenamedPath(_item->_file));
|
||||||
|
|
|
@ -822,11 +822,8 @@ void SyncEngine::setNetworkLimits(int upload, int download)
|
||||||
_propagator->_uploadLimit = upload;
|
_propagator->_uploadLimit = upload;
|
||||||
_propagator->_downloadLimit = download;
|
_propagator->_downloadLimit = download;
|
||||||
|
|
||||||
int propDownloadLimit = _propagator->_downloadLimit.load();
|
if (upload != 0 || download != 0) {
|
||||||
int propUploadLimit = _propagator->_uploadLimit.load();
|
qCInfo(lcEngine) << "Network Limits (down/up) " << upload << download;
|
||||||
|
|
||||||
if (propDownloadLimit != 0 || propUploadLimit != 0) {
|
|
||||||
qCInfo(lcEngine) << "Network Limits (down/up) " << propDownloadLimit << propUploadLimit;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue