mirror of
https://github.com/reactos/reactos.git
synced 2025-02-24 09:25:10 +00:00
[WIN32K]
- Call IntDestroyCurIconObject instead of explicitly destroying the handle. CORE-7575 svn path=/trunk/; revision=64915
This commit is contained in:
parent
6e51ca263b
commit
f0e276168d
1 changed files with 13 additions and 15 deletions
|
@ -644,40 +644,36 @@ NtUserDestroyCursor(
|
|||
_In_ BOOL bForce)
|
||||
{
|
||||
BOOL ret;
|
||||
PCURICON_OBJECT CurIcon = NULL;
|
||||
|
||||
TRACE("Enter NtUserDestroyCursorIcon (%p, %u)\n", hCurIcon, bForce);
|
||||
UserEnterExclusive();
|
||||
|
||||
CurIcon = UserGetCurIconObject(hCurIcon);
|
||||
if (!CurIcon)
|
||||
{
|
||||
ret = FALSE;
|
||||
goto leave;
|
||||
}
|
||||
|
||||
if (!bForce)
|
||||
{
|
||||
/* Maybe we have good reasons not to destroy this object */
|
||||
PCURICON_OBJECT CurIcon = UserGetCurIconObject(hCurIcon);
|
||||
ULONG Flags;
|
||||
if (!CurIcon)
|
||||
{
|
||||
ret = FALSE;
|
||||
goto leave;
|
||||
}
|
||||
|
||||
if (CurIcon->head.ppi != PsGetCurrentProcessWin32Process())
|
||||
{
|
||||
/* No way, you're not touching my cursor */
|
||||
ret = FALSE;
|
||||
UserDereferenceObject(CurIcon);
|
||||
goto leave;
|
||||
}
|
||||
|
||||
Flags = CurIcon->CURSORF_flags;
|
||||
UserDereferenceObject(CurIcon);
|
||||
|
||||
if (Flags & CURSORF_CURRENT)
|
||||
if (CurIcon->CURSORF_flags & CURSORF_CURRENT)
|
||||
{
|
||||
WARN("Trying to delete current cursor!\n");
|
||||
ret = FALSE;
|
||||
goto leave;
|
||||
}
|
||||
|
||||
if (Flags & CURSORF_LRSHARED)
|
||||
if (CurIcon->CURSORF_flags & CURSORF_LRSHARED)
|
||||
{
|
||||
WARN("Trying to delete shared cursor.\n");
|
||||
/* This one is not an error */
|
||||
|
@ -687,9 +683,11 @@ NtUserDestroyCursor(
|
|||
}
|
||||
|
||||
/* Destroy the handle */
|
||||
ret = UserDeleteObject(hCurIcon, TYPE_CURSOR);
|
||||
ret = IntDestroyCurIconObject(CurIcon);
|
||||
|
||||
leave:
|
||||
if (CurIcon)
|
||||
UserDereferenceObject(CurIcon);
|
||||
TRACE("Leave NtUserDestroyCursorIcon, ret=%i\n", ret);
|
||||
UserLeave();
|
||||
return ret;
|
||||
|
|
Loading…
Reference in a new issue