Merge pull request #503 from AttorneyOnline/fix/skip-queue
Fix chat queue being cleared with no way to see what the msgs were
This commit is contained in:
commit
e9eba9b5ab
@ -226,6 +226,9 @@ public:
|
|||||||
// Parse the chat message packet and unpack it into the m_chatmessage[ITEM] format
|
// Parse the chat message packet and unpack it into the m_chatmessage[ITEM] format
|
||||||
void unpack_chatmessage(QStringList p_contents);
|
void unpack_chatmessage(QStringList p_contents);
|
||||||
|
|
||||||
|
// Skip the current queue, adding all the queue messages to the logs if desynchronized logs are disabled
|
||||||
|
void skip_chatmessage_queue();
|
||||||
|
|
||||||
enum LogMode {
|
enum LogMode {
|
||||||
IO_ONLY,
|
IO_ONLY,
|
||||||
DISPLAY_ONLY,
|
DISPLAY_ONLY,
|
||||||
|
@ -1247,7 +1247,7 @@ void Courtroom::set_background(QString p_background, bool display)
|
|||||||
|
|
||||||
// Clear the message queue
|
// Clear the message queue
|
||||||
text_queue_timer->stop();
|
text_queue_timer->stop();
|
||||||
chatmessage_queue.clear();
|
skip_chatmessage_queue();
|
||||||
|
|
||||||
text_state = 2;
|
text_state = 2;
|
||||||
anim_state = 3;
|
anim_state = 3;
|
||||||
@ -1961,8 +1961,10 @@ void Courtroom::chatmessage_enqueue(QStringList p_contents)
|
|||||||
int objection_mod = p_contents[OBJECTION_MOD].split("&")[0].toInt();
|
int objection_mod = p_contents[OBJECTION_MOD].split("&")[0].toInt();
|
||||||
is_objection = objection_mod >= 1 && objection_mod <= 5;
|
is_objection = objection_mod >= 1 && objection_mod <= 5;
|
||||||
// If this is an objection, nuke the queue
|
// If this is an objection, nuke the queue
|
||||||
if (is_objection)
|
if (is_objection) {
|
||||||
chatmessage_queue.clear();
|
text_queue_timer->stop();
|
||||||
|
skip_chatmessage_queue();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Record the log I/O, log files should be accurate.
|
// Record the log I/O, log files should be accurate.
|
||||||
@ -2008,6 +2010,19 @@ void Courtroom::chatmessage_dequeue()
|
|||||||
unpack_chatmessage(chatmessage_queue.dequeue());
|
unpack_chatmessage(chatmessage_queue.dequeue());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Courtroom::skip_chatmessage_queue()
|
||||||
|
{
|
||||||
|
if (ao_app->is_desyncrhonized_logs_enabled()) {
|
||||||
|
chatmessage_queue.clear();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (!chatmessage_queue.isEmpty()) {
|
||||||
|
QStringList p_contents = chatmessage_queue.dequeue();
|
||||||
|
log_chatmessage(p_contents[MESSAGE], p_contents[CHAR_ID].toInt(), p_contents[SHOWNAME], p_contents[TEXT_COLOR].toInt(), DISPLAY_ONLY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void Courtroom::unpack_chatmessage(QStringList p_contents)
|
void Courtroom::unpack_chatmessage(QStringList p_contents)
|
||||||
{
|
{
|
||||||
for (int n_string = 0; n_string < MS_MAXIMUM; ++n_string) {
|
for (int n_string = 0; n_string < MS_MAXIMUM; ++n_string) {
|
||||||
|
Loading…
Reference in New Issue
Block a user