mirror of
https://github.com/MultiMC/MultiMC5.git
synced 2025-01-16 04:13:11 +00:00
dd0e996081
This fixes the situation when liteloader snapshot site is broken and there's an older local snapshot already present.
63 lines
958 B
C++
63 lines
958 B
C++
#pragma once
|
|
|
|
#include "Sink.h"
|
|
|
|
namespace Net {
|
|
/*
|
|
* Sink object for downloads that uses an external QByteArray it doesn't own as a target.
|
|
*/
|
|
class ByteArraySink : public Sink
|
|
{
|
|
public:
|
|
ByteArraySink(QByteArray *output)
|
|
:m_output(output)
|
|
{
|
|
// nil
|
|
};
|
|
|
|
virtual ~ByteArraySink()
|
|
{
|
|
// nil
|
|
}
|
|
|
|
public:
|
|
JobStatus init(QNetworkRequest & request) override
|
|
{
|
|
m_output->clear();
|
|
if(initAllValidators(request))
|
|
return Job_InProgress;
|
|
return Job_Failed;
|
|
};
|
|
|
|
JobStatus write(QByteArray & data) override
|
|
{
|
|
m_output->append(data);
|
|
if(writeAllValidators(data))
|
|
return Job_InProgress;
|
|
return Job_Failed;
|
|
}
|
|
|
|
JobStatus abort() override
|
|
{
|
|
m_output->clear();
|
|
failAllValidators();
|
|
return Job_Failed;
|
|
}
|
|
|
|
JobStatus finalize(QNetworkReply &reply) override
|
|
{
|
|
if(finalizeAllValidators(reply))
|
|
return Job_Finished;
|
|
return Job_Failed;
|
|
}
|
|
|
|
bool hasLocalData() override
|
|
{
|
|
return false;
|
|
}
|
|
|
|
private:
|
|
QByteArray * m_output;
|
|
};
|
|
}
|