From fb816a0eb995ad82d92aef697ed4b03bd45b4045 Mon Sep 17 00:00:00 2001 From: Megamouse Date: Thu, 17 Aug 2017 20:56:25 +0200 Subject: [PATCH] osk: fix backspace --- rpcs3/rpcs3qt/msg_dialog_frame.cpp | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/rpcs3/rpcs3qt/msg_dialog_frame.cpp b/rpcs3/rpcs3qt/msg_dialog_frame.cpp index f5bc09670e..0bee3a19cd 100644 --- a/rpcs3/rpcs3qt/msg_dialog_frame.cpp +++ b/rpcs3/rpcs3qt/msg_dialog_frame.cpp @@ -240,7 +240,8 @@ void msg_dialog_frame::CreateOsk(const std::string& msg, char16_t* osk_text) //Events connect(input, &QLineEdit::textChanged, [=] { - std::memcpy(osk_text_return, reinterpret_cast(input->text().constData()), input->text().size() * 2); + std::memset(osk_text_return, 0, 512 * sizeof(char16_t)); // TODO: use max length instead of default 512 + std::memcpy(osk_text_return, reinterpret_cast(input->text().constData()), input->text().size() * sizeof(char16_t)); on_osk_input_entered(); }); connect(input, &QLineEdit::returnPressed, [=] { on_close(CELL_MSGDIALOG_BUTTON_OK); osk_dialog->accept(); }); @@ -269,6 +270,10 @@ msg_dialog_frame::~msg_dialog_frame() { { m_dialog->deleteLater(); } + if (osk_dialog) + { + osk_dialog->deleteLater(); + } } void msg_dialog_frame::ProgressBarSetMsg(u32 index, const std::string& msg)