Add document flags.
This commit is contained in:
parent
466853496b
commit
ba5643f775
|
@ -20,22 +20,63 @@ template <class StorerT>
|
||||||
void DocumentsManager::store_document(FileId file_id, StorerT &storer) const {
|
void DocumentsManager::store_document(FileId file_id, StorerT &storer) const {
|
||||||
const GeneralDocument *document = get_document(file_id);
|
const GeneralDocument *document = get_document(file_id);
|
||||||
CHECK(document != nullptr);
|
CHECK(document != nullptr);
|
||||||
store(document->file_name, storer);
|
bool has_file_name = !document->file_name.empty();
|
||||||
store(document->mime_type, storer);
|
bool has_mime_type = !document->mime_type.empty();
|
||||||
store(document->minithumbnail, storer);
|
bool has_minithumbnail = !document->minithumbnail.empty();
|
||||||
store(document->thumbnail, storer);
|
bool has_thumbnail = document->thumbnail.file_id.is_valid();
|
||||||
|
BEGIN_STORE_FLAGS();
|
||||||
|
STORE_FLAG(has_file_name);
|
||||||
|
STORE_FLAG(has_mime_type);
|
||||||
|
STORE_FLAG(has_minithumbnail);
|
||||||
|
STORE_FLAG(has_thumbnail);
|
||||||
|
END_STORE_FLAGS();
|
||||||
|
if (has_file_name) {
|
||||||
|
store(document->file_name, storer);
|
||||||
|
}
|
||||||
|
if (has_mime_type) {
|
||||||
|
store(document->mime_type, storer);
|
||||||
|
}
|
||||||
|
if (has_minithumbnail) {
|
||||||
|
store(document->minithumbnail, storer);
|
||||||
|
}
|
||||||
|
if (has_thumbnail) {
|
||||||
|
store(document->thumbnail, storer);
|
||||||
|
}
|
||||||
store(file_id, storer);
|
store(file_id, storer);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class ParserT>
|
template <class ParserT>
|
||||||
FileId DocumentsManager::parse_document(ParserT &parser) {
|
FileId DocumentsManager::parse_document(ParserT &parser) {
|
||||||
auto document = make_unique<GeneralDocument>();
|
auto document = make_unique<GeneralDocument>();
|
||||||
parse(document->file_name, parser);
|
bool has_file_name;
|
||||||
parse(document->mime_type, parser);
|
bool has_mime_type;
|
||||||
if (parser.version() >= static_cast<int32>(Version::SupportMinithumbnails)) {
|
bool has_minithumbnail;
|
||||||
|
bool has_thumbnail;
|
||||||
|
if (parser.version() >= static_cast<int32>(Version::AddDocumentFlags)) {
|
||||||
|
BEGIN_PARSE_FLAGS();
|
||||||
|
PARSE_FLAG(has_file_name);
|
||||||
|
PARSE_FLAG(has_mime_type);
|
||||||
|
PARSE_FLAG(has_minithumbnail);
|
||||||
|
PARSE_FLAG(has_thumbnail);
|
||||||
|
END_PARSE_FLAGS();
|
||||||
|
} else {
|
||||||
|
has_file_name = true;
|
||||||
|
has_mime_type = true;
|
||||||
|
has_minithumbnail = parser.version() >= static_cast<int32>(Version::SupportMinithumbnails);
|
||||||
|
has_thumbnail = true;
|
||||||
|
}
|
||||||
|
if (has_file_name) {
|
||||||
|
parse(document->file_name, parser);
|
||||||
|
}
|
||||||
|
if (has_mime_type) {
|
||||||
|
parse(document->mime_type, parser);
|
||||||
|
}
|
||||||
|
if (has_minithumbnail) {
|
||||||
parse(document->minithumbnail, parser);
|
parse(document->minithumbnail, parser);
|
||||||
}
|
}
|
||||||
parse(document->thumbnail, parser);
|
if (has_thumbnail) {
|
||||||
|
parse(document->thumbnail, parser);
|
||||||
|
}
|
||||||
parse(document->file_id, parser);
|
parse(document->file_id, parser);
|
||||||
if (parser.get_error() != nullptr || !document->file_id.is_valid()) {
|
if (parser.get_error() != nullptr || !document->file_id.is_valid()) {
|
||||||
return FileId();
|
return FileId();
|
||||||
|
|
|
@ -60,6 +60,7 @@ enum class Version : int32 {
|
||||||
AddMessageChatSetTtlFlags,
|
AddMessageChatSetTtlFlags,
|
||||||
AddMessageMediaSpoiler, // 45
|
AddMessageMediaSpoiler, // 45
|
||||||
MakeParticipantFlags64Bit,
|
MakeParticipantFlags64Bit,
|
||||||
|
AddDocumentFlags,
|
||||||
Next
|
Next
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user