2018-12-31 20:04:05 +01:00
|
|
|
//
|
2018-12-31 23:02:34 +01:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2019
|
2018-12-31 20:04:05 +01:00
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#pragma once
|
2018-07-03 21:29:04 +02:00
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
#include "td/telegram/AudiosManager.h"
|
|
|
|
|
|
|
|
#include "td/telegram/files/FileId.hpp"
|
|
|
|
#include "td/telegram/Photo.hpp"
|
|
|
|
|
2019-02-12 21:48:16 +01:00
|
|
|
#include "td/utils/common.h"
|
2018-12-31 20:04:05 +01:00
|
|
|
#include "td/utils/tl_helpers.h"
|
|
|
|
|
|
|
|
namespace td {
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
void AudiosManager::store_audio(FileId file_id, T &storer) const {
|
|
|
|
auto it = audios_.find(file_id);
|
|
|
|
CHECK(it != audios_.end());
|
|
|
|
const Audio *audio = it->second.get();
|
|
|
|
store(audio->file_name, storer);
|
|
|
|
store(audio->mime_type, storer);
|
|
|
|
store(audio->duration, storer);
|
|
|
|
store(audio->title, storer);
|
|
|
|
store(audio->performer, storer);
|
|
|
|
store(audio->thumbnail, storer);
|
2018-03-08 20:43:12 +01:00
|
|
|
store(file_id, storer);
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
FileId AudiosManager::parse_audio(T &parser) {
|
|
|
|
auto audio = make_unique<Audio>();
|
|
|
|
parse(audio->file_name, parser);
|
|
|
|
parse(audio->mime_type, parser);
|
|
|
|
parse(audio->duration, parser);
|
|
|
|
parse(audio->title, parser);
|
|
|
|
parse(audio->performer, parser);
|
|
|
|
parse(audio->thumbnail, parser);
|
|
|
|
parse(audio->file_id, parser);
|
2018-11-06 12:37:07 +01:00
|
|
|
return on_get_audio(std::move(audio), false);
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace td
|