mirror of https://github.com/procxx/kepka.git
				
				
				
			Game play send message action is supported.
This commit is contained in:
		
							parent
							
								
									376941dd5e
								
							
						
					
					
						commit
						a18e3e5616
					
				|  | @ -787,10 +787,10 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org | ||||||
| "lng_user_typing" = "{user} is typing"; | "lng_user_typing" = "{user} is typing"; | ||||||
| "lng_users_typing" = "{user} and {second_user} are typing"; | "lng_users_typing" = "{user} and {second_user} are typing"; | ||||||
| "lng_many_typing" = "{count:_not_used_|# is|# are} typing"; | "lng_many_typing" = "{count:_not_used_|# is|# are} typing"; | ||||||
| "lng_playing_game" = "playing game"; | "lng_playing_game" = "playing a game"; | ||||||
| "lng_user_playing_game" = "{user} is playing game"; | "lng_user_playing_game" = "{user} is playing a game"; | ||||||
| "lng_users_playing_game" = "{user} and {second_user} are playing game"; | "lng_users_playing_game" = "{user} and {second_user} are playing a game"; | ||||||
| "lng_many_playing_game" = "{count:_not_used_|# is|# are} playing game"; | "lng_many_playing_game" = "{count:_not_used_|# is|# are} playing a game"; | ||||||
| "lng_send_action_record_video" = "recording a video"; | "lng_send_action_record_video" = "recording a video"; | ||||||
| "lng_user_action_record_video" = "{user} is recording a video"; | "lng_user_action_record_video" = "{user} is recording a video"; | ||||||
| "lng_send_action_upload_video" = "sending a video"; | "lng_send_action_upload_video" = "sending a video"; | ||||||
|  |  | ||||||
|  | @ -171,7 +171,7 @@ void History::draftSavedToCloud() { | ||||||
| 
 | 
 | ||||||
| bool History::updateTyping(uint64 ms, bool force) { | bool History::updateTyping(uint64 ms, bool force) { | ||||||
| 	bool changed = force; | 	bool changed = force; | ||||||
| 	for (TypingUsers::iterator i = typing.begin(), e = typing.end(); i != e;) { | 	for (auto i = typing.begin(), e = typing.end(); i != e;) { | ||||||
| 		if (ms >= i.value()) { | 		if (ms >= i.value()) { | ||||||
| 			i = typing.erase(i); | 			i = typing.erase(i); | ||||||
| 			changed = true; | 			changed = true; | ||||||
|  | @ -179,7 +179,7 @@ bool History::updateTyping(uint64 ms, bool force) { | ||||||
| 			++i; | 			++i; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	for (SendActionUsers::iterator i = sendActions.begin(); i != sendActions.cend();) { | 	for (auto i = sendActions.begin(); i != sendActions.cend();) { | ||||||
| 		if (ms >= i.value().until) { | 		if (ms >= i.value().until) { | ||||||
| 			i = sendActions.erase(i); | 			i = sendActions.erase(i); | ||||||
| 			changed = true; | 			changed = true; | ||||||
|  | @ -189,23 +189,46 @@ bool History::updateTyping(uint64 ms, bool force) { | ||||||
| 	} | 	} | ||||||
| 	if (changed) { | 	if (changed) { | ||||||
| 		QString newTypingStr; | 		QString newTypingStr; | ||||||
| 		int32 cnt = typing.size(); | 		int typingCount = typing.size(); | ||||||
| 		if (cnt > 2) { | 		if (typingCount > 2) { | ||||||
| 			newTypingStr = lng_many_typing(lt_count, cnt); | 			newTypingStr = lng_many_typing(lt_count, typingCount); | ||||||
| 		} else if (cnt > 1) { | 		} else if (typingCount > 1) { | ||||||
| 			newTypingStr = lng_users_typing(lt_user, typing.begin().key()->firstName, lt_second_user, (typing.end() - 1).key()->firstName); | 			newTypingStr = lng_users_typing(lt_user, typing.begin().key()->firstName, lt_second_user, (typing.end() - 1).key()->firstName); | ||||||
| 		} else if (cnt) { | 		} else if (typingCount) { | ||||||
| 			newTypingStr = peer->isUser() ? lang(lng_typing) : lng_user_typing(lt_user, typing.begin().key()->firstName); | 			newTypingStr = peer->isUser() ? lang(lng_typing) : lng_user_typing(lt_user, typing.begin().key()->firstName); | ||||||
| 		} else if (!sendActions.isEmpty()) { | 		} else if (!sendActions.isEmpty()) { | ||||||
| 			switch (sendActions.begin().value().type) { | 			// Handles all actions except game playing.
 | ||||||
| 			case SendActionRecordVideo: newTypingStr = peer->isUser() ? lang(lng_send_action_record_video) : lng_user_action_record_video(lt_user, sendActions.begin().key()->firstName); break; | 			auto sendActionString = [](SendActionType type, const QString &name) -> QString { | ||||||
| 			case SendActionUploadVideo: newTypingStr = peer->isUser() ? lang(lng_send_action_upload_video) : lng_user_action_upload_video(lt_user, sendActions.begin().key()->firstName); break; | 				switch (type) { | ||||||
| 			case SendActionRecordVoice: newTypingStr = peer->isUser() ? lang(lng_send_action_record_audio) : lng_user_action_record_audio(lt_user, sendActions.begin().key()->firstName); break; | 				case SendActionRecordVideo: return name.isEmpty() ? lang(lng_send_action_record_video) : lng_user_action_record_video(lt_user, name); | ||||||
| 			case SendActionUploadVoice: newTypingStr = peer->isUser() ? lang(lng_send_action_upload_audio) : lng_user_action_upload_audio(lt_user, sendActions.begin().key()->firstName); break; | 				case SendActionUploadVideo: return name.isEmpty() ? lang(lng_send_action_upload_video) : lng_user_action_upload_video(lt_user, name); | ||||||
| 			case SendActionUploadPhoto: newTypingStr = peer->isUser() ? lang(lng_send_action_upload_photo) : lng_user_action_upload_photo(lt_user, sendActions.begin().key()->firstName); break; | 				case SendActionRecordVoice: return name.isEmpty() ? lang(lng_send_action_record_audio) : lng_user_action_record_audio(lt_user, name); | ||||||
| 			case SendActionUploadFile: newTypingStr = peer->isUser() ? lang(lng_send_action_upload_file) : lng_user_action_upload_file(lt_user, sendActions.begin().key()->firstName); break; | 				case SendActionUploadVoice: return name.isEmpty() ? lang(lng_send_action_upload_audio) : lng_user_action_upload_audio(lt_user, name); | ||||||
| 			case SendActionChooseLocation: newTypingStr = peer->isUser() ? lang(lng_send_action_geo_location) : lng_user_action_geo_location(lt_user, sendActions.begin().key()->firstName); break; | 				case SendActionUploadPhoto: return name.isEmpty() ? lang(lng_send_action_upload_photo) : lng_user_action_upload_photo(lt_user, name); | ||||||
| 			case SendActionChooseContact: newTypingStr = peer->isUser() ? lang(lng_send_action_choose_contact) : lng_user_action_choose_contact(lt_user, sendActions.begin().key()->firstName); break; | 				case SendActionUploadFile: return name.isEmpty() ? lang(lng_send_action_upload_file) : lng_user_action_upload_file(lt_user, name); | ||||||
|  | 				case SendActionChooseLocation: return name.isEmpty() ? lang(lng_send_action_geo_location) : lng_user_action_geo_location(lt_user, name); | ||||||
|  | 				case SendActionChooseContact: return name.isEmpty() ? lang(lng_send_action_choose_contact) : lng_user_action_choose_contact(lt_user, name); | ||||||
|  | 				default: break; | ||||||
|  | 				}; | ||||||
|  | 				return QString(); | ||||||
|  | 			}; | ||||||
|  | 			for (auto i = sendActions.cbegin(), e = sendActions.cend(); i != e; ++i) { | ||||||
|  | 				newTypingStr = sendActionString(i->type, peer->isUser() ? QString() : i.key()->firstName); | ||||||
|  | 				if (!newTypingStr.isEmpty()) { | ||||||
|  | 					break; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			// Everyone in sendActions are playing a game.
 | ||||||
|  | 			if (newTypingStr.isEmpty()) { | ||||||
|  | 				int playingCount = sendActions.size(); | ||||||
|  | 				if (playingCount > 2) { | ||||||
|  | 					newTypingStr = lng_many_playing_game(lt_count, playingCount); | ||||||
|  | 				} else if (playingCount > 1) { | ||||||
|  | 					newTypingStr = lng_users_playing_game(lt_user, sendActions.begin().key()->firstName, lt_second_user, (sendActions.end() - 1).key()->firstName); | ||||||
|  | 				} else { | ||||||
|  | 					newTypingStr = peer->isUser() ? lang(lng_playing_game) : lng_user_playing_game(lt_user, sendActions.begin().key()->firstName); | ||||||
|  | 				} | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		if (!newTypingStr.isEmpty()) { | 		if (!newTypingStr.isEmpty()) { | ||||||
|  | @ -527,6 +550,12 @@ void Histories::regSendAction(History *history, UserData *user, const MTPSendMes | ||||||
| 	if (action.type() == mtpc_sendMessageCancelAction) { | 	if (action.type() == mtpc_sendMessageCancelAction) { | ||||||
| 		history->unregTyping(user); | 		history->unregTyping(user); | ||||||
| 		return; | 		return; | ||||||
|  | 	} else if (action.type() == mtpc_sendMessageGameStopAction) { | ||||||
|  | 		auto it = history->sendActions.find(user); | ||||||
|  | 		if (it != history->sendActions.end() && it->type == SendActionPlayGame) { | ||||||
|  | 			history->unregTyping(user); | ||||||
|  | 		} | ||||||
|  | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	uint64 ms = getms(); | 	uint64 ms = getms(); | ||||||
|  | @ -540,12 +569,18 @@ void Histories::regSendAction(History *history, UserData *user, const MTPSendMes | ||||||
| 	case mtpc_sendMessageUploadDocumentAction: history->sendActions.insert(user, SendAction(SendActionUploadFile, ms + 6000, action.c_sendMessageUploadDocumentAction().vprogress.v)); break; | 	case mtpc_sendMessageUploadDocumentAction: history->sendActions.insert(user, SendAction(SendActionUploadFile, ms + 6000, action.c_sendMessageUploadDocumentAction().vprogress.v)); break; | ||||||
| 	case mtpc_sendMessageGeoLocationAction: history->sendActions.insert(user, SendAction(SendActionChooseLocation, ms + 6000)); break; | 	case mtpc_sendMessageGeoLocationAction: history->sendActions.insert(user, SendAction(SendActionChooseLocation, ms + 6000)); break; | ||||||
| 	case mtpc_sendMessageChooseContactAction: history->sendActions.insert(user, SendAction(SendActionChooseContact, ms + 6000)); break; | 	case mtpc_sendMessageChooseContactAction: history->sendActions.insert(user, SendAction(SendActionChooseContact, ms + 6000)); break; | ||||||
|  | 	case mtpc_sendMessageGamePlayAction: { | ||||||
|  | 		auto it = history->sendActions.find(user); | ||||||
|  | 		if (it == history->sendActions.end() || it->type == SendActionPlayGame || it->until <= ms) { | ||||||
|  | 			history->sendActions.insert(user, SendAction(SendActionPlayGame, ms + 30000)); | ||||||
|  | 		} | ||||||
|  | 	} break; | ||||||
| 	default: return; | 	default: return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	user->madeAction(when); | 	user->madeAction(when); | ||||||
| 
 | 
 | ||||||
| 	TypingHistories::const_iterator i = typing.find(history); | 	auto i = typing.find(history); | ||||||
| 	if (i == typing.cend()) { | 	if (i == typing.cend()) { | ||||||
| 		typing.insert(history, ms); | 		typing.insert(history, ms); | ||||||
| 		history->typingDots = 0; | 		history->typingDots = 0; | ||||||
|  | @ -1059,13 +1094,13 @@ HistoryItem *History::addNewItem(HistoryItem *adding, bool newMsg) { | ||||||
| 
 | 
 | ||||||
| void History::unregTyping(UserData *from) { | void History::unregTyping(UserData *from) { | ||||||
| 	uint64 updateAtMs = 0; | 	uint64 updateAtMs = 0; | ||||||
| 	TypingUsers::iterator i = typing.find(from); | 	auto i = typing.find(from); | ||||||
| 	if (i != typing.end()) { | 	if (i != typing.cend()) { | ||||||
| 		updateAtMs = getms(); | 		updateAtMs = getms(); | ||||||
| 		i.value() = updateAtMs; | 		i.value() = updateAtMs; | ||||||
| 	} | 	} | ||||||
| 	SendActionUsers::iterator j = sendActions.find(from); | 	auto j = sendActions.find(from); | ||||||
| 	if (j != sendActions.end()) { | 	if (j != sendActions.cend()) { | ||||||
| 		if (!updateAtMs) updateAtMs = getms(); | 		if (!updateAtMs) updateAtMs = getms(); | ||||||
| 		j.value().until = updateAtMs; | 		j.value().until = updateAtMs; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -142,6 +142,7 @@ enum SendActionType { | ||||||
| 	SendActionUploadFile, | 	SendActionUploadFile, | ||||||
| 	SendActionChooseLocation, | 	SendActionChooseLocation, | ||||||
| 	SendActionChooseContact, | 	SendActionChooseContact, | ||||||
|  | 	SendActionPlayGame, | ||||||
| }; | }; | ||||||
| struct SendAction { | struct SendAction { | ||||||
| 	SendAction(SendActionType type, uint64 until, int32 progress = 0) : type(type), until(until), progress(progress) { | 	SendAction(SendActionType type, uint64 until, int32 progress = 0) : type(type), until(until), progress(progress) { | ||||||
|  | @ -401,9 +402,9 @@ public: | ||||||
| 	mutable const HistoryItem *textCachedFor = nullptr; // cache
 | 	mutable const HistoryItem *textCachedFor = nullptr; // cache
 | ||||||
| 	mutable Text lastItemTextCache; | 	mutable Text lastItemTextCache; | ||||||
| 
 | 
 | ||||||
| 	typedef QMap<UserData*, uint64> TypingUsers; | 	using TypingUsers = QMap<UserData*, uint64>; | ||||||
| 	TypingUsers typing; | 	TypingUsers typing; | ||||||
| 	typedef QMap<UserData*, SendAction> SendActionUsers; | 	using SendActionUsers = QMap<UserData*, SendAction>; | ||||||
| 	SendActionUsers sendActions; | 	SendActionUsers sendActions; | ||||||
| 	QString typingStr; | 	QString typingStr; | ||||||
| 	Text typingText; | 	Text typingText; | ||||||
|  |  | ||||||
|  | @ -3454,6 +3454,7 @@ void HistoryWidget::updateSendAction(History *history, SendActionType type, int3 | ||||||
| 		case SendActionUploadFile: action = MTP_sendMessageUploadDocumentAction(MTP_int(progress)); break; | 		case SendActionUploadFile: action = MTP_sendMessageUploadDocumentAction(MTP_int(progress)); break; | ||||||
| 		case SendActionChooseLocation: action = MTP_sendMessageGeoLocationAction(); break; | 		case SendActionChooseLocation: action = MTP_sendMessageGeoLocationAction(); break; | ||||||
| 		case SendActionChooseContact: action = MTP_sendMessageChooseContactAction(); break; | 		case SendActionChooseContact: action = MTP_sendMessageChooseContactAction(); break; | ||||||
|  | 		case SendActionPlayGame: action = MTP_sendMessageGamePlayAction(); break; | ||||||
| 		} | 		} | ||||||
| 		_sendActionRequests.insert(qMakePair(history, type), MTP::send(MTPmessages_SetTyping(history->peer->input, action), rpcDone(&HistoryWidget::sendActionDone))); | 		_sendActionRequests.insert(qMakePair(history, type), MTP::send(MTPmessages_SetTyping(history->peer->input, action), rpcDone(&HistoryWidget::sendActionDone))); | ||||||
| 		if (type == SendActionTyping) _sendActionStopTimer.start(5000); | 		if (type == SendActionTyping) _sendActionStopTimer.start(5000); | ||||||
|  | @ -5817,7 +5818,8 @@ void HistoryWidget::app_sendBotCallback(const HistoryMessageReplyMarkup::Button | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void HistoryWidget::botCallbackDone(BotCallbackInfo info, const MTPmessages_BotCallbackAnswer &answer, mtpRequestId req) { | void HistoryWidget::botCallbackDone(BotCallbackInfo info, const MTPmessages_BotCallbackAnswer &answer, mtpRequestId req) { | ||||||
| 	if (auto item = App::histItemById(info.msgId)) { | 	auto item = App::histItemById(info.msgId); | ||||||
|  | 	if (item) { | ||||||
| 		if (auto markup = item->Get<HistoryMessageReplyMarkup>()) { | 		if (auto markup = item->Get<HistoryMessageReplyMarkup>()) { | ||||||
| 			if (info.row < markup->rows.size() && info.col < markup->rows.at(info.row).size()) { | 			if (info.row < markup->rows.size() && info.col < markup->rows.at(info.row).size()) { | ||||||
| 				if (markup->rows.at(info.row).at(info.col).requestId == req) { | 				if (markup->rows.at(info.row).at(info.col).requestId == req) { | ||||||
|  | @ -5842,6 +5844,7 @@ void HistoryWidget::botCallbackDone(BotCallbackInfo info, const MTPmessages_BotC | ||||||
| 			if (info.game) { | 			if (info.game) { | ||||||
| 				url = appendShareGameScoreUrl(url, info.msgId); | 				url = appendShareGameScoreUrl(url, info.msgId); | ||||||
| 				BotGameUrlClickHandler(info.bot, url).onClick(Qt::LeftButton); | 				BotGameUrlClickHandler(info.bot, url).onClick(Qt::LeftButton); | ||||||
|  | 				updateSendAction(item->history(), SendActionPlayGame); | ||||||
| 			} else { | 			} else { | ||||||
| 				UrlClickHandler(url).onClick(Qt::LeftButton); | 				UrlClickHandler(url).onClick(Qt::LeftButton); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|  | @ -479,6 +479,8 @@ sendMessageUploadPhotoAction#d1d34a26 progress:int = SendMessageAction; | ||||||
| sendMessageUploadDocumentAction#aa0cd9e4 progress:int = SendMessageAction; | sendMessageUploadDocumentAction#aa0cd9e4 progress:int = SendMessageAction; | ||||||
| sendMessageGeoLocationAction#176f8ba1 = SendMessageAction; | sendMessageGeoLocationAction#176f8ba1 = SendMessageAction; | ||||||
| sendMessageChooseContactAction#628cbc6f = SendMessageAction; | sendMessageChooseContactAction#628cbc6f = SendMessageAction; | ||||||
|  | sendMessageGamePlayAction#dd6a8f48 = SendMessageAction; | ||||||
|  | sendMessageGameStopAction#15c2c99a = SendMessageAction; | ||||||
| 
 | 
 | ||||||
| contacts.found#1aa1f784 results:Vector<Peer> chats:Vector<Chat> users:Vector<User> = contacts.Found; | contacts.found#1aa1f784 results:Vector<Peer> chats:Vector<Chat> users:Vector<User> = contacts.Found; | ||||||
| 
 | 
 | ||||||
|  | @ -649,7 +651,7 @@ inputBotInlineMessageText#3dcd7a87 flags:# no_webpage:flags.0?true message:strin | ||||||
| inputBotInlineMessageMediaGeo#f4a59de1 flags:# geo_point:InputGeoPoint reply_markup:flags.2?ReplyMarkup = InputBotInlineMessage; | inputBotInlineMessageMediaGeo#f4a59de1 flags:# geo_point:InputGeoPoint reply_markup:flags.2?ReplyMarkup = InputBotInlineMessage; | ||||||
| inputBotInlineMessageMediaVenue#aaafadc8 flags:# geo_point:InputGeoPoint title:string address:string provider:string venue_id:string reply_markup:flags.2?ReplyMarkup = InputBotInlineMessage; | inputBotInlineMessageMediaVenue#aaafadc8 flags:# geo_point:InputGeoPoint title:string address:string provider:string venue_id:string reply_markup:flags.2?ReplyMarkup = InputBotInlineMessage; | ||||||
| inputBotInlineMessageMediaContact#2daf01a7 flags:# phone_number:string first_name:string last_name:string reply_markup:flags.2?ReplyMarkup = InputBotInlineMessage; | inputBotInlineMessageMediaContact#2daf01a7 flags:# phone_number:string first_name:string last_name:string reply_markup:flags.2?ReplyMarkup = InputBotInlineMessage; | ||||||
| inputBotInlineMessageGame#3c00f8aa reply_markup:ReplyMarkup = InputBotInlineMessage; | inputBotInlineMessageGame#4b425864 flags:# reply_markup:flags.2?ReplyMarkup = InputBotInlineMessage; | ||||||
| 
 | 
 | ||||||
| inputBotInlineResult#2cbbe15a flags:# id:string type:string title:flags.1?string description:flags.2?string url:flags.3?string thumb_url:flags.4?string content_url:flags.5?string content_type:flags.5?string w:flags.6?int h:flags.6?int duration:flags.7?int send_message:InputBotInlineMessage = InputBotInlineResult; | inputBotInlineResult#2cbbe15a flags:# id:string type:string title:flags.1?string description:flags.2?string url:flags.3?string thumb_url:flags.4?string content_url:flags.5?string content_type:flags.5?string w:flags.6?int h:flags.6?int duration:flags.7?int send_message:InputBotInlineMessage = InputBotInlineResult; | ||||||
| inputBotInlineResultPhoto#a8d864a7 id:string type:string photo:InputPhoto send_message:InputBotInlineMessage = InputBotInlineResult; | inputBotInlineResultPhoto#a8d864a7 id:string type:string photo:InputPhoto send_message:InputBotInlineMessage = InputBotInlineResult; | ||||||
|  |  | ||||||
|  | @ -3896,6 +3896,14 @@ void _serialize_sendMessageChooseContactAction(MTPStringLogger &to, int32 stage, | ||||||
| 	to.add("{ sendMessageChooseContactAction }"); types.pop_back(); vtypes.pop_back(); stages.pop_back(); flags.pop_back(); | 	to.add("{ sendMessageChooseContactAction }"); types.pop_back(); vtypes.pop_back(); stages.pop_back(); flags.pop_back(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void _serialize_sendMessageGamePlayAction(MTPStringLogger &to, int32 stage, int32 lev, Types &types, Types &vtypes, StagesFlags &stages, StagesFlags &flags, const mtpPrime *start, const mtpPrime *end, int32 iflag) { | ||||||
|  | 	to.add("{ sendMessageGamePlayAction }"); types.pop_back(); vtypes.pop_back(); stages.pop_back(); flags.pop_back(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void _serialize_sendMessageGameStopAction(MTPStringLogger &to, int32 stage, int32 lev, Types &types, Types &vtypes, StagesFlags &stages, StagesFlags &flags, const mtpPrime *start, const mtpPrime *end, int32 iflag) { | ||||||
|  | 	to.add("{ sendMessageGameStopAction }"); types.pop_back(); vtypes.pop_back(); stages.pop_back(); flags.pop_back(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void _serialize_contacts_found(MTPStringLogger &to, int32 stage, int32 lev, Types &types, Types &vtypes, StagesFlags &stages, StagesFlags &flags, const mtpPrime *start, const mtpPrime *end, int32 iflag) { | void _serialize_contacts_found(MTPStringLogger &to, int32 stage, int32 lev, Types &types, Types &vtypes, StagesFlags &stages, StagesFlags &flags, const mtpPrime *start, const mtpPrime *end, int32 iflag) { | ||||||
| 	if (stage) { | 	if (stage) { | ||||||
| 		to.add(",\n").addSpaces(lev); | 		to.add(",\n").addSpaces(lev); | ||||||
|  | @ -5387,6 +5395,8 @@ void _serialize_inputBotInlineMessageMediaContact(MTPStringLogger &to, int32 sta | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void _serialize_inputBotInlineMessageGame(MTPStringLogger &to, int32 stage, int32 lev, Types &types, Types &vtypes, StagesFlags &stages, StagesFlags &flags, const mtpPrime *start, const mtpPrime *end, int32 iflag) { | void _serialize_inputBotInlineMessageGame(MTPStringLogger &to, int32 stage, int32 lev, Types &types, Types &vtypes, StagesFlags &stages, StagesFlags &flags, const mtpPrime *start, const mtpPrime *end, int32 iflag) { | ||||||
|  | 	MTPDinputBotInlineMessageGame::Flags flag(iflag); | ||||||
|  | 
 | ||||||
| 	if (stage) { | 	if (stage) { | ||||||
| 		to.add(",\n").addSpaces(lev); | 		to.add(",\n").addSpaces(lev); | ||||||
| 	} else { | 	} else { | ||||||
|  | @ -5394,7 +5404,8 @@ void _serialize_inputBotInlineMessageGame(MTPStringLogger &to, int32 stage, int3 | ||||||
| 		to.add("\n").addSpaces(lev); | 		to.add("\n").addSpaces(lev); | ||||||
| 	} | 	} | ||||||
| 	switch (stage) { | 	switch (stage) { | ||||||
| 	case 0: to.add("  reply_markup: "); ++stages.back(); types.push_back(0); vtypes.push_back(0); stages.push_back(0); flags.push_back(0); break; | 	case 0: to.add("  flags: "); ++stages.back(); if (start >= end) throw Exception("start >= end in flags"); else flags.back() = *start; types.push_back(mtpc_flags); vtypes.push_back(0); stages.push_back(0); flags.push_back(0); break; | ||||||
|  | 	case 1: to.add("  reply_markup: "); ++stages.back(); if (flag & MTPDinputBotInlineMessageGame::Flag::f_reply_markup) { types.push_back(0); vtypes.push_back(0); stages.push_back(0); flags.push_back(0); } else { to.add("[ SKIPPED BY BIT 2 IN FIELD flags ]"); } break; | ||||||
| 	default: to.add("}"); types.pop_back(); vtypes.pop_back(); stages.pop_back(); flags.pop_back(); break; | 	default: to.add("}"); types.pop_back(); vtypes.pop_back(); stages.pop_back(); flags.pop_back(); break; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | @ -9144,6 +9155,8 @@ namespace { | ||||||
| 		_serializers.insert(mtpc_sendMessageUploadDocumentAction, _serialize_sendMessageUploadDocumentAction); | 		_serializers.insert(mtpc_sendMessageUploadDocumentAction, _serialize_sendMessageUploadDocumentAction); | ||||||
| 		_serializers.insert(mtpc_sendMessageGeoLocationAction, _serialize_sendMessageGeoLocationAction); | 		_serializers.insert(mtpc_sendMessageGeoLocationAction, _serialize_sendMessageGeoLocationAction); | ||||||
| 		_serializers.insert(mtpc_sendMessageChooseContactAction, _serialize_sendMessageChooseContactAction); | 		_serializers.insert(mtpc_sendMessageChooseContactAction, _serialize_sendMessageChooseContactAction); | ||||||
|  | 		_serializers.insert(mtpc_sendMessageGamePlayAction, _serialize_sendMessageGamePlayAction); | ||||||
|  | 		_serializers.insert(mtpc_sendMessageGameStopAction, _serialize_sendMessageGameStopAction); | ||||||
| 		_serializers.insert(mtpc_contacts_found, _serialize_contacts_found); | 		_serializers.insert(mtpc_contacts_found, _serialize_contacts_found); | ||||||
| 		_serializers.insert(mtpc_inputPrivacyKeyStatusTimestamp, _serialize_inputPrivacyKeyStatusTimestamp); | 		_serializers.insert(mtpc_inputPrivacyKeyStatusTimestamp, _serialize_inputPrivacyKeyStatusTimestamp); | ||||||
| 		_serializers.insert(mtpc_inputPrivacyKeyChatInvite, _serialize_inputPrivacyKeyChatInvite); | 		_serializers.insert(mtpc_inputPrivacyKeyChatInvite, _serialize_inputPrivacyKeyChatInvite); | ||||||
|  |  | ||||||
|  | @ -353,6 +353,8 @@ enum { | ||||||
| 	mtpc_sendMessageUploadDocumentAction = 0xaa0cd9e4, | 	mtpc_sendMessageUploadDocumentAction = 0xaa0cd9e4, | ||||||
| 	mtpc_sendMessageGeoLocationAction = 0x176f8ba1, | 	mtpc_sendMessageGeoLocationAction = 0x176f8ba1, | ||||||
| 	mtpc_sendMessageChooseContactAction = 0x628cbc6f, | 	mtpc_sendMessageChooseContactAction = 0x628cbc6f, | ||||||
|  | 	mtpc_sendMessageGamePlayAction = 0xdd6a8f48, | ||||||
|  | 	mtpc_sendMessageGameStopAction = 0x15c2c99a, | ||||||
| 	mtpc_contacts_found = 0x1aa1f784, | 	mtpc_contacts_found = 0x1aa1f784, | ||||||
| 	mtpc_inputPrivacyKeyStatusTimestamp = 0x4f96cb18, | 	mtpc_inputPrivacyKeyStatusTimestamp = 0x4f96cb18, | ||||||
| 	mtpc_inputPrivacyKeyChatInvite = 0xbdfb0426, | 	mtpc_inputPrivacyKeyChatInvite = 0xbdfb0426, | ||||||
|  | @ -474,7 +476,7 @@ enum { | ||||||
| 	mtpc_inputBotInlineMessageMediaGeo = 0xf4a59de1, | 	mtpc_inputBotInlineMessageMediaGeo = 0xf4a59de1, | ||||||
| 	mtpc_inputBotInlineMessageMediaVenue = 0xaaafadc8, | 	mtpc_inputBotInlineMessageMediaVenue = 0xaaafadc8, | ||||||
| 	mtpc_inputBotInlineMessageMediaContact = 0x2daf01a7, | 	mtpc_inputBotInlineMessageMediaContact = 0x2daf01a7, | ||||||
| 	mtpc_inputBotInlineMessageGame = 0x3c00f8aa, | 	mtpc_inputBotInlineMessageGame = 0x4b425864, | ||||||
| 	mtpc_inputBotInlineResult = 0x2cbbe15a, | 	mtpc_inputBotInlineResult = 0x2cbbe15a, | ||||||
| 	mtpc_inputBotInlineResultPhoto = 0xa8d864a7, | 	mtpc_inputBotInlineResultPhoto = 0xa8d864a7, | ||||||
| 	mtpc_inputBotInlineResultDocument = 0xfff8fdc4, | 	mtpc_inputBotInlineResultDocument = 0xfff8fdc4, | ||||||
|  | @ -14639,11 +14641,22 @@ public: | ||||||
| 
 | 
 | ||||||
| class MTPDinputBotInlineMessageGame : public mtpDataImpl<MTPDinputBotInlineMessageGame> { | class MTPDinputBotInlineMessageGame : public mtpDataImpl<MTPDinputBotInlineMessageGame> { | ||||||
| public: | public: | ||||||
|  | 	enum class Flag : int32 { | ||||||
|  | 		f_reply_markup = (1 << 2), | ||||||
|  | 
 | ||||||
|  | 		MAX_FIELD = (1 << 2), | ||||||
|  | 	}; | ||||||
|  | 	Q_DECLARE_FLAGS(Flags, Flag); | ||||||
|  | 	friend inline Flags operator~(Flag v) { return QFlag(~static_cast<int32>(v)); } | ||||||
|  | 
 | ||||||
|  | 	bool has_reply_markup() const { return vflags.v & Flag::f_reply_markup; } | ||||||
|  | 
 | ||||||
| 	MTPDinputBotInlineMessageGame() { | 	MTPDinputBotInlineMessageGame() { | ||||||
| 	} | 	} | ||||||
| 	MTPDinputBotInlineMessageGame(const MTPReplyMarkup &_reply_markup) : vreply_markup(_reply_markup) { | 	MTPDinputBotInlineMessageGame(const MTPflags<MTPDinputBotInlineMessageGame::Flags> &_flags, const MTPReplyMarkup &_reply_markup) : vflags(_flags), vreply_markup(_reply_markup) { | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	MTPflags<MTPDinputBotInlineMessageGame::Flags> vflags; | ||||||
| 	MTPReplyMarkup vreply_markup; | 	MTPReplyMarkup vreply_markup; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | @ -24778,6 +24791,12 @@ public: | ||||||
| 	inline static MTPsendMessageAction new_sendMessageChooseContactAction() { | 	inline static MTPsendMessageAction new_sendMessageChooseContactAction() { | ||||||
| 		return MTPsendMessageAction(mtpc_sendMessageChooseContactAction); | 		return MTPsendMessageAction(mtpc_sendMessageChooseContactAction); | ||||||
| 	} | 	} | ||||||
|  | 	inline static MTPsendMessageAction new_sendMessageGamePlayAction() { | ||||||
|  | 		return MTPsendMessageAction(mtpc_sendMessageGamePlayAction); | ||||||
|  | 	} | ||||||
|  | 	inline static MTPsendMessageAction new_sendMessageGameStopAction() { | ||||||
|  | 		return MTPsendMessageAction(mtpc_sendMessageGameStopAction); | ||||||
|  | 	} | ||||||
| 	inline static MTPcontacts_found new_contacts_found(const MTPVector<MTPPeer> &_results, const MTPVector<MTPChat> &_chats, const MTPVector<MTPUser> &_users) { | 	inline static MTPcontacts_found new_contacts_found(const MTPVector<MTPPeer> &_results, const MTPVector<MTPChat> &_chats, const MTPVector<MTPUser> &_users) { | ||||||
| 		return MTPcontacts_found(new MTPDcontacts_found(_results, _chats, _users)); | 		return MTPcontacts_found(new MTPDcontacts_found(_results, _chats, _users)); | ||||||
| 	} | 	} | ||||||
|  | @ -25141,8 +25160,8 @@ public: | ||||||
| 	inline static MTPinputBotInlineMessage new_inputBotInlineMessageMediaContact(const MTPflags<MTPDinputBotInlineMessageMediaContact::Flags> &_flags, const MTPstring &_phone_number, const MTPstring &_first_name, const MTPstring &_last_name, const MTPReplyMarkup &_reply_markup) { | 	inline static MTPinputBotInlineMessage new_inputBotInlineMessageMediaContact(const MTPflags<MTPDinputBotInlineMessageMediaContact::Flags> &_flags, const MTPstring &_phone_number, const MTPstring &_first_name, const MTPstring &_last_name, const MTPReplyMarkup &_reply_markup) { | ||||||
| 		return MTPinputBotInlineMessage(new MTPDinputBotInlineMessageMediaContact(_flags, _phone_number, _first_name, _last_name, _reply_markup)); | 		return MTPinputBotInlineMessage(new MTPDinputBotInlineMessageMediaContact(_flags, _phone_number, _first_name, _last_name, _reply_markup)); | ||||||
| 	} | 	} | ||||||
| 	inline static MTPinputBotInlineMessage new_inputBotInlineMessageGame(const MTPReplyMarkup &_reply_markup) { | 	inline static MTPinputBotInlineMessage new_inputBotInlineMessageGame(const MTPflags<MTPDinputBotInlineMessageGame::Flags> &_flags, const MTPReplyMarkup &_reply_markup) { | ||||||
| 		return MTPinputBotInlineMessage(new MTPDinputBotInlineMessageGame(_reply_markup)); | 		return MTPinputBotInlineMessage(new MTPDinputBotInlineMessageGame(_flags, _reply_markup)); | ||||||
| 	} | 	} | ||||||
| 	inline static MTPinputBotInlineResult new_inputBotInlineResult(const MTPflags<MTPDinputBotInlineResult::Flags> &_flags, const MTPstring &_id, const MTPstring &_type, const MTPstring &_title, const MTPstring &_description, const MTPstring &_url, const MTPstring &_thumb_url, const MTPstring &_content_url, const MTPstring &_content_type, MTPint _w, MTPint _h, MTPint _duration, const MTPInputBotInlineMessage &_send_message) { | 	inline static MTPinputBotInlineResult new_inputBotInlineResult(const MTPflags<MTPDinputBotInlineResult::Flags> &_flags, const MTPstring &_id, const MTPstring &_type, const MTPstring &_title, const MTPstring &_description, const MTPstring &_url, const MTPstring &_thumb_url, const MTPstring &_content_url, const MTPstring &_content_type, MTPint _w, MTPint _h, MTPint _duration, const MTPInputBotInlineMessage &_send_message) { | ||||||
| 		return MTPinputBotInlineResult(new MTPDinputBotInlineResult(_flags, _id, _type, _title, _description, _url, _thumb_url, _content_url, _content_type, _w, _h, _duration, _send_message)); | 		return MTPinputBotInlineResult(new MTPDinputBotInlineResult(_flags, _id, _type, _title, _description, _url, _thumb_url, _content_url, _content_type, _w, _h, _duration, _send_message)); | ||||||
|  | @ -32738,6 +32757,8 @@ inline void MTPsendMessageAction::read(const mtpPrime *&from, const mtpPrime *en | ||||||
| 		} break; | 		} break; | ||||||
| 		case mtpc_sendMessageGeoLocationAction: _type = cons; break; | 		case mtpc_sendMessageGeoLocationAction: _type = cons; break; | ||||||
| 		case mtpc_sendMessageChooseContactAction: _type = cons; break; | 		case mtpc_sendMessageChooseContactAction: _type = cons; break; | ||||||
|  | 		case mtpc_sendMessageGamePlayAction: _type = cons; break; | ||||||
|  | 		case mtpc_sendMessageGameStopAction: _type = cons; break; | ||||||
| 		default: throw mtpErrorUnexpected(cons, "MTPsendMessageAction"); | 		default: throw mtpErrorUnexpected(cons, "MTPsendMessageAction"); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | @ -32773,6 +32794,8 @@ inline MTPsendMessageAction::MTPsendMessageAction(mtpTypeId type) : mtpDataOwner | ||||||
| 		case mtpc_sendMessageUploadDocumentAction: setData(new MTPDsendMessageUploadDocumentAction()); break; | 		case mtpc_sendMessageUploadDocumentAction: setData(new MTPDsendMessageUploadDocumentAction()); break; | ||||||
| 		case mtpc_sendMessageGeoLocationAction: break; | 		case mtpc_sendMessageGeoLocationAction: break; | ||||||
| 		case mtpc_sendMessageChooseContactAction: break; | 		case mtpc_sendMessageChooseContactAction: break; | ||||||
|  | 		case mtpc_sendMessageGamePlayAction: break; | ||||||
|  | 		case mtpc_sendMessageGameStopAction: break; | ||||||
| 		default: throw mtpErrorBadTypeId(type, "MTPsendMessageAction"); | 		default: throw mtpErrorBadTypeId(type, "MTPsendMessageAction"); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | @ -32814,6 +32837,12 @@ inline MTPsendMessageAction MTP_sendMessageGeoLocationAction() { | ||||||
| inline MTPsendMessageAction MTP_sendMessageChooseContactAction() { | inline MTPsendMessageAction MTP_sendMessageChooseContactAction() { | ||||||
| 	return MTP::internal::TypeCreator::new_sendMessageChooseContactAction(); | 	return MTP::internal::TypeCreator::new_sendMessageChooseContactAction(); | ||||||
| } | } | ||||||
|  | inline MTPsendMessageAction MTP_sendMessageGamePlayAction() { | ||||||
|  | 	return MTP::internal::TypeCreator::new_sendMessageGamePlayAction(); | ||||||
|  | } | ||||||
|  | inline MTPsendMessageAction MTP_sendMessageGameStopAction() { | ||||||
|  | 	return MTP::internal::TypeCreator::new_sendMessageGameStopAction(); | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| inline MTPcontacts_found::MTPcontacts_found() : mtpDataOwner(new MTPDcontacts_found()) { | inline MTPcontacts_found::MTPcontacts_found() : mtpDataOwner(new MTPDcontacts_found()) { | ||||||
| } | } | ||||||
|  | @ -35653,7 +35682,7 @@ inline uint32 MTPinputBotInlineMessage::innerLength() const { | ||||||
| 		} | 		} | ||||||
| 		case mtpc_inputBotInlineMessageGame: { | 		case mtpc_inputBotInlineMessageGame: { | ||||||
| 			const MTPDinputBotInlineMessageGame &v(c_inputBotInlineMessageGame()); | 			const MTPDinputBotInlineMessageGame &v(c_inputBotInlineMessageGame()); | ||||||
| 			return v.vreply_markup.innerLength(); | 			return v.vflags.innerLength() + (v.has_reply_markup() ? v.vreply_markup.innerLength() : 0); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	return 0; | 	return 0; | ||||||
|  | @ -35710,7 +35739,8 @@ inline void MTPinputBotInlineMessage::read(const mtpPrime *&from, const mtpPrime | ||||||
| 		case mtpc_inputBotInlineMessageGame: _type = cons; { | 		case mtpc_inputBotInlineMessageGame: _type = cons; { | ||||||
| 			if (!data) setData(new MTPDinputBotInlineMessageGame()); | 			if (!data) setData(new MTPDinputBotInlineMessageGame()); | ||||||
| 			MTPDinputBotInlineMessageGame &v(_inputBotInlineMessageGame()); | 			MTPDinputBotInlineMessageGame &v(_inputBotInlineMessageGame()); | ||||||
| 			v.vreply_markup.read(from, end); | 			v.vflags.read(from, end); | ||||||
|  | 			if (v.has_reply_markup()) { v.vreply_markup.read(from, end); } else { v.vreply_markup = MTPReplyMarkup(); } | ||||||
| 		} break; | 		} break; | ||||||
| 		default: throw mtpErrorUnexpected(cons, "MTPinputBotInlineMessage"); | 		default: throw mtpErrorUnexpected(cons, "MTPinputBotInlineMessage"); | ||||||
| 	} | 	} | ||||||
|  | @ -35756,7 +35786,8 @@ inline void MTPinputBotInlineMessage::write(mtpBuffer &to) const { | ||||||
| 		} break; | 		} break; | ||||||
| 		case mtpc_inputBotInlineMessageGame: { | 		case mtpc_inputBotInlineMessageGame: { | ||||||
| 			const MTPDinputBotInlineMessageGame &v(c_inputBotInlineMessageGame()); | 			const MTPDinputBotInlineMessageGame &v(c_inputBotInlineMessageGame()); | ||||||
| 			v.vreply_markup.write(to); | 			v.vflags.write(to); | ||||||
|  | 			if (v.has_reply_markup()) v.vreply_markup.write(to); | ||||||
| 		} break; | 		} break; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | @ -35803,8 +35834,9 @@ Q_DECLARE_OPERATORS_FOR_FLAGS(MTPDinputBotInlineMessageMediaContact::Flags) | ||||||
| inline MTPinputBotInlineMessage MTP_inputBotInlineMessageMediaContact(const MTPflags<MTPDinputBotInlineMessageMediaContact::Flags> &_flags, const MTPstring &_phone_number, const MTPstring &_first_name, const MTPstring &_last_name, const MTPReplyMarkup &_reply_markup) { | inline MTPinputBotInlineMessage MTP_inputBotInlineMessageMediaContact(const MTPflags<MTPDinputBotInlineMessageMediaContact::Flags> &_flags, const MTPstring &_phone_number, const MTPstring &_first_name, const MTPstring &_last_name, const MTPReplyMarkup &_reply_markup) { | ||||||
| 	return MTP::internal::TypeCreator::new_inputBotInlineMessageMediaContact(_flags, _phone_number, _first_name, _last_name, _reply_markup); | 	return MTP::internal::TypeCreator::new_inputBotInlineMessageMediaContact(_flags, _phone_number, _first_name, _last_name, _reply_markup); | ||||||
| } | } | ||||||
| inline MTPinputBotInlineMessage MTP_inputBotInlineMessageGame(const MTPReplyMarkup &_reply_markup) { | Q_DECLARE_OPERATORS_FOR_FLAGS(MTPDinputBotInlineMessageGame::Flags) | ||||||
| 	return MTP::internal::TypeCreator::new_inputBotInlineMessageGame(_reply_markup); | inline MTPinputBotInlineMessage MTP_inputBotInlineMessageGame(const MTPflags<MTPDinputBotInlineMessageGame::Flags> &_flags, const MTPReplyMarkup &_reply_markup) { | ||||||
|  | 	return MTP::internal::TypeCreator::new_inputBotInlineMessageGame(_flags, _reply_markup); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| inline uint32 MTPinputBotInlineResult::innerLength() const { | inline uint32 MTPinputBotInlineResult::innerLength() const { | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue