The following are commits related to removed variables. apiwrap.cppe050e27: kSaveDraftBeforeQuitTimeout app.cpp113f665: serviceImageCacheSize boxes/auto_download_box.cppa0c6104: checked(Source source, Type type) boxes/background_preview_box.cppb6edf45: resultBytesPerPixelfe21b5a: ms boxes/calendar_box.cppae97704: yearIndex, monthIndex99bb093: ms boxes/connection_box.cppf794d8d: ping boxes/dictionaries_manager.cpp8353867: session boxes/peer_list_box.cpp2ce2a14: grayedWidth boxes/peers/add_participants_box.cpp07e010d: chat, channel boxes/self_destruction_box.cppfe9f02e: count chat_helpers/emoji_suggestions_widget.cppa12bc60: is(QLatin1String string) chat_helpers/field_autocomplete.cpp8c7a35c: atwidth, hashwidth chat_helpers/gifs_list_widget.cppff65734: inlineItems3d846fc: newSelectedd1687ab: kSaveDraftBeforeQuitTimeout chat_helpers/stickers_dice_pack.cppc83e297: kZeroDiceDocumentId chat_helpers/stickers_emoji_pack.cppd298953: length chat_helpers/stickers_list_widget.cppeb75859: index, x core/crash_reports.cpp5940ae6: LaunchedDateTimeStr, LaunchedBinaryName data/data_changes.cpp 3c4e959:clearRealtime data/data_cloud_file.cpp4b354b0: fromCloud, cacheTag data/data_document_media.cpp7db5359: kMaxVideoFrameArea data/data_messages.cpp794e315: wasCount data/data_photo_media.cppe27d2bc: index data/data_wall_paper.cppb6edf45: resultBytesPerPixel data/data_types.cppaa8f62d: kWebDocumentCacheTag, kStorageCacheMask history/admin_log/history_admin_log_inner.cpp794e315: canDelete, canForward history/history_location_manager.cpp60f45ab: kCoordPrecision9f90d3a: kMaxHttpRedirects history/history_message.cppcedf8a6: kPinnedMessageTextLimit history/history_widget.cppb305924: serviceColorefa5fc4: hasForward5e7aa4f: kTabbedSelectorToggleTooltipTimeoutMs, kTabbedSelectorToggleTooltipCount history/view/history_view_context_menu.cppfe1a90b: isVideoLink, isVoiceLink, isAudioLink settings.cppe2f54eb: defaultRecent settings/settings_folders.cppe8bf5bb: kRefreshSuggestedTimeout ui/filter_icon_panel.cppc4a0bc1: kDelayedHideTimeoutMs window/themes/window_theme_preview.cppef927c8: mutedCounter ----- Modified variables boxes/stickers_box.cpp554eb3a: _rows[pressedIndex] -> set data/data_notify_settings.cpp734c410: muteForSeconds -> muteUntil history/view/history_view_list_widget.cpp07528be: _items[index] -> viewe5f3bed: fromState, tillState history/history.cppcd3c1c6: kStatusShowClientsideRecordVideo -> kStatusShowClientsideRecordVoice storage/download_manager_mtproto.cppae8fb14: _queues[dcId] -> queue storage/localstorage.cpp357caf8: MTP::Environment::Production -> production
		
			
				
	
	
		
			135 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			135 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/*
 | 
						|
This file is part of Telegram Desktop,
 | 
						|
the official desktop application for the Telegram messaging service.
 | 
						|
 | 
						|
For license and copyright information please follow this link:
 | 
						|
https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
 | 
						|
*/
 | 
						|
#include "chat_helpers/stickers_dice_pack.h"
 | 
						|
 | 
						|
#include "main/main_session.h"
 | 
						|
#include "data/data_session.h"
 | 
						|
#include "data/data_document.h"
 | 
						|
#include "ui/image/image_location_factory.h"
 | 
						|
#include "storage/localimageloader.h"
 | 
						|
#include "base/unixtime.h"
 | 
						|
#include "apiwrap.h"
 | 
						|
 | 
						|
#include <QtCore/QFile>
 | 
						|
#include <QtCore/QFileInfo>
 | 
						|
 | 
						|
