# HG changeset patch # User ib # Date 1310380569 0 # Node ID cdd4fc0616b68b0a7e3256de282cb7a9d871455f # Parent 04b4fa214c2aa5e584280743479c974a45ef1229 Fix memory leak in the Win32 GUI. Use global config variable skinName which has been set prior to the call of create_gui(), don't pass it. diff -r 04b4fa214c2a -r cdd4fc0616b6 gui/win32/gui.c --- a/gui/win32/gui.c Sun Jul 10 15:45:18 2011 +0000 +++ b/gui/win32/gui.c Mon Jul 11 10:36:09 2011 +0000 @@ -1520,7 +1520,7 @@ return 0; } -gui_t *create_gui(char *skindir, char *skinName, void (*playercontrol)(int event)) +gui_t *create_gui(char *skindir, void (*playercontrol)(int event)) { gui_t *gui = calloc(1, sizeof(gui_t)); char temp[MAX_PATH]; @@ -1540,7 +1540,6 @@ /* create playlist */ gui->playlist = create_playlist(); - if(!skinName) skinName = strdup("Blue"); sprintf(temp, "%s\\%s", skindir, skinName); if(create_window(gui, temp)) return NULL; if(create_subwindow(gui, temp)) return NULL; diff -r 04b4fa214c2a -r cdd4fc0616b6 gui/win32/gui.h --- a/gui/win32/gui.h Sun Jul 10 15:45:18 2011 +0000 +++ b/gui/win32/gui.h Mon Jul 11 10:36:09 2011 +0000 @@ -98,7 +98,7 @@ #define wsMovable 2 #define wsSizeable 4 -gui_t *create_gui(char *skindir, char *skinName, void (*playercontrol)(int event)); +gui_t *create_gui(char *skindir, void (*playercontrol)(int event)); int destroy_window(gui_t *gui); int create_window(gui_t *gui, char *skindir); int create_subwindow(gui_t *gui, char *skindir); diff -r 04b4fa214c2a -r cdd4fc0616b6 gui/win32/interface.c --- a/gui/win32/interface.c Sun Jul 10 15:45:18 2011 +0000 +++ b/gui/win32/interface.c Mon Jul 11 10:36:09 2011 +0000 @@ -377,7 +377,7 @@ MSG msg; if(!skinName) skinName = strdup("Blue"); - if(!mygui) mygui = create_gui(get_path("skins"), skinName, guiSetEvent); + if(!mygui) mygui = create_gui(get_path("skins"), guiSetEvent); if(!mygui) exit_player(EXIT_ERROR); if(autosync && autosync != gtkAutoSync)