Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

132 lines
3.4 KiB

  1. #include "stdafx.h"
  2. #include "Direct.h"
  3. #include "dms.h"
  4. #include "ReferenceClockObj.h"
  5. extern void *g_dxj_ReferenceClock;
  6. ///////////////////////////////////////////////////////////////////
  7. // InternalAddRef
  8. ///////////////////////////////////////////////////////////////////
  9. DWORD C_dxj_ReferenceClockObject::InternalAddRef(){
  10. DWORD i;
  11. i=CComObjectRoot::InternalAddRef();
  12. DPF2(1,"ReferenceClock [%d] AddRef %d \n",creationid,i);
  13. return i;
  14. }
  15. ///////////////////////////////////////////////////////////////////
  16. // InternalRelease
  17. ///////////////////////////////////////////////////////////////////
  18. DWORD C_dxj_ReferenceClockObject::InternalRelease(){
  19. DWORD i;
  20. i=CComObjectRoot::InternalRelease();
  21. DPF2(1,"ReferenceClock [%d] Release %d \n",creationid,i);
  22. return i;
  23. }
  24. ///////////////////////////////////////////////////////////////////
  25. // C_dxj_ReferenceClockObject
  26. ///////////////////////////////////////////////////////////////////
  27. C_dxj_ReferenceClockObject::C_dxj_ReferenceClockObject(){
  28. DPF1(1,"Constructor Creation ReferenceClock Object[%d] \n ",g_creationcount);
  29. m__dxj_ReferenceClock = NULL;
  30. parent = NULL;
  31. pinterface = NULL;
  32. nextobj = g_dxj_ReferenceClock;
  33. creationid = ++g_creationcount;
  34. g_dxj_ReferenceClock = (void *)this;
  35. }
  36. ///////////////////////////////////////////////////////////////////
  37. // ~C_dxj_ReferenceClockObject
  38. ///////////////////////////////////////////////////////////////////
  39. C_dxj_ReferenceClockObject::~C_dxj_ReferenceClockObject()
  40. {
  41. DPF(1,"Entering ~C_dxj_ReferenceClockObject destructor \n");
  42. C_dxj_ReferenceClockObject *prev=NULL;
  43. for(C_dxj_ReferenceClockObject *ptr=(C_dxj_ReferenceClockObject *)g_dxj_ReferenceClock ; ptr; ptr=(C_dxj_ReferenceClockObject *)ptr->nextobj)
  44. {
  45. if(ptr == this)
  46. {
  47. if(prev)
  48. prev->nextobj = ptr->nextobj;
  49. else
  50. g_dxj_ReferenceClock = (void*)ptr->nextobj;
  51. DPF(1,"ReferenceClockObject found in g_dxj list now removed\n");
  52. break;
  53. }
  54. prev = ptr;
  55. }
  56. if(m__dxj_ReferenceClock){
  57. int count = IUNK(m__dxj_ReferenceClock)->Release();
  58. #ifdef DEBUG
  59. char buffer[256];
  60. wsprintf(buffer,"DirectX IReferenceClock Ref count [%d] \n",count);
  61. #endif
  62. if(count==0) m__dxj_ReferenceClock = NULL;
  63. }
  64. if(parent) IUNK(parent)->Release();
  65. }
  66. HRESULT C_dxj_ReferenceClockObject::InternalGetObject(IUnknown **pUnk){
  67. *pUnk=(IUnknown*)m__dxj_ReferenceClock;
  68. return S_OK;
  69. }
  70. HRESULT C_dxj_ReferenceClockObject::InternalSetObject(IUnknown *pUnk){
  71. m__dxj_ReferenceClock=(IReferenceClock*)pUnk;
  72. return S_OK;
  73. }
  74. HRESULT C_dxj_ReferenceClockObject::GetTime(REFERENCE_TIME *ret)
  75. {
  76. HRESULT hr;
  77. if (FAILED(hr=m__dxj_ReferenceClock->GetTime(ret) ) )
  78. return hr;
  79. return S_OK;
  80. }
  81. HRESULT C_dxj_ReferenceClockObject::AdviseTime(REFERENCE_TIME time1, REFERENCE_TIME time2, long lHandle, long *lRet)
  82. {
  83. HRESULT hr;
  84. if (FAILED(hr=m__dxj_ReferenceClock->AdviseTime(time1, time2, (HANDLE) lHandle, (DWORD*) lRet) ) )
  85. return hr;
  86. return S_OK;
  87. }
  88. HRESULT C_dxj_ReferenceClockObject::AdvisePeriodic(REFERENCE_TIME time1, REFERENCE_TIME time2, long lHandle, long *lRet)
  89. {
  90. HRESULT hr;
  91. if (FAILED(hr=m__dxj_ReferenceClock->AdvisePeriodic(time1, time2, (HANDLE) lHandle, (DWORD*) lRet) ) )
  92. return hr;
  93. return S_OK;
  94. }
  95. HRESULT C_dxj_ReferenceClockObject::Unadvise(long lUnadvise)
  96. {
  97. HRESULT hr;
  98. if (FAILED(hr=m__dxj_ReferenceClock->Unadvise((DWORD) lUnadvise) ) )
  99. return hr;
  100. return S_OK;
  101. }