168 lines
4.6 KiB
C
168 lines
4.6 KiB
C
/*
|
|
* Copyright 2016 Michael Müller
|
|
* Copyright 2017 Andrey Gusev
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
|
*/
|
|
|
|
#define COBJMACROS
|
|
|
|
#include "ntstatus.h"
|
|
#define WIN32_NO_STATUS
|
|
#include "windows.h"
|
|
#include "appmodel.h"
|
|
#include "shlwapi.h"
|
|
|
|
#include "wine/debug.h"
|
|
#include "winternl.h"
|
|
|
|
WINE_DEFAULT_DEBUG_CHANNEL(kernelbase);
|
|
|
|
/***********************************************************************
|
|
* AppPolicyGetProcessTerminationMethod (KERNELBASE.@)
|
|
*/
|
|
LONG WINAPI AppPolicyGetProcessTerminationMethod(HANDLE token, AppPolicyProcessTerminationMethod *policy)
|
|
{
|
|
FIXME("%p, %p\n", token, policy);
|
|
|
|
if(policy)
|
|
*policy = AppPolicyProcessTerminationMethod_ExitProcess;
|
|
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* AppPolicyGetThreadInitializationType (KERNELBASE.@)
|
|
*/
|
|
LONG WINAPI AppPolicyGetThreadInitializationType(HANDLE token, AppPolicyThreadInitializationType *policy)
|
|
{
|
|
FIXME("%p, %p\n", token, policy);
|
|
|
|
if(policy)
|
|
*policy = AppPolicyThreadInitializationType_None;
|
|
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* AppPolicyGetShowDeveloperDiagnostic (KERNELBASE.@)
|
|
*/
|
|
LONG WINAPI AppPolicyGetShowDeveloperDiagnostic(HANDLE token, AppPolicyShowDeveloperDiagnostic *policy)
|
|
{
|
|
FIXME("%p, %p\n", token, policy);
|
|
|
|
if(policy)
|
|
*policy = AppPolicyShowDeveloperDiagnostic_ShowUI;
|
|
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* AppPolicyGetWindowingModel (KERNELBASE.@)
|
|
*/
|
|
LONG WINAPI AppPolicyGetWindowingModel(HANDLE token, AppPolicyWindowingModel *policy)
|
|
{
|
|
FIXME("%p, %p\n", token, policy);
|
|
|
|
if(policy)
|
|
*policy = AppPolicyWindowingModel_ClassicDesktop;
|
|
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* QuirkIsEnabled (KERNELBASE.@)
|
|
*/
|
|
BOOL WINAPI QuirkIsEnabled(void *arg)
|
|
{
|
|
FIXME("(%p): stub\n", arg);
|
|
return FALSE;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* QuirkIsEnabled3 (KERNELBASE.@)
|
|
*/
|
|
BOOL WINAPI QuirkIsEnabled3(void *unk1, void *unk2)
|
|
{
|
|
static int once;
|
|
|
|
if (!once++)
|
|
FIXME("(%p, %p) stub!\n", unk1, unk2);
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* WaitOnAddress (KERNELBASE.@)
|
|
*/
|
|
BOOL WINAPI WaitOnAddress(volatile void *addr, void *cmp, SIZE_T size, DWORD timeout)
|
|
{
|
|
LARGE_INTEGER to;
|
|
NTSTATUS status;
|
|
|
|
if (timeout != INFINITE)
|
|
{
|
|
to.QuadPart = -(LONGLONG)timeout * 10000;
|
|
status = RtlWaitOnAddress((const void *)addr, cmp, size, &to);
|
|
}
|
|
else
|
|
status = RtlWaitOnAddress((const void *)addr, cmp, size, NULL);
|
|
|
|
if (status != STATUS_SUCCESS)
|
|
{
|
|
SetLastError( RtlNtStatusToDosError(status) );
|
|
return FALSE;
|
|
}
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
HRESULT WINAPI QISearch(void *base, const QITAB *table, REFIID riid, void **obj)
|
|
{
|
|
const QITAB *ptr;
|
|
IUnknown *unk;
|
|
|
|
TRACE("%p, %p, %s, %p\n", base, table, debugstr_guid(riid), obj);
|
|
|
|
if (!obj)
|
|
return E_POINTER;
|
|
|
|
for (ptr = table; ptr->piid; ++ptr)
|
|
{
|
|
TRACE("trying (offset %d) %s\n", ptr->dwOffset, debugstr_guid(ptr->piid));
|
|
if (IsEqualIID(riid, ptr->piid))
|
|
{
|
|
unk = (IUnknown *)((BYTE *)base + ptr->dwOffset);
|
|
TRACE("matched, returning (%p)\n", unk);
|
|
*obj = unk;
|
|
IUnknown_AddRef(unk);
|
|
return S_OK;
|
|
}
|
|
}
|
|
|
|
if (IsEqualIID(riid, &IID_IUnknown))
|
|
{
|
|
unk = (IUnknown *)((BYTE *)base + table->dwOffset);
|
|
TRACE("returning first for IUnknown (%p)\n", unk);
|
|
*obj = unk;
|
|
IUnknown_AddRef(unk);
|
|
return S_OK;
|
|
}
|
|
|
|
WARN("Not found %s.\n", debugstr_guid(riid));
|
|
*obj = NULL;
|
|
return E_NOINTERFACE;
|
|
}
|