• Rémi Bernon's avatar
    server: Track desktop users per thread instead of per process. · 769a2616
    Rémi Bernon authored
    As some thread may use a different desktop from their process.
    
    This fixes the user32 win tests, which leaks a desktop that never gets
    closed. The test_shell_window test creates a new desktop, which spawns
    explorer.exe process, incrementing the desktop user count to 1, then
    associates the desktop to a thread, which closes it on exit.
    
    Never the user count is incremented to 2, and closing the thread desktop
    doesn't either check whether the desktop process should be terminated.
    
    Reversely, it is possible to create a desktop, associate it with a
    thread /and/ a process, and this time the desktop process would be
    terminated when the process exits, although the thread may still be
    using it.
    
    Tracking the users per thread is more robust and fixes the problem as
    set_thread_desktop increments the desktop user count, and thread exit
    decrements it.
    Signed-off-by: 's avatarRémi Bernon <rbernon@codeweavers.com>
    Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
    769a2616
Name
Last commit
Last update
dlls Loading commit data...
documentation Loading commit data...
fonts Loading commit data...
include Loading commit data...
libs Loading commit data...
loader Loading commit data...
nls Loading commit data...
po Loading commit data...
programs Loading commit data...
server Loading commit data...
tools Loading commit data...
.editorconfig Loading commit data...
.mailmap Loading commit data...
ANNOUNCE Loading commit data...
AUTHORS Loading commit data...
COPYING.LIB Loading commit data...
LICENSE Loading commit data...
LICENSE.OLD Loading commit data...
MAINTAINERS Loading commit data...
Makefile.in Loading commit data...
README Loading commit data...
VERSION Loading commit data...
aclocal.m4 Loading commit data...
configure Loading commit data...
configure.ac Loading commit data...