2018-12-31 22:04:05 +03:00
|
|
|
//
|
2018-01-02 16:42:31 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2018
|
2018-12-31 22:04:05 +03: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 22:29:04 +03:00
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
#include "td/telegram/AudiosManager.h"
|
|
|
|
|
|
|
|
#include "td/telegram/files/FileId.hpp"
|
|
|
|
#include "td/telegram/Photo.hpp"
|
|
|
|
|
|
|
|
#include "td/utils/logging.h"
|
|
|
|
#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 22:43:12 +03:00
|
|
|
store(file_id, storer);
|
2018-12-31 22:04:05 +03: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);
|
|
|
|
return on_get_audio(std::move(audio), true);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace td
|