mirror of https://github.com/procxx/kepka.git
				
				
				
			Sort scheduled messages on an update.
This commit is contained in:
		
							parent
							
								
									99037d3d46
								
							
						
					
					
						commit
						956bb876f6
					
				|  | @ -102,7 +102,9 @@ void ScheduledMessages::apply(const MTPDupdateNewScheduledMessage &update) { | |||
| 	if (!history) { | ||||
| 		return; | ||||
| 	} | ||||
| 	append(history, _data[history], message); | ||||
| 	auto &list = _data[history]; | ||||
| 	append(history, list, message); | ||||
| 	sort(list); | ||||
| 	_updates.fire_copy(history); | ||||
| } | ||||
| 
 | ||||
|  | @ -163,7 +165,7 @@ Data::MessagesSlice ScheduledMessages::list(not_null<History*> history) { | |||
| 		list | ||||
| 	) | ranges::view::transform( | ||||
| 		&HistoryItem::fullId | ||||
| 	) | ranges::view::reverse | ranges::to_vector; | ||||
| 	) | ranges::to_vector; | ||||
| 	return result; | ||||
| } | ||||
| 
 | ||||
|  | @ -203,7 +205,9 @@ void ScheduledMessages::parse( | |||
| 		for (const auto &message : messages) { | ||||
| 			append(history, list, message); | ||||
| 		} | ||||
| 		if (list.items.empty()) { | ||||
| 		if (!list.items.empty()) { | ||||
| 			sort(list); | ||||
| 		} else { | ||||
| 			_data.erase(element); | ||||
| 			element = end(_data); | ||||
| 		} | ||||
|  | @ -225,17 +229,7 @@ void ScheduledMessages::append( | |||
| 	const auto id = message.match([&](const auto &data) { | ||||
| 		return data.vid().v; | ||||
| 	}); | ||||
| 	const auto i = list.itemById.find(id); | ||||
| 	if (i != end(list.itemById)) { | ||||
| 		const auto j = ranges::find( | ||||
| 			list.items, | ||||
| 			i->second.get(), | ||||
| 			&OwnedItem::get); | ||||
| 		const auto e = end(list.items); | ||||
| 		Assert(j != e); | ||||
| 		if (j + 1 != e) { | ||||
| 			std::rotate(j, j + 1, e); | ||||
| 		} | ||||
| 	if (list.itemById.find(id) != end(list.itemById)) { | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
|  | @ -252,6 +246,10 @@ void ScheduledMessages::append( | |||
| 	list.idByItem.emplace(item, id); | ||||
| } | ||||
| 
 | ||||
| void ScheduledMessages::sort(List &list) { | ||||
| 	ranges::sort(list.items, ranges::less(), &HistoryItem::position); | ||||
| } | ||||
| 
 | ||||
| void ScheduledMessages::remove(not_null<const HistoryItem*> item) { | ||||
| 	const auto history = item->history(); | ||||
| 	const auto i = _data.find(history); | ||||
|  | @ -278,7 +276,7 @@ int32 ScheduledMessages::countListHash(const List &list) const { | |||
| 	using namespace Api; | ||||
| 
 | ||||
| 	auto hash = HashInit(); | ||||
| 	for (const auto &item : list.items) { | ||||
| 	for (const auto &item : list.items | ranges::view::reverse) { | ||||
| 		const auto j = list.idByItem.find(item.get()); | ||||
| 		HashUpdate(hash, j->second); | ||||
| 		if (const auto edited = item->Get<HistoryMessageEdited>()) { | ||||
|  |  | |||
|  | @ -56,6 +56,7 @@ private: | |||
| 		not_null<History*> history, | ||||
| 		List &list, | ||||
| 		const MTPMessage &message); | ||||
| 	void sort(List &list); | ||||
| 	void remove(not_null<const HistoryItem*> item); | ||||
| 	[[nodiscard]] int32 countListHash(const List &list) const; | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue