Fix crash when editing an edited message pointing to itself

This commit is contained in:
Nicolas Werner 2021-02-12 16:10:48 +01:00
parent 192c3b7a77
commit 3c91b5b47b
1 changed files with 9 additions and 7 deletions

View File

@ -1542,13 +1542,11 @@ TimelineModel::setEdit(QString newEdit)
if (edit_ != newEdit) {
auto ev = events.get(newEdit.toStdString(), "");
if (ev && mtx::accessors::sender(*ev) == http::client()->user_id().to_string()) {
edit_ = newEdit;
emit editChanged(edit_);
auto e = *ev;
setReply(QString::fromStdString(
mtx::accessors::relations(*ev).reply_to().value_or("")));
mtx::accessors::relations(e).reply_to().value_or("")));
auto msgType = mtx::accessors::msg_type(*ev);
auto msgType = mtx::accessors::msg_type(e);
if (msgType == mtx::events::MessageType::Text ||
msgType == mtx::events::MessageType::Notice) {
input()->setText(relatedInfo(newEdit).quoted_body);
@ -1557,11 +1555,15 @@ TimelineModel::setEdit(QString newEdit)
} else {
input()->setText("");
}
edit_ = newEdit;
} else {
edit_ = "";
emit editChanged(edit_);
resetReply();
input()->setText("");
edit_ = "";
}
emit editChanged(edit_);
}
}