Merge pull request #92201 from bruvzg/input_flush

Clean `Input::frame_parsed_events` before de-initialising scripting languages to ensure no script created events exist at the exit.
This commit is contained in:
Rémi Verschelde 2024-05-30 15:41:56 +02:00
commit be2c5e66f4
No known key found for this signature in database
GPG key ID: C3336907360768E1
3 changed files with 17 additions and 0 deletions

View file

@ -1029,6 +1029,14 @@ void Input::parse_input_event(const Ref<InputEvent> &p_event) {
}
}
#ifdef DEBUG_ENABLED
void Input::flush_frame_parsed_events() {
_THREAD_SAFE_METHOD_
frame_parsed_events.clear();
}
#endif
void Input::flush_buffered_events() {
_THREAD_SAFE_METHOD_

View file

@ -363,6 +363,9 @@ public:
Dictionary get_joy_info(int p_device) const;
void set_fallback_mapping(const String &p_guid);
#ifdef DEBUG_ENABLED
void flush_frame_parsed_events();
#endif
void flush_buffered_events();
bool is_using_input_buffering();
void set_use_input_buffering(bool p_enable);

View file

@ -4182,6 +4182,12 @@ void Main::cleanup(bool p_force) {
ERR_FAIL_COND(!_start_success);
}
#ifdef DEBUG_ENABLED
if (input) {
input->flush_frame_parsed_events();
}
#endif
for (int i = 0; i < TextServerManager::get_singleton()->get_interface_count(); i++) {
TextServerManager::get_singleton()->get_interface(i)->cleanup();
}