mirror of https://github.com/procxx/kepka.git
Removed obsolete storage_file_type fields.
This commit is contained in:
parent
83720d8789
commit
31009b19c6
|
@ -1657,7 +1657,7 @@ private:
|
||||||
};
|
};
|
||||||
|
|
||||||
MTPDocumentAttribute audioReadSongAttributes(const QString &fname, const QByteArray &data, QImage &cover, QByteArray &coverBytes, QByteArray &coverFormat) {
|
MTPDocumentAttribute audioReadSongAttributes(const QString &fname, const QByteArray &data, QImage &cover, QByteArray &coverBytes, QByteArray &coverFormat) {
|
||||||
FFMpegAttributesReader reader(FileLocation(StorageFilePartial, fname), data);
|
FFMpegAttributesReader reader(FileLocation(fname), data);
|
||||||
qint64 position = 0;
|
qint64 position = 0;
|
||||||
if (reader.open(position)) {
|
if (reader.open(position)) {
|
||||||
int32 duration = reader.duration() / reader.frequency();
|
int32 duration = reader.duration() / reader.frequency();
|
||||||
|
|
|
@ -833,7 +833,7 @@ Manager::~Manager() {
|
||||||
}
|
}
|
||||||
|
|
||||||
MTPDocumentAttribute readAttributes(const QString &fname, const QByteArray &data, QImage &cover) {
|
MTPDocumentAttribute readAttributes(const QString &fname, const QByteArray &data, QImage &cover) {
|
||||||
FileLocation localloc(StorageFilePartial, fname);
|
FileLocation localloc(fname);
|
||||||
QByteArray localdata(data);
|
QByteArray localdata(data);
|
||||||
|
|
||||||
auto playId = 0ULL;
|
auto playId = 0ULL;
|
||||||
|
|
|
@ -70,7 +70,6 @@ FileLoader::FileLoader(const QString &toFile, int32 size, LocationType locationT
|
||||||
, _toCache(toCache)
|
, _toCache(toCache)
|
||||||
, _fromCloud(fromCloud)
|
, _fromCloud(fromCloud)
|
||||||
, _size(size)
|
, _size(size)
|
||||||
, _type(mtpc_storage_fileUnknown)
|
|
||||||
, _locationType(locationType) {
|
, _locationType(locationType) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -89,14 +88,8 @@ QPixmap FileLoader::imagePixmap(const QSize &shrinkBox) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileLoader::readImage(const QSize &shrinkBox) const {
|
void FileLoader::readImage(const QSize &shrinkBox) const {
|
||||||
QByteArray format;
|
auto format = QByteArray();
|
||||||
switch (_type) {
|
auto image = App::readImage(_data, &format, false);
|
||||||
case mtpc_storage_fileGif: format = "GIF"; break;
|
|
||||||
case mtpc_storage_fileJpeg: format = "JPG"; break;
|
|
||||||
case mtpc_storage_filePng: format = "PNG"; break;
|
|
||||||
default: format = QByteArray(); break;
|
|
||||||
}
|
|
||||||
QImage image = App::readImage(_data, &format, false);
|
|
||||||
if (!image.isNull()) {
|
if (!image.isNull()) {
|
||||||
if (!shrinkBox.isEmpty() && (image.width() > shrinkBox.width() || image.height() > shrinkBox.height())) {
|
if (!shrinkBox.isEmpty() && (image.width() > shrinkBox.width() || image.height() > shrinkBox.height())) {
|
||||||
_imagePixmap = App::pixmapFromImageInPlace(image.scaled(shrinkBox, Qt::KeepAspectRatio, Qt::SmoothTransformation));
|
_imagePixmap = App::pixmapFromImageInPlace(image.scaled(shrinkBox, Qt::KeepAspectRatio, Qt::SmoothTransformation));
|
||||||
|
@ -108,7 +101,7 @@ void FileLoader::readImage(const QSize &shrinkBox) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
float64 FileLoader::currentProgress() const {
|
float64 FileLoader::currentProgress() const {
|
||||||
if (_complete) return 1.;
|
if (_finished) return 1.;
|
||||||
if (!fullSize()) return 0.;
|
if (!fullSize()) return 0.;
|
||||||
return snap(float64(currentOffset()) / fullSize(), 0., 1.);
|
return snap(float64(currentOffset()) / fullSize(), 0., 1.);
|
||||||
}
|
}
|
||||||
|
@ -175,13 +168,12 @@ FileLoader::~FileLoader() {
|
||||||
|
|
||||||
void FileLoader::localLoaded(const StorageImageSaved &result, const QByteArray &imageFormat, const QPixmap &imagePixmap) {
|
void FileLoader::localLoaded(const StorageImageSaved &result, const QByteArray &imageFormat, const QPixmap &imagePixmap) {
|
||||||
_localTaskId = 0;
|
_localTaskId = 0;
|
||||||
if (result.type == StorageFileUnknown) {
|
if (result.data.isEmpty()) {
|
||||||
_localStatus = LocalFailed;
|
_localStatus = LocalFailed;
|
||||||
start(true);
|
start(true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
_data = result.data;
|
_data = result.data;
|
||||||
_type = mtpFromStorageType(result.type);
|
|
||||||
if (!imagePixmap.isNull()) {
|
if (!imagePixmap.isNull()) {
|
||||||
_imageFormat = imageFormat;
|
_imageFormat = imageFormat;
|
||||||
_imagePixmap = imagePixmap;
|
_imagePixmap = imagePixmap;
|
||||||
|
@ -199,7 +191,7 @@ void FileLoader::localLoaded(const StorageImageSaved &result, const QByteArray &
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
_complete = true;
|
_finished = true;
|
||||||
if (_fileIsOpen) {
|
if (_fileIsOpen) {
|
||||||
_file.close();
|
_file.close();
|
||||||
_fileIsOpen = false;
|
_fileIsOpen = false;
|
||||||
|
@ -218,7 +210,7 @@ void FileLoader::start(bool loadFirst, bool prior) {
|
||||||
if (_paused) {
|
if (_paused) {
|
||||||
_paused = false;
|
_paused = false;
|
||||||
}
|
}
|
||||||
if (_complete || tryLoadLocal()) return;
|
if (_finished || tryLoadLocal()) return;
|
||||||
|
|
||||||
if (_fromCloud == LoadFromLocalOnly) {
|
if (_fromCloud == LoadFromLocalOnly) {
|
||||||
cancel();
|
cancel();
|
||||||
|
@ -327,8 +319,8 @@ void FileLoader::cancel() {
|
||||||
void FileLoader::cancel(bool fail) {
|
void FileLoader::cancel(bool fail) {
|
||||||
bool started = currentOffset(true) > 0;
|
bool started = currentOffset(true) > 0;
|
||||||
cancelRequests();
|
cancelRequests();
|
||||||
_type = mtpc_storage_fileUnknown;
|
_cancelled = true;
|
||||||
_complete = true;
|
_finished = true;
|
||||||
if (_fileIsOpen) {
|
if (_fileIsOpen) {
|
||||||
_file.close();
|
_file.close();
|
||||||
_fileIsOpen = false;
|
_fileIsOpen = false;
|
||||||
|
@ -350,7 +342,7 @@ void FileLoader::cancel(bool fail) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileLoader::startLoading(bool loadFirst, bool prior) {
|
void FileLoader::startLoading(bool loadFirst, bool prior) {
|
||||||
if ((_queue->queries >= _queue->limit && (!loadFirst || !prior)) || _complete) return;
|
if ((_queue->queries >= _queue->limit && (!loadFirst || !prior)) || _finished) return;
|
||||||
loadPart();
|
loadPart();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -403,9 +395,9 @@ namespace {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool mtpFileLoader::loadPart() {
|
bool mtpFileLoader::loadPart() {
|
||||||
if (_complete || _lastComplete || (!_requests.isEmpty() && !_size)) {
|
if (_finished || _lastComplete || (!_requests.isEmpty() && !_size)) {
|
||||||
if (DebugLogging::FileLoader() && _id) {
|
if (DebugLogging::FileLoader() && _id) {
|
||||||
DEBUG_LOG(("FileLoader(%1): loadPart() returned, _complete=%2, _lastComplete=%3, _requests.size()=%4, _size=%5").arg(_id).arg(Logs::b(_complete)).arg(Logs::b(_lastComplete)).arg(_requests.size()).arg(_size));
|
DEBUG_LOG(("FileLoader(%1): loadPart() returned, _finished=%2, _lastComplete=%3, _requests.size()=%4, _size=%5").arg(_id).arg(Logs::b(_finished)).arg(Logs::b(_lastComplete)).arg(_requests.size()).arg(_size));
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -526,8 +518,7 @@ void mtpFileLoader::partLoaded(int32 offset, const MTPupload_File &result, mtpRe
|
||||||
return cancel(true);
|
return cancel(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_type = d.vtype.type();
|
_finished = true;
|
||||||
_complete = true;
|
|
||||||
if (_fileIsOpen) {
|
if (_fileIsOpen) {
|
||||||
_file.close();
|
_file.close();
|
||||||
_fileIsOpen = false;
|
_fileIsOpen = false;
|
||||||
|
@ -543,7 +534,7 @@ void mtpFileLoader::partLoaded(int32 offset, const MTPupload_File &result, mtpRe
|
||||||
if (_locationType != UnknownFileLocation) { // audio, video, document
|
if (_locationType != UnknownFileLocation) { // audio, video, document
|
||||||
MediaKey mkey = mediaKey(_locationType, _dc, _id, _version);
|
MediaKey mkey = mediaKey(_locationType, _dc, _id, _version);
|
||||||
if (!_fname.isEmpty()) {
|
if (!_fname.isEmpty()) {
|
||||||
Local::writeFileLocation(mkey, FileLocation(mtpToStorageType(_type), _fname));
|
Local::writeFileLocation(mkey, FileLocation(_fname));
|
||||||
}
|
}
|
||||||
if (_toCache == LoadToCacheAsWell) {
|
if (_toCache == LoadToCacheAsWell) {
|
||||||
if (_locationType == DocumentFileLocation) {
|
if (_locationType == DocumentFileLocation) {
|
||||||
|
@ -553,7 +544,7 @@ void mtpFileLoader::partLoaded(int32 offset, const MTPupload_File &result, mtpRe
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Local::writeImage(storageKey(*_location), StorageImageSaved(mtpToStorageType(_type), _data));
|
Local::writeImage(storageKey(*_location), StorageImageSaved(_data));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -561,7 +552,7 @@ void mtpFileLoader::partLoaded(int32 offset, const MTPupload_File &result, mtpRe
|
||||||
DEBUG_LOG(("FileLoader(%1): not done yet, _lastComplete=%2, _size=%3, _nextRequestOffset=%4, _requests=%5").arg(_id).arg(Logs::b(_lastComplete)).arg(_size).arg(_nextRequestOffset).arg(serializereqs(_requests)));
|
DEBUG_LOG(("FileLoader(%1): not done yet, _lastComplete=%2, _size=%3, _nextRequestOffset=%4, _requests=%5").arg(_id).arg(Logs::b(_lastComplete)).arg(_size).arg(_nextRequestOffset).arg(serializereqs(_requests)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (_complete) {
|
if (_finished) {
|
||||||
FileDownload::ImageLoaded().notify();
|
FileDownload::ImageLoaded().notify();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -623,7 +614,7 @@ bool mtpFileLoader::tryLoadLocal() {
|
||||||
MustNotDestroy.erase(this);
|
MustNotDestroy.erase(this);
|
||||||
|
|
||||||
if (_localStatus != LocalNotTried) {
|
if (_localStatus != LocalNotTried) {
|
||||||
return _complete;
|
return _finished;
|
||||||
} else if (_localTaskId) {
|
} else if (_localTaskId) {
|
||||||
_localStatus = LocalLoading;
|
_localStatus = LocalLoading;
|
||||||
return true;
|
return true;
|
||||||
|
@ -645,7 +636,7 @@ webFileLoader::webFileLoader(const QString &url, const QString &to, LoadFromClou
|
||||||
}
|
}
|
||||||
|
|
||||||
bool webFileLoader::loadPart() {
|
bool webFileLoader::loadPart() {
|
||||||
if (_complete || _requestSent || _webLoadManager == FinishedWebLoadManager) return false;
|
if (_finished || _requestSent || _webLoadManager == FinishedWebLoadManager) return false;
|
||||||
if (!_webLoadManager) {
|
if (!_webLoadManager) {
|
||||||
_webLoadMainManager = new WebLoadMainManager();
|
_webLoadMainManager = new WebLoadMainManager();
|
||||||
|
|
||||||
|
@ -688,8 +679,7 @@ void webFileLoader::onFinished(const QByteArray &data) {
|
||||||
return cancel(true);
|
return cancel(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_type = mtpc_storage_filePartial;
|
_finished = true;
|
||||||
_complete = true;
|
|
||||||
if (_fileIsOpen) {
|
if (_fileIsOpen) {
|
||||||
_file.close();
|
_file.close();
|
||||||
_fileIsOpen = false;
|
_fileIsOpen = false;
|
||||||
|
@ -723,7 +713,7 @@ bool webFileLoader::tryLoadLocal() {
|
||||||
|
|
||||||
_localTaskId = Local::startWebFileLoad(_url, this);
|
_localTaskId = Local::startWebFileLoad(_url, this);
|
||||||
if (_localStatus != LocalNotTried) {
|
if (_localStatus != LocalNotTried) {
|
||||||
return _complete;
|
return _finished;
|
||||||
} else if (_localTaskId) {
|
} else if (_localTaskId) {
|
||||||
_localStatus = LocalLoading;
|
_localStatus = LocalLoading;
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -35,55 +35,13 @@ enum LocationType {
|
||||||
VideoFileLocation = 0x3d0364ec, // mtpc_inputVideoFileLocation
|
VideoFileLocation = 0x3d0364ec, // mtpc_inputVideoFileLocation
|
||||||
};
|
};
|
||||||
|
|
||||||
enum StorageFileType {
|
|
||||||
StorageFileUnknown = 0xaa963b05, // mtpc_storage_fileUnknown
|
|
||||||
StorageFileJpeg = 0x7efe0e, // mtpc_storage_fileJpeg
|
|
||||||
StorageFileGif = 0xcae1aadf, // mtpc_storage_fileGif
|
|
||||||
StorageFilePng = 0xa4f63c0, // mtpc_storage_filePng
|
|
||||||
StorageFilePdf = 0xae1e508d, // mtpc_storage_filePdf
|
|
||||||
StorageFileMp3 = 0x528a0677, // mtpc_storage_fileMp3
|
|
||||||
StorageFileMov = 0x4b09ebbc, // mtpc_storage_fileMov
|
|
||||||
StorageFilePartial = 0x40bc6f52, // mtpc_storage_filePartial
|
|
||||||
StorageFileMp4 = 0xb3cea0e4, // mtpc_storage_fileMp4
|
|
||||||
StorageFileWebp = 0x1081464c, // mtpc_storage_fileWebp
|
|
||||||
};
|
|
||||||
inline StorageFileType mtpToStorageType(mtpTypeId type) {
|
|
||||||
switch (type) {
|
|
||||||
case mtpc_storage_fileJpeg: return StorageFileJpeg;
|
|
||||||
case mtpc_storage_fileGif: return StorageFileGif;
|
|
||||||
case mtpc_storage_filePng: return StorageFilePng;
|
|
||||||
case mtpc_storage_filePdf: return StorageFilePdf;
|
|
||||||
case mtpc_storage_fileMp3: return StorageFileMp3;
|
|
||||||
case mtpc_storage_fileMov: return StorageFileMov;
|
|
||||||
case mtpc_storage_filePartial: return StorageFilePartial;
|
|
||||||
case mtpc_storage_fileMp4: return StorageFileMp4;
|
|
||||||
case mtpc_storage_fileWebp: return StorageFileWebp;
|
|
||||||
case mtpc_storage_fileUnknown:
|
|
||||||
default: return StorageFileUnknown;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
inline mtpTypeId mtpFromStorageType(StorageFileType type) {
|
|
||||||
switch (type) {
|
|
||||||
case StorageFileJpeg: return mtpc_storage_fileJpeg;
|
|
||||||
case StorageFileGif: return mtpc_storage_fileGif;
|
|
||||||
case StorageFilePng: return mtpc_storage_filePng;
|
|
||||||
case StorageFilePdf: return mtpc_storage_filePdf;
|
|
||||||
case StorageFileMp3: return mtpc_storage_fileMp3;
|
|
||||||
case StorageFileMov: return mtpc_storage_fileMov;
|
|
||||||
case StorageFilePartial: return mtpc_storage_filePartial;
|
|
||||||
case StorageFileMp4: return mtpc_storage_fileMp4;
|
|
||||||
case StorageFileWebp: return mtpc_storage_fileWebp;
|
|
||||||
case StorageFileUnknown:
|
|
||||||
default: return mtpc_storage_fileUnknown;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
struct StorageImageSaved {
|
struct StorageImageSaved {
|
||||||
StorageImageSaved() : type(StorageFileUnknown) {
|
StorageImageSaved() = default;
|
||||||
|
explicit StorageImageSaved(const QByteArray &data) : data(data) {
|
||||||
}
|
}
|
||||||
StorageImageSaved(StorageFileType type, const QByteArray &data) : type(type), data(data) {
|
|
||||||
}
|
|
||||||
StorageFileType type;
|
|
||||||
QByteArray data;
|
QByteArray data;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
enum LocalLoadStatus {
|
enum LocalLoadStatus {
|
||||||
|
@ -114,11 +72,11 @@ class FileLoader : public QObject {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
FileLoader(const QString &toFile, int32 size, LocationType locationType, LoadToCacheSetting, LoadFromCloudSetting fromCloud, bool autoLoading);
|
FileLoader(const QString &toFile, int32 size, LocationType locationType, LoadToCacheSetting, LoadFromCloudSetting fromCloud, bool autoLoading);
|
||||||
bool done() const {
|
bool finished() const {
|
||||||
return _complete;
|
return _finished;
|
||||||
}
|
}
|
||||||
mtpTypeId fileType() const {
|
bool cancelled() const {
|
||||||
return _type;
|
return _cancelled;
|
||||||
}
|
}
|
||||||
const QByteArray &bytes() const {
|
const QByteArray &bytes() const {
|
||||||
return _data;
|
return _data;
|
||||||
|
@ -179,7 +137,8 @@ protected:
|
||||||
bool _paused = false;
|
bool _paused = false;
|
||||||
bool _autoLoading = false;
|
bool _autoLoading = false;
|
||||||
bool _inQueue = false;
|
bool _inQueue = false;
|
||||||
bool _complete = false;
|
bool _finished = false;
|
||||||
|
bool _cancelled = false;
|
||||||
mutable LocalLoadStatus _localStatus = LocalNotTried;
|
mutable LocalLoadStatus _localStatus = LocalNotTried;
|
||||||
|
|
||||||
virtual bool tryLoadLocal() = 0;
|
virtual bool tryLoadLocal() = 0;
|
||||||
|
@ -202,7 +161,6 @@ protected:
|
||||||
QByteArray _data;
|
QByteArray _data;
|
||||||
|
|
||||||
int32 _size;
|
int32 _size;
|
||||||
mtpTypeId _type;
|
|
||||||
LocationType _locationType;
|
LocationType _locationType;
|
||||||
|
|
||||||
TaskId _localTaskId = 0;
|
TaskId _localTaskId = 0;
|
||||||
|
|
|
@ -43,7 +43,7 @@ void FileUploader::uploadMedia(const FullMsgId &msgId, const SendMediaReady &med
|
||||||
document->setData(media.data);
|
document->setData(media.data);
|
||||||
}
|
}
|
||||||
if (!media.file.isEmpty()) {
|
if (!media.file.isEmpty()) {
|
||||||
document->setLocation(FileLocation(StorageFilePartial, media.file));
|
document->setLocation(FileLocation(media.file));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
queue.insert(msgId, File(media));
|
queue.insert(msgId, File(media));
|
||||||
|
@ -66,7 +66,7 @@ void FileUploader::upload(const FullMsgId &msgId, const FileLoadResultPtr &file)
|
||||||
document->setData(file->content);
|
document->setData(file->content);
|
||||||
}
|
}
|
||||||
if (!file->filepath.isEmpty()) {
|
if (!file->filepath.isEmpty()) {
|
||||||
document->setLocation(FileLocation(StorageFilePartial, file->filepath));
|
document->setLocation(FileLocation(file->filepath));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
queue.insert(msgId, File(file));
|
queue.insert(msgId, File(file));
|
||||||
|
|
|
@ -691,8 +691,9 @@ void _writeLocations(WriteMapWhen when = WriteMapSoon) {
|
||||||
}
|
}
|
||||||
|
|
||||||
EncryptedDescriptor data(size);
|
EncryptedDescriptor data(size);
|
||||||
|
auto legacyTypeField = 0;
|
||||||
for (FileLocations::const_iterator i = _fileLocations.cbegin(); i != _fileLocations.cend(); ++i) {
|
for (FileLocations::const_iterator i = _fileLocations.cbegin(); i != _fileLocations.cend(); ++i) {
|
||||||
data.stream << quint64(i.key().first) << quint64(i.key().second) << quint32(i.value().type) << i.value().name();
|
data.stream << quint64(i.key().first) << quint64(i.key().second) << quint32(legacyTypeField) << i.value().name();
|
||||||
if (AppVersion > 9013) {
|
if (AppVersion > 9013) {
|
||||||
data.stream << i.value().bookmark();
|
data.stream << i.value().bookmark();
|
||||||
}
|
}
|
||||||
|
@ -734,21 +735,20 @@ void _readLocations() {
|
||||||
quint64 first, second;
|
quint64 first, second;
|
||||||
QByteArray bookmark;
|
QByteArray bookmark;
|
||||||
FileLocation loc;
|
FileLocation loc;
|
||||||
quint32 type;
|
quint32 legacyTypeField = 0;
|
||||||
locations.stream >> first >> second >> type >> loc.fname;
|
locations.stream >> first >> second >> legacyTypeField >> loc.fname;
|
||||||
if (locations.version > 9013) {
|
if (locations.version > 9013) {
|
||||||
locations.stream >> bookmark;
|
locations.stream >> bookmark;
|
||||||
}
|
}
|
||||||
locations.stream >> loc.modified >> loc.size;
|
locations.stream >> loc.modified >> loc.size;
|
||||||
loc.setBookmark(bookmark);
|
loc.setBookmark(bookmark);
|
||||||
|
|
||||||
if (!first && !second && !type && loc.fname.isEmpty() && !loc.size) { // end mark
|
if (!first && !second && !legacyTypeField && loc.fname.isEmpty() && !loc.size) { // end mark
|
||||||
endMarkFound = true;
|
endMarkFound = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
MediaKey key(first, second);
|
MediaKey key(first, second);
|
||||||
loc.type = StorageFileType(type);
|
|
||||||
|
|
||||||
_fileLocations.insert(key, loc);
|
_fileLocations.insert(key, loc);
|
||||||
_fileLocationPairs.insert(loc.fname, FileLocationPair(key, loc));
|
_fileLocationPairs.insert(loc.fname, FileLocationPair(key, loc));
|
||||||
|
@ -2628,19 +2628,8 @@ void writeImage(const StorageKey &location, const ImagePtr &image) {
|
||||||
if (image->isNull() || !image->loaded()) return;
|
if (image->isNull() || !image->loaded()) return;
|
||||||
if (_imagesMap.constFind(location) != _imagesMap.cend()) return;
|
if (_imagesMap.constFind(location) != _imagesMap.cend()) return;
|
||||||
|
|
||||||
QByteArray fmt = image->savedFormat();
|
image->forget();
|
||||||
StorageFileType format = StorageFileUnknown;
|
writeImage(location, StorageImageSaved(image->savedData()), false);
|
||||||
if (fmt == "JPG") {
|
|
||||||
format = StorageFileJpeg;
|
|
||||||
} else if (fmt == "PNG") {
|
|
||||||
format = StorageFilePng;
|
|
||||||
} else if (fmt == "GIF") {
|
|
||||||
format = StorageFileGif;
|
|
||||||
}
|
|
||||||
if (format) {
|
|
||||||
image->forget();
|
|
||||||
writeImage(location, StorageImageSaved(format, image->savedData()), false);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void writeImage(const StorageKey &location, const StorageImageSaved &image, bool overwrite) {
|
void writeImage(const StorageKey &location, const StorageImageSaved &image, bool overwrite) {
|
||||||
|
@ -2656,8 +2645,12 @@ void writeImage(const StorageKey &location, const StorageImageSaved &image, bool
|
||||||
} else if (!overwrite) {
|
} else if (!overwrite) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
auto legacyTypeField = 0;
|
||||||
|
|
||||||
EncryptedDescriptor data(sizeof(quint64) * 2 + sizeof(quint32) + sizeof(quint32) + image.data.size());
|
EncryptedDescriptor data(sizeof(quint64) * 2 + sizeof(quint32) + sizeof(quint32) + image.data.size());
|
||||||
data.stream << quint64(location.first) << quint64(location.second) << quint32(image.type) << image.data;
|
data.stream << quint64(location.first) << quint64(location.second) << quint32(legacyTypeField) << image.data;
|
||||||
|
|
||||||
FileWriteDescriptor file(i.value().first, FileOption::User);
|
FileWriteDescriptor file(i.value().first, FileOption::User);
|
||||||
file.writeEncrypted(data);
|
file.writeEncrypted(data);
|
||||||
if (i.value().second != size) {
|
if (i.value().second != size) {
|
||||||
|
@ -2681,15 +2674,15 @@ public:
|
||||||
|
|
||||||
QByteArray imageData;
|
QByteArray imageData;
|
||||||
quint64 locFirst, locSecond;
|
quint64 locFirst, locSecond;
|
||||||
quint32 imageType;
|
quint32 legacyTypeField = 0;
|
||||||
readFromStream(image.stream, locFirst, locSecond, imageType, imageData);
|
readFromStream(image.stream, locFirst, locSecond, imageData);
|
||||||
|
|
||||||
// we're saving files now before we have actual location
|
// we're saving files now before we have actual location
|
||||||
//if (locFirst != _location.first || locSecond != _location.second) {
|
//if (locFirst != _location.first || locSecond != _location.second) {
|
||||||
// return;
|
// return;
|
||||||
//}
|
//}
|
||||||
|
|
||||||
_result = new Result(StorageFileType(imageType), imageData, _readImageFlag);
|
_result = new Result(imageData, _readImageFlag);
|
||||||
}
|
}
|
||||||
void finish() {
|
void finish() {
|
||||||
if (_result) {
|
if (_result) {
|
||||||
|
@ -2699,7 +2692,7 @@ public:
|
||||||
_loader->localLoaded(StorageImageSaved());
|
_loader->localLoaded(StorageImageSaved());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
virtual void readFromStream(QDataStream &stream, quint64 &first, quint64 &second, quint32 &type, QByteArray &data) = 0;
|
virtual void readFromStream(QDataStream &stream, quint64 &first, quint64 &second, QByteArray &data) = 0;
|
||||||
virtual void clearInMap() = 0;
|
virtual void clearInMap() = 0;
|
||||||
virtual ~AbstractCachedLoadTask() {
|
virtual ~AbstractCachedLoadTask() {
|
||||||
delete base::take(_result);
|
delete base::take(_result);
|
||||||
|
@ -2710,25 +2703,19 @@ protected:
|
||||||
StorageKey _location;
|
StorageKey _location;
|
||||||
bool _readImageFlag;
|
bool _readImageFlag;
|
||||||
struct Result {
|
struct Result {
|
||||||
Result(StorageFileType type, const QByteArray &data, bool readImageFlag) : image(type, data) {
|
Result(const QByteArray &data, bool readImageFlag) : image(data) {
|
||||||
if (readImageFlag) {
|
if (readImageFlag) {
|
||||||
QByteArray guessFormat;
|
auto realFormat = QByteArray();
|
||||||
switch (type) {
|
pixmap = App::pixmapFromImageInPlace(App::readImage(data, &realFormat, false));
|
||||||
case StorageFileGif: guessFormat = "GIF"; break;
|
|
||||||
case StorageFileJpeg: guessFormat = "JPG"; break;
|
|
||||||
case StorageFilePng: guessFormat = "PNG"; break;
|
|
||||||
case StorageFileWebp: guessFormat = "WEBP"; break;
|
|
||||||
default: guessFormat = QByteArray(); break;
|
|
||||||
}
|
|
||||||
pixmap = App::pixmapFromImageInPlace(App::readImage(data, &guessFormat, false));
|
|
||||||
if (!pixmap.isNull()) {
|
if (!pixmap.isNull()) {
|
||||||
format = guessFormat;
|
format = realFormat;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
StorageImageSaved image;
|
StorageImageSaved image;
|
||||||
QByteArray format;
|
QByteArray format;
|
||||||
QPixmap pixmap;
|
QPixmap pixmap;
|
||||||
|
|
||||||
};
|
};
|
||||||
mtpFileLoader *_loader;
|
mtpFileLoader *_loader;
|
||||||
Result *_result;
|
Result *_result;
|
||||||
|
@ -2740,8 +2727,9 @@ public:
|
||||||
ImageLoadTask(const FileKey &key, const StorageKey &location, mtpFileLoader *loader) :
|
ImageLoadTask(const FileKey &key, const StorageKey &location, mtpFileLoader *loader) :
|
||||||
AbstractCachedLoadTask(key, location, true, loader) {
|
AbstractCachedLoadTask(key, location, true, loader) {
|
||||||
}
|
}
|
||||||
void readFromStream(QDataStream &stream, quint64 &first, quint64 &second, quint32 &type, QByteArray &data) {
|
void readFromStream(QDataStream &stream, quint64 &first, quint64 &second, QByteArray &data) override {
|
||||||
stream >> first >> second >> type >> data;
|
qint32 legacyTypeField = 0;
|
||||||
|
stream >> first >> second >> legacyTypeField >> data;
|
||||||
}
|
}
|
||||||
void clearInMap() {
|
void clearInMap() {
|
||||||
StorageMap::iterator j = _imagesMap.find(_location);
|
StorageMap::iterator j = _imagesMap.find(_location);
|
||||||
|
@ -2798,9 +2786,8 @@ public:
|
||||||
StickerImageLoadTask(const FileKey &key, const StorageKey &location, mtpFileLoader *loader) :
|
StickerImageLoadTask(const FileKey &key, const StorageKey &location, mtpFileLoader *loader) :
|
||||||
AbstractCachedLoadTask(key, location, true, loader) {
|
AbstractCachedLoadTask(key, location, true, loader) {
|
||||||
}
|
}
|
||||||
void readFromStream(QDataStream &stream, quint64 &first, quint64 &second, quint32 &type, QByteArray &data) {
|
void readFromStream(QDataStream &stream, quint64 &first, quint64 &second, QByteArray &data) {
|
||||||
stream >> first >> second >> data;
|
stream >> first >> second >> data;
|
||||||
type = StorageFilePartial;
|
|
||||||
}
|
}
|
||||||
void clearInMap() {
|
void clearInMap() {
|
||||||
auto j = _stickerImagesMap.find(_location);
|
auto j = _stickerImagesMap.find(_location);
|
||||||
|
@ -2872,9 +2859,8 @@ public:
|
||||||
AudioLoadTask(const FileKey &key, const StorageKey &location, mtpFileLoader *loader) :
|
AudioLoadTask(const FileKey &key, const StorageKey &location, mtpFileLoader *loader) :
|
||||||
AbstractCachedLoadTask(key, location, false, loader) {
|
AbstractCachedLoadTask(key, location, false, loader) {
|
||||||
}
|
}
|
||||||
void readFromStream(QDataStream &stream, quint64 &first, quint64 &second, quint32 &type, QByteArray &data) {
|
void readFromStream(QDataStream &stream, quint64 &first, quint64 &second, QByteArray &data) {
|
||||||
stream >> first >> second >> data;
|
stream >> first >> second >> data;
|
||||||
type = StorageFilePartial;
|
|
||||||
}
|
}
|
||||||
void clearInMap() {
|
void clearInMap() {
|
||||||
auto j = _audiosMap.find(_location);
|
auto j = _audiosMap.find(_location);
|
||||||
|
@ -2962,7 +2948,7 @@ public:
|
||||||
QString url;
|
QString url;
|
||||||
image.stream >> url >> imageData;
|
image.stream >> url >> imageData;
|
||||||
|
|
||||||
_result = new Result(StorageFilePartial, imageData);
|
_result = new Result(imageData);
|
||||||
}
|
}
|
||||||
void finish() {
|
void finish() {
|
||||||
if (_result) {
|
if (_result) {
|
||||||
|
@ -2985,7 +2971,7 @@ protected:
|
||||||
FileKey _key;
|
FileKey _key;
|
||||||
QString _url;
|
QString _url;
|
||||||
struct Result {
|
struct Result {
|
||||||
Result(StorageFileType type, const QByteArray &data) : image(type, data) {
|
explicit Result(const QByteArray &data) : image(data) {
|
||||||
QByteArray guessFormat;
|
QByteArray guessFormat;
|
||||||
pixmap = App::pixmapFromImageInPlace(App::readImage(data, &guessFormat, false));
|
pixmap = App::pixmapFromImageInPlace(App::readImage(data, &guessFormat, false));
|
||||||
if (!pixmap.isNull()) {
|
if (!pixmap.isNull()) {
|
||||||
|
@ -2995,6 +2981,7 @@ protected:
|
||||||
StorageImageSaved image;
|
StorageImageSaved image;
|
||||||
QByteArray format;
|
QByteArray format;
|
||||||
QPixmap pixmap;
|
QPixmap pixmap;
|
||||||
|
|
||||||
};
|
};
|
||||||
webFileLoader *_loader;
|
webFileLoader *_loader;
|
||||||
Result *_result;
|
Result *_result;
|
||||||
|
|
|
@ -1520,12 +1520,12 @@ void DocumentData::performActionOnLoad() {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool DocumentData::loaded(FilePathResolveType type) const {
|
bool DocumentData::loaded(FilePathResolveType type) const {
|
||||||
if (loading() && _loader->done()) {
|
if (loading() && _loader->finished()) {
|
||||||
if (_loader->fileType() == mtpc_storage_fileUnknown) {
|
if (_loader->cancelled()) {
|
||||||
destroyLoaderDelayed(CancelledMtpFileLoader);
|
destroyLoaderDelayed(CancelledMtpFileLoader);
|
||||||
} else {
|
} else {
|
||||||
auto that = const_cast<DocumentData*>(this);
|
auto that = const_cast<DocumentData*>(this);
|
||||||
that->_location = FileLocation(mtpToStorageType(_loader->fileType()), _loader->fileName());
|
that->_location = FileLocation(_loader->fileName());
|
||||||
that->_data = _loader->bytes();
|
that->_data = _loader->bytes();
|
||||||
if (that->sticker() && !_loader->imagePixmap().isNull()) {
|
if (that->sticker() && !_loader->imagePixmap().isNull()) {
|
||||||
that->sticker()->img = ImagePtr(_data, _loader->imageFormat(), _loader->imagePixmap());
|
that->sticker()->img = ImagePtr(_data, _loader->imageFormat(), _loader->imagePixmap());
|
||||||
|
@ -1580,8 +1580,8 @@ void DocumentData::save(const QString &toFile, ActionOnLoad action, const FullMs
|
||||||
f.write(_data);
|
f.write(_data);
|
||||||
f.close();
|
f.close();
|
||||||
|
|
||||||
setLocation(FileLocation(StorageFilePartial, toFile));
|
setLocation(FileLocation(toFile));
|
||||||
Local::writeFileLocation(mediaKey(), FileLocation(mtpToStorageType(mtpc_storage_filePartial), toFile));
|
Local::writeFileLocation(mediaKey(), FileLocation(toFile));
|
||||||
} else if (l.accessEnable()) {
|
} else if (l.accessEnable()) {
|
||||||
auto alreadyName = l.name();
|
auto alreadyName = l.name();
|
||||||
if (alreadyName != toFile) {
|
if (alreadyName != toFile) {
|
||||||
|
@ -1738,7 +1738,7 @@ QString DocumentData::filepath(FilePathResolveType type, bool forceSavingAs) con
|
||||||
if (f.open(QIODevice::WriteOnly)) {
|
if (f.open(QIODevice::WriteOnly)) {
|
||||||
if (f.write(data()) == data().size()) {
|
if (f.write(data()) == data().size()) {
|
||||||
f.close();
|
f.close();
|
||||||
const_cast<DocumentData*>(this)->_location = FileLocation(StorageFilePartial, filename);
|
const_cast<DocumentData*>(this)->_location = FileLocation(filename);
|
||||||
Local::writeFileLocation(mediaKey(), _location);
|
Local::writeFileLocation(mediaKey(), _location);
|
||||||
result = filename;
|
result = filename;
|
||||||
}
|
}
|
||||||
|
|
|
@ -823,7 +823,7 @@ int64 imageCacheSize() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void RemoteImage::doCheckload() const {
|
void RemoteImage::doCheckload() const {
|
||||||
if (!amLoading() || !_loader->done()) return;
|
if (!amLoading() || !_loader->finished()) return;
|
||||||
|
|
||||||
QPixmap data = _loader->imagePixmap(shrinkBox());
|
QPixmap data = _loader->imagePixmap(shrinkBox());
|
||||||
if (data.isNull()) {
|
if (data.isNull()) {
|
||||||
|
@ -969,7 +969,7 @@ StorageImage::StorageImage(const StorageImageLocation &location, QByteArray &byt
|
||||||
, _size(bytes.size()) {
|
, _size(bytes.size()) {
|
||||||
setData(bytes);
|
setData(bytes);
|
||||||
if (!_location.isNull()) {
|
if (!_location.isNull()) {
|
||||||
Local::writeImage(storageKey(_location), StorageImageSaved(mtpToStorageType(mtpc_storage_filePartial), bytes));
|
Local::writeImage(storageKey(_location), StorageImageSaved(bytes));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1178,7 +1178,7 @@ StorageImage *getImage(const StorageImageLocation &location, const QByteArray &b
|
||||||
QByteArray bytesArr(bytes);
|
QByteArray bytesArr(bytes);
|
||||||
i.value()->setData(bytesArr);
|
i.value()->setData(bytesArr);
|
||||||
if (!location.isNull()) {
|
if (!location.isNull()) {
|
||||||
Local::writeImage(key, StorageImageSaved(mtpToStorageType(mtpc_storage_filePartial), bytes));
|
Local::writeImage(key, StorageImageSaved(bytes));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return i.value();
|
return i.value();
|
||||||
|
@ -1196,10 +1196,9 @@ ReadAccessEnabler::~ReadAccessEnabler() {
|
||||||
if (_bookmark && !_failed) _bookmark->disable();
|
if (_bookmark && !_failed) _bookmark->disable();
|
||||||
}
|
}
|
||||||
|
|
||||||
FileLocation::FileLocation(StorageFileType type, const QString &name) : type(type), fname(name) {
|
FileLocation::FileLocation(const QString &name) : fname(name) {
|
||||||
if (fname.isEmpty()) {
|
if (fname.isEmpty()) {
|
||||||
size = 0;
|
size = 0;
|
||||||
type = StorageFileUnknown;
|
|
||||||
} else {
|
} else {
|
||||||
setBookmark(psPathBookmark(name));
|
setBookmark(psPathBookmark(name));
|
||||||
|
|
||||||
|
@ -1210,7 +1209,6 @@ FileLocation::FileLocation(StorageFileType type, const QString &name) : type(typ
|
||||||
fname = QString();
|
fname = QString();
|
||||||
_bookmark.clear();
|
_bookmark.clear();
|
||||||
size = 0;
|
size = 0;
|
||||||
type = StorageFileUnknown;
|
|
||||||
} else {
|
} else {
|
||||||
modified = f.lastModified();
|
modified = f.lastModified();
|
||||||
size = qint32(s);
|
size = qint32(s);
|
||||||
|
@ -1219,7 +1217,6 @@ FileLocation::FileLocation(StorageFileType type, const QString &name) : type(typ
|
||||||
fname = QString();
|
fname = QString();
|
||||||
_bookmark.clear();
|
_bookmark.clear();
|
||||||
size = 0;
|
size = 0;
|
||||||
type = StorageFileUnknown;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -483,9 +483,8 @@ private:
|
||||||
|
|
||||||
class FileLocation {
|
class FileLocation {
|
||||||
public:
|
public:
|
||||||
FileLocation(StorageFileType type, const QString &name);
|
FileLocation() = default;
|
||||||
FileLocation() : size(0) {
|
explicit FileLocation(const QString &name);
|
||||||
}
|
|
||||||
|
|
||||||
bool check() const;
|
bool check() const;
|
||||||
const QString &name() const;
|
const QString &name() const;
|
||||||
|
@ -498,7 +497,6 @@ public:
|
||||||
bool accessEnable() const;
|
bool accessEnable() const;
|
||||||
void accessDisable() const;
|
void accessDisable() const;
|
||||||
|
|
||||||
StorageFileType type;
|
|
||||||
QString fname;
|
QString fname;
|
||||||
QDateTime modified;
|
QDateTime modified;
|
||||||
qint32 size;
|
qint32 size;
|
||||||
|
@ -508,7 +506,7 @@ private:
|
||||||
|
|
||||||
};
|
};
|
||||||
inline bool operator==(const FileLocation &a, const FileLocation &b) {
|
inline bool operator==(const FileLocation &a, const FileLocation &b) {
|
||||||
return a.type == b.type && a.name() == b.name() && a.modified == b.modified && a.size == b.size;
|
return (a.name() == b.name()) && (a.modified == b.modified) && (a.size == b.size);
|
||||||
}
|
}
|
||||||
inline bool operator!=(const FileLocation &a, const FileLocation &b) {
|
inline bool operator!=(const FileLocation &a, const FileLocation &b) {
|
||||||
return !(a == b);
|
return !(a == b);
|
||||||
|
|
Loading…
Reference in New Issue