Add create_*_file_source methods.

GitOrigin-RevId: 52c2f793bb911a7068b0ee29f8b15086c7c74a67
This commit is contained in:
levlam 2019-01-18 22:36:23 +03:00
parent 94f94750fe
commit afed91fec9
2 changed files with 57 additions and 8 deletions

View File

@ -38,11 +38,52 @@ FileSourceId FileReferenceManager::get_current_file_source_id() const {
return FileSourceId(narrow_cast<int32>(file_sources_.size())); return FileSourceId(narrow_cast<int32>(file_sources_.size()));
} }
template <class T>
FileSourceId FileReferenceManager::add_file_source_id(T source) {
file_sources_.emplace_back(std::move(source));
return get_current_file_source_id();
}
FileSourceId FileReferenceManager::create_message_file_source(FullMessageId full_message_id) { FileSourceId FileReferenceManager::create_message_file_source(FullMessageId full_message_id) {
VLOG(file_references) << "Create file source for " << full_message_id; VLOG(file_references) << "Create file source for " << full_message_id;
FileSourceMessage source{full_message_id}; FileSourceMessage source{full_message_id};
file_sources_.emplace_back(source); return add_file_source_id(source);
return get_current_file_source_id(); }
FileSourceId FileReferenceManager::create_user_photo_file_source(UserId user_id, int64 photo_id) {
VLOG(file_references) << "Create file source for photo " << photo_id << " of " << user_id;
FileSourceUserPhoto source{photo_id, user_id};
return add_file_source_id(source);
}
FileSourceId FileReferenceManager::create_chat_photo_file_source(ChatId chat_id) {
VLOG(file_references) << "Create file source for photo of " << chat_id;
FileSourceChatPhoto source{chat_id};
return add_file_source_id(source);
}
FileSourceId FileReferenceManager::create_channel_photo_file_source(ChannelId channel_id) {
VLOG(file_references) << "Create file source for photo of " << channel_id;
FileSourceChannelPhoto source{channel_id};
return add_file_source_id(source);
}
FileSourceId FileReferenceManager::create_wallpapers_file_source() {
VLOG(file_references) << "Create file source for wallpapers";
FileSourceWebPage source;
return add_file_source_id(source);
}
FileSourceId FileReferenceManager::create_web_page_file_source(string url) {
VLOG(file_references) << "Create file source for web page of " << url;
FileSourceWebPage source{std::move(url)};
return add_file_source_id(std::move(source));
}
FileSourceId FileReferenceManager::create_saved_animations_file_source() {
VLOG(file_references) << "Create file source for saved animations";
FileSourceSavedAnimations source;
return add_file_source_id(source);
} }
void FileReferenceManager::add_file_source(NodeId node_id, FileSourceId file_source_id) { void FileReferenceManager::add_file_source(NodeId node_id, FileSourceId file_source_id) {
@ -73,7 +114,7 @@ void FileReferenceManager::merge(NodeId to_node_id, NodeId from_node_id) {
if (to.query || from.query) { if (to.query || from.query) {
if (!to.query) { if (!to.query) {
to.query = make_unique<Query>(); to.query = make_unique<Query>();
to.query->generation = ++query_generation; to.query->generation = ++query_generation_;
} }
if (from.query) { if (from.query) {
::td::merge(to.query->promises, from.query->promises); ::td::merge(to.query->promises, from.query->promises);
@ -221,11 +262,12 @@ void FileReferenceManager::update_file_reference(NodeId node_id, Promise<> promi
auto &node = nodes_[node_id]; auto &node = nodes_[node_id];
if (!node.query) { if (!node.query) {
node.query = make_unique<Query>(); node.query = make_unique<Query>();
node.query->generation = ++query_generation; node.query->generation = ++query_generation_;
node.file_source_ids.reset_position(); node.file_source_ids.reset_position();
VLOG(file_references) << "new query " << query_generation; VLOG(file_references) << "new query " << query_generation_;
} }
node.query->promises.push_back(std::move(promise)); node.query->promises.push_back(std::move(promise));
run_node(node_id); run_node(node_id);
} }
} // namespace td } // namespace td

View File

@ -25,10 +25,14 @@ namespace td {
extern int VERBOSITY_NAME(file_references); extern int VERBOSITY_NAME(file_references);
class FileReferenceManager : public Actor { class FileReferenceManager : public Actor {
struct Node;
public: public:
FileSourceId create_message_file_source(FullMessageId full_message_id); FileSourceId create_message_file_source(FullMessageId full_message_id);
FileSourceId create_user_photo_file_source(UserId user_id, int64 photo_id);
FileSourceId create_chat_photo_file_source(ChatId chat_id);
FileSourceId create_channel_photo_file_source(ChannelId channel_id);
FileSourceId create_wallpapers_file_source();
FileSourceId create_web_page_file_source(string url);
FileSourceId create_saved_animations_file_source();
using NodeId = FileId; using NodeId = FileId;
void update_file_reference(NodeId node_id, Promise<> promise); void update_file_reference(NodeId node_id, Promise<> promise);
@ -83,7 +87,7 @@ class FileReferenceManager : public Actor {
FileSourceWallpapers, FileSourceWebPage, FileSourceSavedAnimations>; FileSourceWallpapers, FileSourceWebPage, FileSourceSavedAnimations>;
vector<FileSource> file_sources_; vector<FileSource> file_sources_;
int64 query_generation{0}; int64 query_generation_{0};
std::unordered_map<NodeId, Node, FileIdHash> nodes_; std::unordered_map<NodeId, Node, FileIdHash> nodes_;
@ -91,6 +95,9 @@ class FileReferenceManager : public Actor {
void send_query(Destination dest, FileSourceId file_source_id); void send_query(Destination dest, FileSourceId file_source_id);
Destination on_query_result(Destination dest, FileSourceId file_source_id, Status status, int32 sub = 0); Destination on_query_result(Destination dest, FileSourceId file_source_id, Status status, int32 sub = 0);
template <class T>
FileSourceId add_file_source_id(T source);
FileSourceId get_current_file_source_id() const; FileSourceId get_current_file_source_id() const;
}; };