Sweden-Number/dlls/wmiutils/path.c

364 lines
7.9 KiB
C
Raw Normal View History

/*
* Copyright 2012 Hans Leidekker for CodeWeavers
*
* 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 "config.h"
#include <stdarg.h>
#include "windef.h"
#include "winbase.h"
#include "ole2.h"
#include "wmiutils.h"
#include "wine/debug.h"
#include "wine/unicode.h"
#include "wmiutils_private.h"
WINE_DEFAULT_DEBUG_CHANNEL(wmiutils);
struct path
{
IWbemPath IWbemPath_iface;
LONG refs;
};
static inline struct path *impl_from_IWbemPath( IWbemPath *iface )
{
return CONTAINING_RECORD(iface, struct path, IWbemPath_iface);
}
static ULONG WINAPI path_AddRef(
IWbemPath *iface )
{
struct path *path = impl_from_IWbemPath( iface );
return InterlockedIncrement( &path->refs );
}
static ULONG WINAPI path_Release(
IWbemPath *iface )
{
struct path *path = impl_from_IWbemPath( iface );
LONG refs = InterlockedDecrement( &path->refs );
if (!refs)
{
TRACE("destroying %p\n", path);
HeapFree( GetProcessHeap(), 0, path );
}
return refs;
}
static HRESULT WINAPI path_QueryInterface(
IWbemPath *iface,
REFIID riid,
void **ppvObject )
{
struct path *path = impl_from_IWbemPath( iface );
TRACE("%p, %s, %p\n", path, debugstr_guid( riid ), ppvObject );
if ( IsEqualGUID( riid, &IID_IWbemPath ) ||
IsEqualGUID( riid, &IID_IUnknown ) )
{
*ppvObject = iface;
}
else
{
FIXME("interface %s not implemented\n", debugstr_guid(riid));
return E_NOINTERFACE;
}
IWbemPath_AddRef( iface );
return S_OK;
}
static HRESULT WINAPI path_SetText(
IWbemPath *iface,
ULONG uMode,
LPCWSTR pszPath)
{
FIXME("%p, %u, %s\n", iface, uMode, debugstr_w(pszPath));
return E_NOTIMPL;
}
static HRESULT WINAPI path_GetText(
IWbemPath *iface,
LONG lFlags,
ULONG *puBufferLength,
LPWSTR pszText)
{
FIXME("%p, 0x%x, %p, %p\n", iface, lFlags, puBufferLength, pszText);
return E_NOTIMPL;
}
static HRESULT WINAPI path_GetInfo(
IWbemPath *iface,
ULONG uRequestedInfo,
ULONGLONG *puResponse)
{
FIXME("%p, %d, %p\n", iface, uRequestedInfo, puResponse);
return E_NOTIMPL;
}
static HRESULT WINAPI path_SetServer(
IWbemPath *iface,
LPCWSTR Name)
{
FIXME("%p, %s\n", iface, debugstr_w(Name));
return E_NOTIMPL;
}
static HRESULT WINAPI path_GetServer(
IWbemPath *iface,
ULONG *puNameBufLength,
LPWSTR pName)
{
FIXME("%p, %p, %p\n", iface, puNameBufLength, pName);
return E_NOTIMPL;
}
static HRESULT WINAPI path_GetNamespaceCount(
IWbemPath *iface,
ULONG *puCount)
{
FIXME("%p, %p\n", iface, puCount);
return E_NOTIMPL;
}
static HRESULT WINAPI path_SetNamespaceAt(
IWbemPath *iface,
ULONG uIndex,
LPCWSTR pszName)
{
FIXME("%p, %u, %s\n", iface, uIndex, debugstr_w(pszName));
return E_NOTIMPL;
}
static HRESULT WINAPI path_GetNamespaceAt(
IWbemPath *iface,
ULONG uIndex,
ULONG *puNameBufLength,
LPWSTR pName)
{
FIXME("%p, %u, %p, %p\n", iface, uIndex, puNameBufLength, pName);
return E_NOTIMPL;
}
static HRESULT WINAPI path_RemoveNamespaceAt(
IWbemPath *iface,
ULONG uIndex)
{
FIXME("%p, %u\n", iface, uIndex);
return E_NOTIMPL;
}
static HRESULT WINAPI path_RemoveAllNamespaces(
IWbemPath *iface)
{
FIXME("%p\n", iface);
return E_NOTIMPL;
}
static HRESULT WINAPI path_GetScopeCount(
IWbemPath *iface,
ULONG *puCount)
{
FIXME("%p, %p\n", iface, puCount);
return E_NOTIMPL;
}
static HRESULT WINAPI path_SetScope(
IWbemPath *iface,
ULONG uIndex,
LPWSTR pszClass)
{
FIXME("%p, %u, %s\n", iface, uIndex, debugstr_w(pszClass));
return E_NOTIMPL;
}
static HRESULT WINAPI path_SetScopeFromText(
IWbemPath *iface,
ULONG uIndex,
LPWSTR pszText)
{
FIXME("%p, %u, %s\n", iface, uIndex, debugstr_w(pszText));
return E_NOTIMPL;
}
static HRESULT WINAPI path_GetScope(
IWbemPath *iface,
ULONG uIndex,
ULONG *puClassNameBufSize,
LPWSTR pszClass,
IWbemPathKeyList **pKeyList)
{
FIXME("%p, %u, %p, %p, %p\n", iface, uIndex, puClassNameBufSize, pszClass, pKeyList);
return E_NOTIMPL;
}
static HRESULT WINAPI path_GetScopeAsText(
IWbemPath *iface,
ULONG uIndex,
ULONG *puTextBufSize,
LPWSTR pszText)
{
FIXME("%p, %u, %p, %p\n", iface, uIndex, puTextBufSize, pszText);
return E_NOTIMPL;
}
static HRESULT WINAPI path_RemoveScope(
IWbemPath *iface,
ULONG uIndex)
{
FIXME("%p, %u\n", iface, uIndex);
return E_NOTIMPL;
}
static HRESULT WINAPI path_RemoveAllScopes(
IWbemPath *iface)
{
FIXME("%p\n", iface);
return E_NOTIMPL;
}
static HRESULT WINAPI path_SetClassName(
IWbemPath *iface,
LPCWSTR Name)
{
FIXME("%p, %s\n", iface, debugstr_w(Name));
return E_NOTIMPL;
}
static HRESULT WINAPI path_GetClassName(
IWbemPath *iface,
ULONG *puBufferLength,
LPWSTR pszName)
{
FIXME("%p,%p, %p\n", iface, puBufferLength, pszName);
return E_NOTIMPL;
}
static HRESULT WINAPI path_GetKeyList(
IWbemPath *iface,
IWbemPathKeyList **pOut)
{
FIXME("%p, %p\n", iface, pOut);
return E_NOTIMPL;
}
static HRESULT WINAPI path_CreateClassPart(
IWbemPath *iface,
LONG lFlags,
LPCWSTR Name)
{
FIXME("%p, 0x%x, %s\n", iface, lFlags, debugstr_w(Name));
return E_NOTIMPL;
}
static HRESULT WINAPI path_DeleteClassPart(
IWbemPath *iface,
LONG lFlags)
{
FIXME("%p, 0x%x\n", iface, lFlags);
return E_NOTIMPL;
}
static BOOL WINAPI path_IsRelative(
IWbemPath *iface,
LPWSTR wszMachine,
LPWSTR wszNamespace)
{
FIXME("%p, %s, %s\n", iface, debugstr_w(wszMachine), debugstr_w(wszNamespace));
return E_NOTIMPL;
}
static BOOL WINAPI path_IsRelativeOrChild(
IWbemPath *iface,
LPWSTR wszMachine,
LPWSTR wszNamespace,
LONG lFlags)
{
FIXME("%p, %s, %s, 0x%x\n", iface, debugstr_w(wszMachine), debugstr_w(wszNamespace), lFlags);
return E_NOTIMPL;
}
static BOOL WINAPI path_IsLocal(
IWbemPath *iface,
LPCWSTR wszMachine)
{
FIXME("%p, %s\n", iface, debugstr_w(wszMachine));
return E_NOTIMPL;
}
static BOOL WINAPI path_IsSameClassName(
IWbemPath *iface,
LPCWSTR wszClass)
{
FIXME("%p, %s\n", iface, debugstr_w(wszClass));
return E_NOTIMPL;
}
static const struct IWbemPathVtbl path_vtbl =
{
path_QueryInterface,
path_AddRef,
path_Release,
path_SetText,
path_GetText,
path_GetInfo,
path_SetServer,
path_GetServer,
path_GetNamespaceCount,
path_SetNamespaceAt,
path_GetNamespaceAt,
path_RemoveNamespaceAt,
path_RemoveAllNamespaces,
path_GetScopeCount,
path_SetScope,
path_SetScopeFromText,
path_GetScope,
path_GetScopeAsText,
path_RemoveScope,
path_RemoveAllScopes,
path_SetClassName,
path_GetClassName,
path_GetKeyList,
path_CreateClassPart,
path_DeleteClassPart,
path_IsRelative,
path_IsRelativeOrChild,
path_IsLocal,
path_IsSameClassName
};
HRESULT WbemPath_create( IUnknown *pUnkOuter, LPVOID *ppObj )
{
struct path *path;
TRACE("%p, %p\n", pUnkOuter, ppObj);
if (!(path = HeapAlloc( GetProcessHeap(), 0, sizeof(*path) ))) return E_OUTOFMEMORY;
path->IWbemPath_iface.lpVtbl = &path_vtbl;
path->refs = 1;
*ppObj = &path->IWbemPath_iface;
TRACE("returning iface %p\n", *ppObj);
return S_OK;
}