namespace Stickers {
 | 
						|
 | 
						|
DicePack::DicePack(not_null<Main::Session*> session, const QString &emoji)
 | 
						|
: _session(session)
 | 
						|
, _emoji(emoji) {
 | 
						|
}
 | 
						|
 | 
						|
DicePack::~DicePack() = default;
 | 
						|
 | 
						|
DocumentData *DicePack::lookup(int value) {
 | 
						|
	if (!_requestId) {
 | 
						|
		load();
 | 
						|
	}
 | 
						|
	tryGenerateLocalZero();
 | 
						|
	const auto i = _map.find(value);
 | 
						|
	return (i != end(_map)) ? i->second.get() : nullptr;
 | 
						|
}
 | 
						|
 | 
						|
void DicePack::load() {
 | 
						|
	if (_requestId) {
 | 
						|
		return;
 | 
						|
	}
 | 
						|
	_requestId = _session->api().request(MTPmessages_GetStickerSet(
 | 
						|
		MTP_inputStickerSetDice(MTP_string(_emoji))
 | 
						|
	)).done([=](const MTPmessages_StickerSet &result) {
 | 
						|
		result.match([&](const MTPDmessages_stickerSet &data) {
 | 
						|
			applySet(data);
 | 
						|
		});
 | 
						|
	}).fail([=](const RPCError &error) {
 | 
						|
		_requestId = 0;
 | 
						|
	}).send();
 | 
						|
}
 | 
						|
 | 
						|
void DicePack::applySet(const MTPDmessages_stickerSet &data) {
 | 
						|
	_map.clear();
 | 
						|
	auto documents = base::flat_map<DocumentId, not_null<DocumentData*>>();
 | 
						|
	for (const auto &sticker : data.vdocuments().v) {
 | 
						|
		const auto document = _session->data().processDocument(
 | 
						|
			sticker);
 | 
						|
		if (document->sticker()) {
 | 
						|
			documents.emplace(document->id, document);
 | 
						|
		}
 | 
						|
	}
 | 
						|
	for (const auto pack : data.vpacks().v) {
 | 
						|
		pack.match([&](const MTPDstickerPack &data) {
 | 
						|
			const auto emoji = qs(data.vemoticon());
 | 
						|
			if (emoji.isEmpty()) {
 | 
						|
				return;
 | 
						|
			}
 | 
						|
			const auto ch = int(emoji[0].unicode());
 | 
						|
			const auto index = (ch == '#') ? 0 : (ch + 1 - '1');
 | 
						|
			if (index < 0 || index > 6) {
 | 
						|
				return;
 | 
						|
			}
 | 
						|
			for (const auto id : data.vdocuments().v) {
 | 
						|
				if (const auto document = documents.take(id.v)) {
 | 
						|
					_map.emplace(index, *document);
 | 
						|
				}
 | 
						|
			}
 | 
						|
		});
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
void DicePack::tryGenerateLocalZero() {
 | 
						|
	if (!_map.empty()) {
 | 
						|
		return;
 | 
						|
	}
 | 
						|
 | 
						|
	static const auto kDiceString = QString::fromUtf8("\xF0\x9F\x8E\xB2");
 | 
						|
	static const auto kDartString = QString::fromUtf8("\xF0\x9F\x8E\xAF");
 | 
						|
	const auto path = (_emoji == kDiceString)
 | 
						|
		? qsl(":/gui/art/dice_idle.tgs")
 | 
						|
		: (_emoji == kDartString)
 | 
						|
		? qsl(":/gui/art/dart_idle.tgs")
 | 
						|
		: QString();
 | 
						|
	if (path.isEmpty()) {
 | 
						|
		return;
 | 
						|
	}
 | 
						|
	auto task = FileLoadTask(
 | 
						|
		_session,
 | 
						|
		path,
 | 
						|
		QByteArray(),
 | 
						|
		nullptr,
 | 
						|
		SendMediaType::File,
 | 
						|
		FileLoadTo(0, {}, 0),
 | 
						|
		{});
 | 
						|
	task.process();
 | 
						|
	const auto result = task.peekResult();
 | 
						|
	Assert(result != nullptr);
 | 
						|
	const auto document = _session->data().processDocument(
 | 
						|
		result->document,
 | 
						|
		Images::FromImageInMemory(result->thumb, "PNG"));
 | 
						|
	document->setLocation(FileLocation(path));
 | 
						|
 | 
						|
	_map.emplace(0, document);
 | 
						|
 | 
						|
	Ensures(document->sticker());
 | 
						|
	Ensures(document->sticker()->animated);
 | 
						|
}
 | 
						|
 | 
						|
DicePacks::DicePacks(not_null<Main::Session*> session) : _session(session) {
 | 
						|
}
 | 
						|
 | 
						|
DocumentData *DicePacks::lookup(const QString &emoji, int value) {
 | 
						|
	const auto i = _packs.find(emoji);
 | 
						|
	if (i != end(_packs)) {
 | 
						|
		return i->second->lookup(value);
 | 
						|
	}
 | 
						|
	return _packs.emplace(
 | 
						|
		emoji,
 | 
						|
		std::make_unique<DicePack>(_session, emoji)
 | 
						|
	).first->second->lookup(value);
 | 
						|
}
 | 
						|
 | 
						|
} // namespace Stickers
 |