Fix searching Great Minds by name.

GitOrigin-RevId: 1c9b2731b3b44bda2ca001363e5d4754326ecd70
This commit is contained in:
levlam 2019-04-19 02:36:48 +03:00
parent 3bb65d6ea3
commit a25ac45f08
2 changed files with 21 additions and 13 deletions

View File

@ -502,6 +502,7 @@ class ReorderStickerSetsQuery : public Td::ResultHandler {
class GetStickerSetQuery : public Td::ResultHandler { class GetStickerSetQuery : public Td::ResultHandler {
Promise<Unit> promise_; Promise<Unit> promise_;
int64 sticker_set_id_; int64 sticker_set_id_;
string sticker_set_name_;
public: public:
explicit GetStickerSetQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) { explicit GetStickerSetQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) {
@ -509,6 +510,10 @@ class GetStickerSetQuery : public Td::ResultHandler {
void send(int64 sticker_set_id, tl_object_ptr<telegram_api::InputStickerSet> &&input_sticker_set) { void send(int64 sticker_set_id, tl_object_ptr<telegram_api::InputStickerSet> &&input_sticker_set) {
sticker_set_id_ = sticker_set_id; sticker_set_id_ = sticker_set_id;
if (input_sticker_set->get_id() == telegram_api::inputStickerSetShortName::ID) {
sticker_set_name_ =
static_cast<const telegram_api::inputStickerSetShortName *>(input_sticker_set.get())->short_name_;
}
LOG(INFO) << "Load sticker set " << sticker_set_id << " from server: " << to_string(input_sticker_set); LOG(INFO) << "Load sticker set " << sticker_set_id << " from server: " << to_string(input_sticker_set);
send_query(G()->net_query_creator().create( send_query(G()->net_query_creator().create(
create_storer(telegram_api::messages_getStickerSet(std::move(input_sticker_set))))); create_storer(telegram_api::messages_getStickerSet(std::move(input_sticker_set)))));
@ -520,9 +525,19 @@ class GetStickerSetQuery : public Td::ResultHandler {
return on_error(id, result_ptr.move_as_error()); return on_error(id, result_ptr.move_as_error());
} }
auto ptr = result_ptr.move_as_ok(); auto set = result_ptr.move_as_ok();
// LOG(DEBUG) << "Receive result for get sticker set " << to_string(ptr);
td->stickers_manager_->on_get_messages_sticker_set(sticker_set_id_, std::move(ptr), true); constexpr int64 GREAT_MINDS_COLOR_SET_ID = 151353307481243663;
if (set->set_->id_ == GREAT_MINDS_COLOR_SET_ID) {
string great_minds_name = "TelegramGreatMinds";
if (sticker_set_id_ == StickersManager::GREAT_MINDS_SET_ID ||
trim(to_lower(sticker_set_name_)) == to_lower(great_minds_name)) {
set->set_->id_ = StickersManager::GREAT_MINDS_SET_ID;
set->set_->short_name_ = std::move(great_minds_name);
}
}
td->stickers_manager_->on_get_messages_sticker_set(sticker_set_id_, std::move(set), true);
promise_.set_value(Unit()); promise_.set_value(Unit());
} }
@ -1710,11 +1725,6 @@ void StickersManager::on_get_messages_sticker_set(int64 sticker_set_id,
bool is_changed) { bool is_changed) {
LOG(INFO) << "Receive sticker set " << to_string(set); LOG(INFO) << "Receive sticker set " << to_string(set);
if (sticker_set_id == GREAT_MINDS_SET_ID && set->set_->id_ == GREAT_MINDS_COLOR_SET_ID) {
set->set_->id_ = GREAT_MINDS_SET_ID;
set->set_->short_name_ = "TelegramGreatMinds";
}
auto set_id = on_get_sticker_set(std::move(set->set_), is_changed); auto set_id = on_get_sticker_set(std::move(set->set_), is_changed);
if (set_id == 0) { if (set_id == 0) {
return; return;
@ -2689,8 +2699,7 @@ void StickersManager::on_load_sticker_set_from_database(int64 sticker_set_id, bo
CHECK(!sticker_set->load_without_stickers_requests.empty()); CHECK(!sticker_set->load_without_stickers_requests.empty());
} }
if (value.empty()) { if (value.empty()) {
reload_sticker_set(sticker_set_id, get_input_sticker_set(sticker_set), Auto()); return reload_sticker_set(sticker_set_id, get_input_sticker_set(sticker_set), Auto());
return;
} }
LOG(INFO) << "Successfully loaded sticker set " << sticker_set_id << " with" << (with_stickers ? "" : "out") LOG(INFO) << "Successfully loaded sticker set " << sticker_set_id << " with" << (with_stickers ? "" : "out")

View File

@ -36,6 +36,8 @@ class Td;
class StickersManager : public Actor { class StickersManager : public Actor {
public: public:
static constexpr int64 GREAT_MINDS_SET_ID = 1842540969984001;
StickersManager(Td *td, ActorShared<> parent); StickersManager(Td *td, ActorShared<> parent);
tl_object_ptr<td_api::sticker> get_sticker_object(FileId file_id) const; tl_object_ptr<td_api::sticker> get_sticker_object(FileId file_id) const;
@ -243,9 +245,6 @@ class StickersManager : public Actor {
static constexpr size_t MAX_STICKER_SET_TITLE_LENGTH = 64; // server side limit static constexpr size_t MAX_STICKER_SET_TITLE_LENGTH = 64; // server side limit
static constexpr size_t MAX_STICKER_SET_SHORT_NAME_LENGTH = 64; // server side limit static constexpr size_t MAX_STICKER_SET_SHORT_NAME_LENGTH = 64; // server side limit
static constexpr int64 GREAT_MINDS_SET_ID = 1842540969984001;
static constexpr int64 GREAT_MINDS_COLOR_SET_ID = 151353307481243663;
class Sticker { class Sticker {
public: public:
int64 set_id = 0; int64 set_id = 0;