Forráskód Böngészése

Fixed memory leak when removing existing displays

Sam Lantinga 2 éve
szülő
commit
cfc7cac3c9
1 módosított fájl, 1 hozzáadás és 0 törlés
  1. 1 0
      src/video/SDL_video.c

+ 1 - 0
src/video/SDL_video.c

@@ -640,6 +640,7 @@ void SDL_DelVideoDisplay(int index)
     SDL_SendDisplayEvent(&_this->displays[index], SDL_DISPLAYEVENT_DISCONNECTED, 0);
     SDL_SendDisplayEvent(&_this->displays[index], SDL_DISPLAYEVENT_DISCONNECTED, 0);
 
 
     if (index < (_this->num_displays - 1)) {
     if (index < (_this->num_displays - 1)) {
+        SDL_free(_this->displays[index].driverdata);
         SDL_memmove(&_this->displays[index], &_this->displays[index + 1], (_this->num_displays - index - 1) * sizeof(_this->displays[index]));
         SDL_memmove(&_this->displays[index], &_this->displays[index + 1], (_this->num_displays - index - 1) * sizeof(_this->displays[index]));
     }
     }
     --_this->num_displays;
     --_this->num_displays;