dmusic: Add trace to DMUSIC_CreateReferenceClockImpl and rename some variables.
[wine/multimedia.git] / dlls / dmusic / clock.c
blob45058760ff4bcf23ded7998e3938dfc6765290d9
1 /* IReferenceClock Implementation
3 * Copyright (C) 2003-2004 Rok Mandeljc
5 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2.1 of the License, or (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this program; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
20 #include "dmusic_private.h"
22 WINE_DEFAULT_DEBUG_CHANNEL(dmusic);
24 /* IReferenceClockImpl IUnknown part: */
25 static HRESULT WINAPI IReferenceClockImpl_QueryInterface (IReferenceClock *iface, REFIID riid, LPVOID *ppobj) {
26 IReferenceClockImpl *This = (IReferenceClockImpl *)iface;
27 TRACE("(%p, %s, %p)\n", This, debugstr_dmguid(riid), ppobj);
29 if (IsEqualIID (riid, &IID_IUnknown) ||
30 IsEqualIID (riid, &IID_IReferenceClock)) {
31 IUnknown_AddRef(iface);
32 *ppobj = This;
33 return S_OK;
35 WARN("(%p, %s, %p): not found\n", This, debugstr_dmguid(riid), ppobj);
36 return E_NOINTERFACE;
39 static ULONG WINAPI IReferenceClockImpl_AddRef (IReferenceClock *iface) {
40 IReferenceClockImpl *This = (IReferenceClockImpl *)iface;
41 ULONG refCount = InterlockedIncrement(&This->ref);
43 TRACE("(%p)->(ref before=%u)\n", This, refCount - 1);
45 DMUSIC_LockModule();
47 return refCount;
50 static ULONG WINAPI IReferenceClockImpl_Release (IReferenceClock *iface) {
51 IReferenceClockImpl *This = (IReferenceClockImpl *)iface;
52 ULONG refCount = InterlockedDecrement(&This->ref);
54 TRACE("(%p)->(ref before=%u)\n", This, refCount + 1);
56 if (!refCount) {
57 HeapFree(GetProcessHeap(), 0, This);
60 DMUSIC_UnlockModule();
62 return refCount;
65 /* IReferenceClockImpl IReferenceClock part: */
66 static HRESULT WINAPI IReferenceClockImpl_GetTime (IReferenceClock *iface, REFERENCE_TIME* pTime) {
67 IReferenceClockImpl *This = (IReferenceClockImpl *)iface;
68 TRACE("(%p, %p)\n", This, pTime);
69 *pTime = This->rtTime;
70 return S_OK;
73 static HRESULT WINAPI IReferenceClockImpl_AdviseTime (IReferenceClock *iface, REFERENCE_TIME baseTime, REFERENCE_TIME streamTime, HANDLE hEvent, DWORD* pdwAdviseCookie) {
74 IReferenceClockImpl *This = (IReferenceClockImpl *)iface;
75 FIXME("(%p, 0x%s, 0x%s, %p, %p): stub\n", This, wine_dbgstr_longlong(baseTime), wine_dbgstr_longlong(streamTime), hEvent, pdwAdviseCookie);
76 return S_OK;
79 static HRESULT WINAPI IReferenceClockImpl_AdvisePeriodic (IReferenceClock *iface, REFERENCE_TIME startTime, REFERENCE_TIME periodTime, HANDLE hSemaphore, DWORD* pdwAdviseCookie) {
80 IReferenceClockImpl *This = (IReferenceClockImpl *)iface;
81 FIXME("(%p, 0x%s, 0x%s, %p, %p): stub\n", This, wine_dbgstr_longlong(startTime), wine_dbgstr_longlong(periodTime), hSemaphore, pdwAdviseCookie);
82 return S_OK;
85 static HRESULT WINAPI IReferenceClockImpl_Unadvise (IReferenceClock *iface, DWORD dwAdviseCookie) {
86 IReferenceClockImpl *This = (IReferenceClockImpl *)iface;
87 FIXME("(%p, %d): stub\n", This, dwAdviseCookie);
88 return S_OK;
91 static const IReferenceClockVtbl ReferenceClock_Vtbl = {
92 IReferenceClockImpl_QueryInterface,
93 IReferenceClockImpl_AddRef,
94 IReferenceClockImpl_Release,
95 IReferenceClockImpl_GetTime,
96 IReferenceClockImpl_AdviseTime,
97 IReferenceClockImpl_AdvisePeriodic,
98 IReferenceClockImpl_Unadvise
101 /* for ClassFactory */
102 HRESULT WINAPI DMUSIC_CreateReferenceClockImpl(LPCGUID riid, LPVOID* ret_iface, LPUNKNOWN unkouter)
104 IReferenceClockImpl* clock;
106 TRACE("(%p,%p,%p)\n", riid, ret_iface, unkouter);
108 clock = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(IReferenceClockImpl));
109 if (!clock) {
110 *ret_iface = NULL;
111 return E_OUTOFMEMORY;
114 clock->lpVtbl = &ReferenceClock_Vtbl;
115 clock->ref = 0; /* will be inited by QueryInterface */
116 clock->rtTime = 0;
117 clock->pClockInfo.dwSize = sizeof (DMUS_CLOCKINFO);
119 return IReferenceClockImpl_QueryInterface((IReferenceClock*)clock, riid, ret_iface);