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.

1109 lines
46 KiB

  1. //+-------------------------------------------------------------------------
  2. //
  3. // Microsoft Windows
  4. //
  5. // Copyright (C) Microsoft Corporation, 1998 - 1999
  6. //
  7. // File: dms.h
  8. //
  9. //--------------------------------------------------------------------------
  10. //
  11. // dms.h : david's funky stuff
  12. //
  13. // CLONETO, QIOVERLOAD: see d3drmVisualObj.cpp
  14. //
  15. //
  16. //
  17. #include "basetsd.h"
  18. #include "dvp.h"
  19. #ifdef DEBUG
  20. #define DPF(n,o) {OutputDebugString(o);}
  21. #define DPF1(n,o,p) {char szOutN[1024]; wsprintf(szOutN,o,p);OutputDebugString(szOutN);}
  22. #define DPF2(n,o,p,e) {char szOutN[1024]; wsprintf(szOutN,o,p,e);OutputDebugString(szOutN);}
  23. #else
  24. #define DPF(n,o)
  25. #define DPF1(n,o,p)
  26. #define DPF2(n,o,p,e)
  27. #endif
  28. #define INTERNAL_CREATE_RETOBJ(objType,objOther,retval,classobj) \
  29. { C##objType##Object *prev=NULL; \
  30. *retval = NULL; \
  31. for(C##objType##Object *ptr=(C##objType##Object *)g##objType##; ptr; ptr=(C##objType##Object *)ptr->nextobj) \
  32. { IUnknown *unk=0; \
  33. ptr->InternalGetObject(&unk); \
  34. if(unk == objOther) \
  35. { \
  36. *retval = (I##objType*)ptr->pinterface; \
  37. IUNK(ptr->pinterface)->AddRef(); \
  38. IUNK(objOther)->Release(); \
  39. classobj=ptr; \
  40. break; \
  41. } \
  42. prev = ptr; \
  43. } \
  44. if(!ptr) \
  45. { C##objType##Object *c=new CComObject<C##objType##Object>;if( c == NULL ) { objOther->Release(); return E_FAIL;} \
  46. c->parent = this; \
  47. ((I##objType *)this)->AddRef(); \
  48. c->InternalSetObject(objOther); \
  49. if (FAILED( ((I##objType *)c)->QueryInterface(IID_I##objType, (void **)retval))) \
  50. return E_FAIL; \
  51. c->pinterface = (void*)*retval; \
  52. classobj=c; \
  53. } }
  54. #define INTERNAL_CREATE_STRUCT(objType,retval) { C##objType##Object *c=new CComObject<C##objType##Object>;\
  55. if (c==NULL) return E_OUTOFMEMORY;\
  56. if (FAILED(((I##objType *)c)->QueryInterface(IID_I##objType, (void **)retval))) return E_FAIL;\
  57. }
  58. #define INTERNAL_CREATE_NOADDREF(objType,objOther,retval) {C##objType##Object *prev=NULL; *retval = NULL; \
  59. for(C##objType##Object *ptr=(C##objType##Object *)g##objType##; ptr; ptr=(C##objType##Object *)ptr->nextobj){IUnknown *unk=0;ptr->InternalGetObject(&unk); if(unk == objOther) { *retval = (I##objType*)ptr->pinterface; IUNK(ptr->pinterface)->AddRef(); IUNK(objOther)->Release(); break; } prev = ptr; } \
  60. if(!ptr) { C##objType##Object *c=new CComObject<C##objType##Object>; if( c == NULL ) { objOther->Release();return E_FAIL;} c->InternalSetObject(objOther); if FAILED(((I##objType *)c)->QueryInterface(IID_I##objType, (void **)retval)) return E_FAIL; c->pinterface = (void*)*retval; }}
  61. // Given a java interface (objtype), envoke InternalSetObject and set the given
  62. // DIRECTX pointer (objOther). Also envoke QueryInterface and set a ** interface
  63. // ptr to a DIRECTX object (retval). So we create a DIRECTX object.
  64. //#define INTERNAL_CREATE(objType,objOther,retval){C##objType##Object *c=new CComObject<C##objType##Object>;if( c == NULL ) { objOther->Release(); return E_FAIL;} \
  65. //c->parent = this; AddRef(); c->InternalSetObject(objOther);if (FAILED(c->QueryInterface(IID_I##objType, (void **)retval))) return E_FAIL; }
  66. // if (FAILED(ptr->QueryInterface(IID_I##objType, (void **)retval))) return E_FAIL;
  67. #ifdef _DEBUG
  68. #define INTERNAL_CREATE(objType,objOther,retval) \
  69. { \
  70. DWORD refcount; char buffer[256]; wsprintf(buffer,"INTERNAL_CREATE %s \n",__FILE__); \
  71. OutputDebugString(buffer); \
  72. C##objType##Object *prev=NULL; \
  73. *retval = NULL; \
  74. for(C##objType##Object *ptr=(C##objType##Object *)g##objType##; ptr; ptr=(C##objType##Object *)ptr->nextobj) \
  75. {\
  76. IUnknown *unk=0; \
  77. ptr->InternalGetObject(&unk); \
  78. if(unk == objOther) \
  79. { \
  80. *retval = (I##objType*)ptr->pinterface;\
  81. IUNK(ptr->pinterface)->AddRef();\
  82. IUNK(objOther)->Release(); \
  83. refcount = *(((DWORD*)ptr)+1); \
  84. wsprintf(buffer," Retrived Object [%s] RefCount %d \n\r",__FILE__, refcount);\
  85. OutputDebugString(buffer);\
  86. break; \
  87. } \
  88. prev = ptr; \
  89. } \
  90. if(!ptr) \
  91. { \
  92. C##objType##Object *c=new CComObject<C##objType##Object>;if( c == NULL ) { objOther->Release(); return E_FAIL;} \
  93. c->parent = this; \
  94. ((I##objType *)this)->AddRef(); \
  95. refcount = *(((DWORD*)this)+1); \
  96. wsprintf(buffer,"Object [%s] RefCount[%d]\n\r",__FILE__, refcount);\
  97. OutputDebugString(buffer);\
  98. c->InternalSetObject(objOther);if (FAILED(( ((I##objType *)c))->QueryInterface(IID_I##objType, (void **)retval))) return E_FAIL; \
  99. c->pinterface = (void*)*retval; \
  100. } \
  101. }
  102. #else
  103. #define INTERNAL_CREATE(objType,objOther,retval) \
  104. { \
  105. C##objType##Object *prev=NULL; \
  106. *retval = NULL; \
  107. for(C##objType##Object *ptr=(C##objType##Object *)g##objType##; ptr; ptr=(C##objType##Object *)ptr->nextobj) \
  108. {\
  109. IUnknown *unk=0; \
  110. ptr->InternalGetObject(&unk); \
  111. if(unk == objOther) \
  112. { \
  113. *retval = (I##objType*)ptr->pinterface; \
  114. IUNK(ptr->pinterface)->AddRef(); \
  115. IUNK(objOther)->Release(); \
  116. break; \
  117. } \
  118. prev = ptr; \
  119. } \
  120. if(!ptr) \
  121. { \
  122. C##objType##Object *c=new CComObject<C##objType##Object>;if( c == NULL ) { objOther->Release(); return E_FAIL;} \
  123. c->parent = this; \
  124. ((I##objType *)this)->AddRef(); \
  125. c->InternalSetObject(objOther); \
  126. if (FAILED( ((I##objType *)c)->QueryInterface(IID_I##objType, (void **)retval))) return E_FAIL; \
  127. c->pinterface = (void*)*retval; \
  128. } \
  129. }
  130. #endif
  131. #define INTERNAL_CREATE_2REFS(objType,objParentType,objParent, objOther,retval) \
  132. { \
  133. C##objType##Object *prev=NULL; \
  134. *retval = NULL; \
  135. for(C##objType##Object *ptr=(C##objType##Object *)g##objType##; ptr; ptr=(C##objType##Object *)ptr->nextobj) \
  136. {\
  137. IUnknown *unk=0; \
  138. ptr->InternalGetObject(&unk); \
  139. if(unk == objOther) \
  140. { \
  141. *retval = (I##objType*)ptr->pinterface; \
  142. IUNK(ptr->pinterface)->AddRef(); \
  143. IUNK(objOther)->Release(); \
  144. break; \
  145. } \
  146. prev = ptr; \
  147. } \
  148. if(!ptr) \
  149. { \
  150. C##objType##Object *c=new CComObject<C##objType##Object>;if( c == NULL ) { objOther->Release(); return E_FAIL;} \
  151. c->parent = this; \
  152. c->parent2 = IUNK(objParent); \
  153. ((I##objType *)this)->AddRef(); \
  154. ((I##objParentType*)objParent)->AddRef(); \
  155. c->InternalSetObject(objOther); \
  156. if (FAILED( ((I##objType *)c)->QueryInterface(IID_I##objType, (void **)retval))) return E_FAIL; \
  157. c->pinterface = (void*)*retval; \
  158. } \
  159. }
  160. #define INTERNAL_CREATE_1REFS(objType,objParentType,objParent, objOther,retval) \
  161. { \
  162. C##objType##Object *prev=NULL; \
  163. *retval = NULL; \
  164. for(C##objType##Object *ptr=(C##objType##Object *)g##objType##; ptr; ptr=(C##objType##Object *)ptr->nextobj) \
  165. {\
  166. IUnknown *unk=0; \
  167. ptr->InternalGetObject(&unk); \
  168. if(unk == objOther) \
  169. { \
  170. *retval = (I##objType*)ptr->pinterface; \
  171. IUNK(ptr->pinterface)->AddRef(); \
  172. IUNK(objOther)->Release(); \
  173. break; \
  174. } \
  175. prev = ptr; \
  176. } \
  177. if(!ptr) \
  178. { \
  179. C##objType##Object *c=new CComObject<C##objType##Object>; \
  180. if( c == NULL ) \
  181. { objOther->Release(); return E_FAIL;} \
  182. c->parent = IUNK(objParent); \
  183. ((I##objParentType*)objParent)->AddRef(); \
  184. c->InternalSetObject(objOther); \
  185. if (FAILED( ((I##objType *)c)->QueryInterface(IID_I##objType, (void **)retval))) return E_FAIL; \
  186. c->pinterface = (void*)*retval; \
  187. } \
  188. }
  189. typedef struct FrameMoveCallback3
  190. {
  191. FrameMoveCallback3 *next;
  192. FrameMoveCallback3 *prev;
  193. I_dxj_Direct3dRMFrameMoveCallback3 *c;
  194. IUnknown *pUser;
  195. IUnknown *pParent;
  196. IUnknown *m_obj;
  197. int m_stopflag;
  198. } FrameMoveCallback3;
  199. struct TextureCallback
  200. {
  201. TextureCallback *next;
  202. TextureCallback *prev;
  203. I_dxj_Direct3dRMLoadTextureCallback3 *c;
  204. IUnknown *pUser;
  205. IUnknown *pParent;
  206. IUnknown *m_obj;
  207. int m_stopflag;
  208. };
  209. typedef struct TextureCallback3
  210. {
  211. TextureCallback3 *next;
  212. TextureCallback3 *prev;
  213. I_dxj_Direct3dRMLoadTextureCallback3 *c;
  214. IUnknown *pUser;
  215. IUnknown *pParent;
  216. IUnknown *m_obj;
  217. int m_stopflag;
  218. } TextureCallback3;
  219. struct d3drmCallback // used for AddDestroyCallback
  220. {
  221. d3drmCallback *next;
  222. d3drmCallback *prev;
  223. I_dxj_Direct3dRMCallback *c;
  224. IUnknown *pUser;
  225. IUnknown *pParent;
  226. IUnknown *m_obj;
  227. int m_stopflag;
  228. };
  229. struct DestroyCallback
  230. {
  231. DestroyCallback *next;
  232. DestroyCallback *prev;
  233. I_dxj_Direct3dRMCallback *c;
  234. IUnknown *pUser;
  235. IUnknown *pParent;
  236. IUnknown *m_obj;
  237. int m_stopflag;
  238. };
  239. struct EnumerateObjectsCallback
  240. {
  241. EnumerateObjectsCallback *next;
  242. EnumerateObjectsCallback *prev;
  243. I_dxj_Direct3dRMEnumerateObjectsCallback *c;
  244. IUnknown *pUser;
  245. IUnknown *pParent;
  246. IUnknown *m_obj;
  247. int m_stopflag;
  248. };
  249. struct GeneralCallback
  250. {
  251. GeneralCallback *next;
  252. GeneralCallback *prev;
  253. IUnknown *c;
  254. IUnknown *pUser;
  255. IUnknown *pParent;
  256. IUnknown *m_obj;
  257. int m_stopflag;
  258. };
  259. typedef struct DeviceUpdateCallback3
  260. {
  261. DeviceUpdateCallback3 *next;
  262. DeviceUpdateCallback3 *prev;
  263. I_dxj_Direct3dRMDeviceUpdateCallback3 *c;
  264. IUnknown *pUser;
  265. IUnknown *pParent;
  266. IUnknown *m_obj;
  267. int m_stopflag;
  268. } DeviceUpdateCallback3;
  269. struct LoadCallback
  270. {
  271. LoadCallback *next;
  272. LoadCallback *prev;
  273. I_dxj_Direct3dRMLoadCallback *c;
  274. IUnknown *pUser;
  275. IUnknown *pParent;
  276. IUnknown *m_obj;
  277. int m_stopflag;
  278. };
  279. /////////////////////////////////////////////////////////////////////////
  280. #define MAX_INTERNAL_STR_LEN 256
  281. struct JavaString
  282. {
  283. DWORD nBytes;
  284. WCHAR Item[MAX_INTERNAL_STR_LEN];
  285. };
  286. /////////////////////////////////////////////////////////////////////////
  287. /////////////////////////////////////////////////////////////////////////
  288. // mod:dp helper macros for stuffing expanded unions in DirectX Structures
  289. #define IUNK(o) ((IUnknown*)(void*)(o))
  290. #define IS_NULLGUID(g) (\
  291. (g->data1==0) && \
  292. (g->data2==0) && \
  293. (g->data3==0) && \
  294. (g->data4[0]==0) && \
  295. (g->data4[1]==0) && \
  296. (g->data4[2]==0) && \
  297. (g->data4[3]==0) && \
  298. (g->data4[4]==0) && \
  299. (g->data4[5]==0) && \
  300. (g->data4[6]==0) && \
  301. (g->data4[7]==0) )
  302. extern HRESULT CopyOutDDSurfaceDesc2(DDSurfaceDesc2 *dOut,DDSURFACEDESC2 *d);
  303. extern HRESULT CopyInDDSurfaceDesc2(DDSURFACEDESC2 *dOut,DDSurfaceDesc2 *d);
  304. extern HRESULT CopyInDDPixelFormat(DDPIXELFORMAT *ddpfOut,DDPixelFormat *pf);
  305. extern HRESULT CopyOutDDPixelFormat( DDPixelFormat *ddpfOut,DDPIXELFORMAT *pf);
  306. /////////////////////////////////////////////////////////////////////////
  307. #define JAVASTRING(item) {sizeof(item)*2-2, L##item}
  308. #define PASS_THROUGH(cl,m) STDMETHODIMP C##cl##Object::m() { return m_##cl->m();}
  309. #define PASS_THROUGH1(c,m,t1) STDMETHODIMP C##c##Object::m(t1 v1) { return m_##c->m(v1);}
  310. #define PASS_THROUGH2(c,m,t1,t2) STDMETHODIMP C##c##Object::m(t1 v1, t2 v2) { return m_##c->m(v1, v2);}
  311. #define PASS_THROUGH3(c,m,t1,t2,t3) STDMETHODIMP C##c##Object::m(t1 v1, t2 v2,t3 v3) { return m_##c->m(v1, v2,v3);}
  312. #define PASS_THROUGH4(c,m,t1,t2,t3,t4) STDMETHODIMP C##c##Object::m(t1 v1,t2 v2,t3 v3,t4 v4){return m_##c->m(v1, v2,v3,v4);}
  313. #define PASS_THROUGH5(c,m,t1,t2,t3,t4,t5) STDMETHODIMP C##c##Object::m(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5){return m_##c->m(v1, v2,v3,v4,v5);}
  314. #define PASS_THROUGH6(c,m,t1,t2,t3,t4,t5,t6) STDMETHODIMP C##c##Object::m(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6){return m_##c->m(v1, v2,v3,v4,v5,v6);}
  315. #define PASS_THROUGH7(c,m,t1,t2,t3,t4,t5,t6,t7) STDMETHODIMP C##c##Object::m(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6,t7 v7){return m_##c->m(v1, v2,v3,v4,v5,v6,v7);}
  316. #define PASS_THROUGH8(c,m,t1,t2,t3,t4,t5,t6,t7,t8) STDMETHODIMP C##c##Object::m(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6,t7 v7,t8 v8){return m_##c->m(v1,v2,v3,v4,v5,v6,v7,v8);}
  317. #define PASS_THROUGH_CAST_1(c,m,t1,tt1) STDMETHODIMP C##c##Object::m(t1 v1) { return m_##c->m(tt1 v1);}
  318. #define PASS_THROUGH_CAST_2(c,m,t1,tt1,t2,tt2) STDMETHODIMP C##c##Object::m(t1 v1, t2 v2) { return m_##c->m(tt1 v1, tt2 v2);}
  319. #define PASS_THROUGH_CAST_3(c,m,t1,tt1,t2,tt2,t3,tt3) STDMETHODIMP C##c##Object::m(t1 v1, t2 v2,t3 v3) { return m_##c->m(tt1 v1,tt2 v2,tt3 v3);}
  320. #define PASS_THROUGH_CAST_4(c,m,t1,tt1,t2,tt2,t3,tt3,t4,tt4) STDMETHODIMP C##c##Object::m(t1 v1,t2 v2,t3 v3,t4 v4){return m_##c->m(tt1 v1, tt2 v2,tt3 v3,tt4 v4);}
  321. #define PASS_THROUGH_CAST_5(c,m,t1,tt1,t2,tt2,t3,tt3,t4,tt4,t5,tt5) STDMETHODIMP C##c##Object::m(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5){return m_##c->m(tt1 v1,tt2 v2,tt3 v3,tt4 v4,tt5 v5);}
  322. #define PASS_THROUGH_CAST_6(c,m,t1,tt1,t2,tt2,t3,tt3,t4,tt4,t5,tt5,t6,tt6) STDMETHODIMP C##c##Object::m(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6){return m_##c->m(tt1 v1,tt2 v2,tt3 v3,tt4 v4,tt5 v5,tt6 v6);}
  323. #define PASS_THROUGH_CAST_7(c,m,t1,tt1,t2,tt2,t3,tt3,t4,tt4,t5,tt5,t6,tt6,t7,tt7) STDMETHODIMP C##c##Object::m(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6,t7 v7){return m_##c->m(tt1 v1,tt2 v2,tt3 v3,tt4 v4,tt5 v5,tt6 v6,tt7 v7);}
  324. #define PASS_THROUGH_CAST_8(c,m,t1,tt1,t2,tt2,t3,tt3,t4,tt4,t5,tt5,t6,tt6,t7,tt7,t8,tt8) STDMETHODIMP C##c##Object::m(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6,t7 v7,t8 v8){return m_##c->m(tt1 v1,tt2 v2,tt3 v3,tt4 v4,tt5 v5,tt6 v6,tt7 v7,tt8 v8);}
  325. //mod:dp additions due to renaming
  326. #define PASS_THROUGH_R(c,m1,m2) STDMETHODIMP C##c##Object::m1() { if(m_##c==NULL)return E_FAIL; return m_##c->m2();}
  327. #define PASS_THROUGH1_R(c,m1,m2,t1) STDMETHODIMP C##c##Object::m1(t1 v1) { if(m_##c==NULL)return E_FAIL; return m_##c->m2(v1);}
  328. #define PASS_THROUGH2_R(c,m1,m2,t1,t2) STDMETHODIMP C##c##Object::m1(t1 v1, t2 v2) { if(m_##c==NULL)return E_FAIL; return m_##c->m2(v1, v2);}
  329. #define PASS_THROUGH3_R(c,m1,m2,t1,t2,t3) STDMETHODIMP C##c##Object::m1(t1 v1, t2 v2,t3 v3) { if(m_##c==NULL)return E_FAIL; return m_##c->m2(v1, v2,v3);}
  330. #define PASS_THROUGH4_R(c,m1,m2,t1,t2,t3,t4) STDMETHODIMP C##c##Object::m1(t1 v1,t2 v2,t3 v3,t4 v4){ if(m_##c==NULL)return E_FAIL; return m_##c->m2(v1, v2,v3,v4);}
  331. #define PASS_THROUGH5_R(c,m1,m2,t1,t2,t3,t4,t5) STDMETHODIMP C##c##Object::m1(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5){ if(m_##c==NULL)return E_FAIL; return m_##c->m2(v1, v2,v3,v4,v5);}
  332. #define PASS_THROUGH6_R(c,m1,m2,t1,t2,t3,t4,t5,t6) STDMETHODIMP C##c##Object::m1(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6){ if(m_##c==NULL)return E_FAIL; return m_##c->m2(v1, v2,v3,v4,v5,v6);}
  333. #define PASS_THROUGH7_R(c,m1,m2,t1,t2,t3,t4,t5,t6,t7) STDMETHODIMP C##c##Object::m1(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6,t7 v7){if(m_##c==NULL)return E_FAIL; return m_##c->m2(v1, v2,v3,v4,v5,v6,v7);}
  334. #define PASS_THROUGH8_R(c,m1,m2,t1,t2,t3,t4,t5,t6,t7,t8) STDMETHODIMP C##c##Object::m1(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6,t7 v7,t8 v8){ if(m_##c==NULL)return E_FAIL; return m_##c->m2(v1,v2,v3,v4,v5,v6,v7,v8);}
  335. #define PASS_THROUGH_CAST_1_R(c,m1,m2,t1,tt1) STDMETHODIMP C##c##Object::m1(t1 v1) { if(m_##c==NULL)return E_FAIL; return m_##c->m2(tt1 v1);}
  336. #define PASS_THROUGH_CAST_2_R(c,m1,m2,t1,tt1,t2,tt2) STDMETHODIMP C##c##Object::m1(t1 v1, t2 v2) { if(m_##c==NULL)return E_FAIL; return m_##c->m2(tt1 v1, tt2 v2);}
  337. #define PASS_THROUGH_CAST_3_R(c,m1,m2,t1,tt1,t2,tt2,t3,tt3) STDMETHODIMP C##c##Object::m1(t1 v1, t2 v2,t3 v3) { if(m_##c==NULL)return E_FAIL; return m_##c->m2(tt1 v1,tt2 v2,tt3 v3);}
  338. #define PASS_THROUGH_CAST_4_R(c,m1,m2,t1,tt1,t2,tt2,t3,tt3,t4,tt4) STDMETHODIMP C##c##Object::m1(t1 v1,t2 v2,t3 v3,t4 v4){ if(m_##c==NULL)return E_FAIL; return m_##c->m2(tt1 v1, tt2 v2,tt3 v3,tt4 v4);}
  339. #define PASS_THROUGH_CAST_5_R(c,m1,m2,t1,tt1,t2,tt2,t3,tt3,t4,tt4,t5,tt5) STDMETHODIMP C##c##Object::m1(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5){ if(m_##c==NULL)return E_FAIL; return m_##c->m2(tt1 v1,tt2 v2,tt3 v3,tt4 v4,tt5 v5);}
  340. #define PASS_THROUGH_CAST_6_R(c,m1,m2,t1,tt1,t2,tt2,t3,tt3,t4,tt4,t5,tt5,t6,tt6) STDMETHODIMP C##c##Object::m1(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6){ if(m_##c==NULL)return E_FAIL; return m_##c->m2(tt1 v1,tt2 v2,tt3 v3,tt4 v4,tt5 v5,tt6 v6);}
  341. #define PASS_THROUGH_CAST_7_R(c,m1,m2,t1,tt1,t2,tt2,t3,tt3,t4,tt4,t5,tt5,t6,tt6,t7,tt7) STDMETHODIMP C##c##Object::m1(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6,t7 v7){ if(m_##c==NULL)return E_FAIL; return m_##c->m2(tt1 v1,tt2 v2,tt3 v3,tt4 v4,tt5 v5,tt6 v6,tt7 v7);}
  342. #define PASS_THROUGH_CAST_8_R(c,m1,m2,t1,tt1,t2,tt2,t3,tt3,t4,tt4,t5,tt5,t6,tt6,t7,tt7,t8,tt8) STDMETHODIMP C##c##Object::m1(t1 v1,t2 v2,t3 v3,t4 v4,t5 v5,t6 v6,t7 v7,t8 v8){ if(m_##c==NULL)return E_FAIL; return m_##c->m2(tt1 v1,tt2 v2,tt3 v3,tt4 v4,tt5 v5,tt6 v6,tt7 v7,tt8 v8);}
  343. #define COPY_OR_CLEAR(dest, src, si) {if(src) memcpy((void *)dest, (void *)src, si);else memset((void *)dest, si, 0);}
  344. #define COPY(dest, src, si) memcpy((void *)dest, (void *)src, si)
  345. // ??
  346. #define DECLSET_OBJECT(ifacevar, var, typ) {if(var) var->Release(); var = (typ)ifacevar;}
  347. #define DECLGET_OBJECT(ifacevar, var){*ifacevar = (IUnknown *)var;}
  348. #define ISEQUAL(c) \
  349. STDMETHODIMP C##c##Object::isEqual(I##c *d, int *retval)\
  350. { IUnknown *IU1;\
  351. IUnknown *IU2;\
  352. if (d == NULL)\
  353. return E_FAIL; \
  354. this->InternalGetObject((IUnknown **)(&IU1)); \
  355. d->InternalGetObject((IUnknown **)(&IU2)); \
  356. if (IU1 == IU2) \
  357. *retval = TRUE; \
  358. else \
  359. *retval = FALSE; \
  360. return S_OK;}
  361. #define DX3J_GLOBAL_LINKS( obj_type ) \
  362. int creationid;\
  363. void *parent; \
  364. void *pinterface; \
  365. void *nextobj;
  366. /*STDMETHOD(isEqual)(IUnknown *pobj, int *ret)*/;
  367. // Given a class (c)
  368. #define GETSET_OBJECT(c) \
  369. STDMETHODIMP C##c##Object::InternalSetObject(IUnknown *l)\
  370. {DECLSET_OBJECT(l,m_##c,typedef_##c);return S_OK;} \
  371. STDMETHODIMP C##c##Object::InternalGetObject(IUnknown **l)\
  372. {DECLGET_OBJECT(l,m_##c);return S_OK;}
  373. //ISEQUAL(c);
  374. // Given a java interface, go get a pointer_to_a_pointer to a DIRECTX object
  375. //pac DO_GETOBJECT_NOTNULL is too dangerous and is commented. use DO_GETOBJECT_NOTNULL
  376. //#define DO_GETOBJECT(t,v,i) t v;i->InternalGetObject((IUnknown **)(&v));
  377. #define DO_GETOBJECT_NOTNULL(t,v,i) t v=NULL;if(i) i->InternalGetObject((IUnknown **)(&v));
  378. //
  379. extern int g_creationcount;
  380. #ifdef _DEBUG
  381. #define CONSTRUCTOR(c, o) C##c##Object::C##c##Object(){ \
  382. m_##c = NULL; parent = NULL; pinterface = NULL; \
  383. nextobj = g##c##;\
  384. creationid = ++g_creationcount;\
  385. char buffer[256];\
  386. wsprintf(buffer,"Constructor Creation Id [%d] %s",g_creationcount,__FILE__);\
  387. OutputDebugString(buffer);\
  388. g##c## = (void *)this; o }
  389. #else
  390. #define CONSTRUCTOR(c, o) C##c##Object::C##c##Object(){ \
  391. m_##c = NULL; parent = NULL; pinterface = NULL; \
  392. nextobj = (void*)g##c##; \
  393. creationid = ++g_creationcount; \
  394. g##c## = (void*)this; o}
  395. #endif
  396. #ifdef _DEBUG
  397. #define DESTRUCTOR(c, o) C##c##Object::~C##c##Object(){o; \
  398. char buffer[256]; \
  399. wsprintf(buffer,"Destructor Id[%d] %s ",creationid,__FILE__); \
  400. OutputDebugString(buffer); C##c##Object *prev=NULL; \
  401. for(C##c##Object *ptr=(C##c##Object *)g##c##; ptr; ptr=(C##c##Object *)ptr->nextobj) \
  402. {\
  403. if(ptr == this) \
  404. { \
  405. if(prev) \
  406. prev->nextobj = ptr->nextobj; \
  407. else \
  408. g##c## = (void*)ptr->nextobj; \
  409. break; \
  410. } \
  411. prev = ptr; \
  412. } \
  413. if(m_##c){ int count = IUNK(m_##c)->Release(); wsprintf(buffer,"DirectX %s Ref count [%d]",__FILE__,count); OutputDebugString(buffer); \
  414. if(count==0){ char szOut[512];wsprintf(szOut,"\n Real %s released \n",__FILE__); OutputDebugString(szOut); m_##c = NULL; } \
  415. } \
  416. if(parent) IUNK(parent)->Release(); \
  417. }
  418. #else
  419. #define DESTRUCTOR(c, o) C##c##Object::~C##c##Object(){o; \
  420. C##c##Object *prev=NULL; \
  421. for(C##c##Object *ptr=(C##c##Object *)g##c##; ptr; ptr=(C##c##Object *)ptr->nextobj) \
  422. {\
  423. if(ptr == this) \
  424. { \
  425. if(prev) \
  426. prev->nextobj = ptr->nextobj; \
  427. else \
  428. g##c## = (void*)ptr->nextobj; \
  429. break; \
  430. } \
  431. prev = ptr; \
  432. } \
  433. if(m_##c){ \
  434. if (IUNK(m_##c)->Release()==0) m_##c = NULL; \
  435. } \
  436. if(parent) IUNK(parent)->Release();\
  437. }
  438. #endif
  439. #define OBJCHECK(lable, c) { \
  440. char buffer[256];\
  441. if ( g##c ) \
  442. {\
  443. int count = 0; \
  444. C##c##Object *prev=NULL; \
  445. C##c##Object *ptr;\
  446. for(ptr=(C##c##Object *)g##c##; ptr; ptr=(C##c##Object *)ptr->nextobj) \
  447. {\
  448. DWORD refcount = *(((DWORD*)ptr)+1);\
  449. wsprintf( buffer,"%s: Ref Count [%d] CreateId [%d]\n\r",lable,refcount,ptr->creationid);\
  450. OutputDebugString(buffer);\
  451. count++;\
  452. }\
  453. wsprintf(buffer,"%s: %d \n\r",lable,count);\
  454. OutputDebugString(buffer);\
  455. }\
  456. }
  457. #ifdef _DEBUG
  458. #define CONSTRUCTOR_STRUCT(c, o) C##c##Object::C##c##Object(){ nextobj = g##c##;\
  459. creationid = ++g_creationcount;\
  460. char buffer[256];\
  461. wsprintf(buffer,"Creation Id [%d]",g_creationcount);\
  462. OutputDebugString(buffer);\
  463. g##c## = (void*)this;o}
  464. #else
  465. #define CONSTRUCTOR_STRUCT(c, o) C##c##Object::C##c##Object(){ \
  466. nextobj =(void*) g##c##; \
  467. creationid = ++g_creationcount; \
  468. g##c## = (void*)this; \
  469. o}
  470. #endif
  471. #define DESTRUCTOR_STRUCT(c, o) C##c##Object::~C##c##Object(){o; \
  472. C##c##Object *prev=NULL; \
  473. for(C##c##Object *ptr=(C##c##Object *)g##c##; ptr; ptr=(C##c##Object *)ptr->nextobj) \
  474. {\
  475. if(ptr == this) \
  476. { \
  477. if(prev) \
  478. prev->nextobj = ptr->nextobj; \
  479. else \
  480. g##c## = (void*)ptr->nextobj; \
  481. break; \
  482. } \
  483. prev = ptr; \
  484. } \
  485. }
  486. #define CHECK_AND_RETURN_RMVIS(real,cover,f) {##real *lpReal=NULL;\
  487. if (S_OK==lp->QueryInterface(IID_##real, (void**) &lpReal)){\
  488. I##cover *lpFake=NULL;\
  489. INTERNAL_CREATE(cover, lpReal, (void**)&lpFake);\
  490. if (!lpFake) {IUNK(lpFake)->Release(); return E_OUTOFMEMORY;}\
  491. ((I##cover *)lpFake)->QueryInterface(IID_I_dxj_Direct3dRMVisual,(void**)f);\
  492. ((I##cover *)lpFake)->Release();\
  493. return S_OK;\
  494. }}
  495. // Given a java class (c), create a DIRECTX object and an interface ** ptr to it.
  496. #define RETURN_NEW_ITEM(c,m,oc) STDMETHODIMP C##c##Object::m(I##oc **rv){typedef_##oc lp;\
  497. if( m_##c->m(&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  498. return S_OK;}
  499. #define RETURN_NEW_ITEM_CAST(c,m,oc, ty) STDMETHODIMP C##c##Object::m(I##oc **rv){typedef_##oc lp;\
  500. if( m_##c->m(ty &lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  501. return S_OK;}
  502. #define RETURN_NEW_ITEM_NOREL(c,m,oc) STDMETHODIMP C##c##Object::m(I##oc **rv){typedef_##oc lp;\
  503. if( m_##c->m(&lp) != S_OK)return E_FAIL;INTERNAL_CREATE_NOREL(oc, lp, rv);\
  504. return S_OK;}
  505. #define RETURN_NEW_ITEM1(c,m,oc,t1) STDMETHODIMP C##c##Object::m(t1 v1, I##oc **rv){typedef_##oc lp;\
  506. if( m_##c->m(v1,&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  507. return S_OK;}
  508. #define RETURN_NEW_ITEM2(c,m,oc,t1,t2) STDMETHODIMP C##c##Object::m(t1 v1, t2 v2,I##oc **rv){typedef_##oc lp;\
  509. if( m_##c->m(v1,v2,&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  510. return S_OK;}
  511. #define RETURN_NEW_ITEM_CAST_1(c,m,oc,t1,tt1) STDMETHODIMP C##c##Object::m(t1 v1, I##oc **rv){typedef_##oc lp;\
  512. if( m_##c->m(tt1 v1,&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  513. return S_OK;}
  514. #define RETURN_NEW_ITEM_CAST_2(c,m,oc,t1,tt1,t2,tt2) STDMETHODIMP C##c##Object::m(t1 v1, t2 v2,I##oc **rv){typedef_##oc lp;\
  515. if( m_##c->m(tt1 v1,tt2 v2,&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  516. return S_OK;}
  517. #define RETURN_NEW_ITEM_CAST_3(c,m,oc,t1,tt1,t2,tt2,t3,tt3) STDMETHODIMP C##c##Object::m(t1 v1, t2 v2, t3 v3, I##oc **rv){typedef_##oc lp;\
  518. if( m_##c->m(tt1 v1,tt2 v2,tt3 v3,&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  519. return S_OK;}
  520. //mod:dp additions due to renaming
  521. // Given a java class (c), create a DIRECTX object and an interface ** ptr to it.
  522. #define RETURN_NEW_ITEM_R(c,m,m2,oc) STDMETHODIMP C##c##Object::m(I##oc **rv){typedef_##oc lp;\
  523. if( m_##c->m2(&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  524. return S_OK;}
  525. #define RETURN_NEW_ITEM1_R(c,m,m2,oc,t1) STDMETHODIMP C##c##Object::m(t1 v1, I##oc **rv){typedef_##oc lp;\
  526. if( m_##c->m2(v1,&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  527. return S_OK;}
  528. #define RETURN_NEW_ITEM2_R(c,m,m2,oc,t1,t2) STDMETHODIMP C##c##Object::m(t1 v1, t2 v2,I##oc **rv){typedef_##oc lp;\
  529. if( m_##c->m2(v1,v2,&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  530. return S_OK;}
  531. #define RETURN_NEW_ITEM_CAST_R(c,m,m2,oc,ty) STDMETHODIMP C##c##Object::m(I##oc **rv){typedef_##oc lp;\
  532. if( m_##c->m2(ty &lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  533. return S_OK;}
  534. #define RETURN_NEW_ITEM_CAST_1_R(c,m,m2,oc,t1,tt1) STDMETHODIMP C##c##Object::m(t1 v1, I##oc **rv){typedef_##oc lp;\
  535. if( m_##c->m2(tt1 v1,&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  536. return S_OK;}
  537. #define RETURN_NEW_ITEM_CAST_2_R(c,m,m2,oc,t1,tt1,t2,tt2) STDMETHODIMP C##c##Object::m(t1 v1, t2 v2,I##oc **rv){typedef_##oc lp;\
  538. if( m_##c->m2(tt1 v1,tt2 v2,&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  539. return S_OK;}
  540. #if 0
  541. #define RETURN_NEW_ITEM_NOREL(c,m,oc) STDMETHODIMP C##c##Object::m(I##oc **rv){typedef_##oc lp;\
  542. if( m_##c->m(&lp) != S_OK)return E_FAIL;INTERNAL_CREATE_NOREL(oc, lp, rv);\
  543. return S_OK;}
  544. #define RETURN_NEW_ITEM_CAST_3(c,m,oc,t1,tt1,t2,tt2,t3,tt3) STDMETHODIMP C##c##Object::m(t1 v1, t2 v2, t3 v3, I##oc **rv){typedef_##oc lp;\
  545. if( m_##c->m(tt1 v1,tt2 v2,tt3 v3,&lp) != S_OK)return E_FAIL;INTERNAL_CREATE(oc, lp, rv);\
  546. return S_OK;}
  547. #endif
  548. // Return a primitive value by reference.
  549. #define GET_DIRECT(cl,met,t) STDMETHODIMP C##cl##Object::met(t *h){*h=(t)m_##cl->met();return S_OK;}
  550. #define GET_DIRECT1(cl,met,t,t1) STDMETHODIMP C##cl##Object::met(t1 v1,t *h){*h=(t)m_##cl->met(v1);return S_OK;}
  551. #define GET_DIRECT2(cl,met,t,t1,t2) STDMETHODIMP C##cl##Object::met(t1 v1, t2 v2, t *h){*h=(t)m_##cl->met(v1,v2);return S_OK;}
  552. #define GET_DIRECT_R(cl,met,met2,t) STDMETHODIMP C##cl##Object::met(t *h){*h=(t)m_##cl->met2();return S_OK;}
  553. #define GET_DIRECT1_R(cl,met,met2,t,t1) STDMETHODIMP C##cl##Object::met(t1 v1,t *h){*h=(t)m_##cl->met2(v1);return S_OK;}
  554. #define GET_DIRECT2_R(cl,met,met2,t,t1,t2) STDMETHODIMP C##cl##Object::met(t1 v1, t2 v2, t *h){*h=(t)m_##cl->met2(v1,v2);return S_OK;}
  555. // Return a pointer to a primitive value as a ** ptr.
  556. #define GET_DIRECTPTR(cl,met,t) STDMETHODIMP C##cl##Object::met(t **h){*h=(struct t*)m_##cl->met();return S_OK;}
  557. #define GET_DIRECTPTR1(cl,met,t,t1) STDMETHODIMP C##cl##Object::met(t1 v1,t **h){*h=(struct t*)m_##cl->met(v1);return S_OK;}
  558. #define GET_DIRECTPTR2(cl,met,t,t1,t2) STDMETHODIMP C##cl##Object::met(t1 v1, t2 v2, t **h){*h=(struct t*)m_##cl->met(v1,v2);return S_OK;}
  559. //Do a DO_GETOBJECT_NOTNULL and then call a method on the object
  560. #define DO_GETOBJECT_ANDUSEIT(cl,me,iface) STDMETHODIMP C##cl##Object::me(I##iface *vis) \
  561. {DO_GETOBJECT_NOTNULL( typedef_##iface, lp, vis); if ( m_##cl == NULL ) return E_FAIL; return m_##cl->me(lp); }
  562. #define DO_GETOBJECT_ANDUSEIT_CAST(cl,me,iface, t1) STDMETHODIMP C##cl##Object::me(I##iface *vis) \
  563. {DO_GETOBJECT_NOTNULL( typedef_##iface, lp, vis); if ( m_##cl == NULL ) return E_FAIL; return m_##cl->me((t1)lp); }
  564. #define DO_GETOBJECT_ANDUSEIT1(cl,me,iface,t1) STDMETHODIMP C##cl##Object::me(t1 v1,I##iface *vis) \
  565. {DO_GETOBJECT_NOTNULL( typedef_##iface, lp, vis); if ( m_##cl == NULL ) return E_FAIL; return m_##cl->me(v1, lp); }
  566. #define DO_GETOBJECT_ANDUSEIT2(cl,me,iface,t1,t2) STDMETHODIMP C##cl##Object::me(t1 v1,t2 v2,I##iface *vis) \
  567. {DO_GETOBJECT_NOTNULL( typedef_##iface, lp, vis); if ( m_##cl == NULL ) return E_FAIL; return m_##cl->me(v1, v2, lp); }
  568. //mod:dp additions due to renaming
  569. //Do a DO_GETOBJECT_NOTNULL and then call a method on the object
  570. #define DO_GETOBJECT_ANDUSEIT_R(cl,me, m2, iface) STDMETHODIMP C##cl##Object::me(I##iface *vis) \
  571. {DO_GETOBJECT_NOTNULL( typedef_##iface, lp, vis); if ( m_##cl == NULL ) return E_FAIL; return m_##cl->m2(lp); }
  572. #define DO_GETOBJECT_ANDUSEIT_CAST_R(cl,me, m2, iface, t1) STDMETHODIMP C##cl##Object::me(I##iface *vis) \
  573. {DO_GETOBJECT_NOTNULL( typedef_##iface, lp, vis); if ( m_##cl == NULL ) return E_FAIL; return m_##cl->m2((t1)lp); }
  574. #define DO_GETOBJECT_ANDUSEIT1_R(cl,me, m2, iface,t1) STDMETHODIMP C##cl##Object::me(t1 v1,I##iface *vis) \
  575. {DO_GETOBJECT_NOTNULL( typedef_##iface, lp, vis); if ( m_##cl == NULL ) return E_FAIL; return m_##cl->m2(v1, lp); }
  576. #define DO_GETOBJECT_ANDUSEIT2_R(cl,me, m2, iface,t1,t2) STDMETHODIMP C##cl##Object::me(t1 v1,t2 v2,I##iface *vis) \
  577. {DO_GETOBJECT_NOTNULL( typedef_##iface, lp, vis); if ( m_##cl == NULL ) return E_FAIL; return m_##cl->m2(v1, v2, lp); }
  578. // Make a copy of an object!
  579. //#define CLONE(cl) STDMETHODIMP C##cl##Object::Clone(Id3drmObject **retval){typedef_##cl lp;\
  580. // m_##cl->Clone(0,IID_I##cl,(void **)&lp);INTERNAL_CREATE(cl,lp,retval);return S_OK;}
  581. //#define CLONE(cl) STDMETHODIMP C##cl##Object::Clone(I##cl **retval){typedef_##cl lp;\
  582. //m_##cl->Clone(0,IID_I##cl,(void **)&lp);INTERNAL_CREATE(cl, lp, retval); return S_OK;}
  583. //#define CLONE_R(cl,c2) STDMETHODIMP C##cl##Object::clone(I##cl **retval){typedef_##cl lp;\
  584. //m_##cl->Clone(0,IID_I##c2,(void **)&lp);INTERNAL_CREATE(cl, lp, retval); return S_OK;}
  585. #define CLONE_R(cl,c2) STDMETHODIMP C##cl##Object::clone(IUnknown **retval){typedef_##cl lp;\
  586. m_##cl->Clone(0,IID_I##c2,(void **)&lp);INTERNAL_CREATE(cl, lp, (I##cl **)retval); return S_OK;}
  587. // ??
  588. // Call the d3drmObject->GetName method
  589. extern "C" HRESULT _GetName(IDirect3DRMObject *i, BSTR *Name, BOOL bName);
  590. #define GETNAME(cl) STDMETHODIMP C##cl##Object::GetName(BSTR *n){return _GetName(m_##cl, n, TRUE);}
  591. #define GETCLASSNAME(cl) STDMETHODIMP C##cl##Object::GetClassName(BSTR *n){return _GetName(m_##cl, n, FALSE);}
  592. #define SETNAME(cl) STDMETHODIMP C##cl##Object::SetName(BSTR Name){ \
  593. USES_CONVERSION;\
  594. LPSTR str = W2T(Name); return m_##cl->SetName( str );}
  595. #define GETNAME_R(cl) STDMETHODIMP C##cl##Object::getName(BSTR *n){return _GetName(m_##cl, n, TRUE);}
  596. #define GETCLASSNAME_R(cl) STDMETHODIMP C##cl##Object::getClassName(BSTR *n){return _GetName(m_##cl, n, FALSE);}
  597. #define SETNAME_R(cl) STDMETHODIMP C##cl##Object::setName(BSTR Name){ \
  598. USES_CONVERSION;\
  599. LPSTR str = W2T(Name); return m_##cl->SetName( str );}
  600. extern "C" HRESULT _DeleteDestroyCallback(IDirect3DRMObject *iface, I_dxj_Direct3dRMCallback *oC,
  601. IUnknown *args);
  602. #define DELETEDESTROYCALLBACK(cl) STDMETHODIMP C##cl##Object::DeleteDestroyCallback( I_dxj_Direct3dRMCallback *oC, IUnknown *args) \
  603. {return _DeleteDestroyCallback(m_##cl, oC, args);}
  604. #define DELETEDESTROYCALLBACK_R(cl) STDMETHODIMP C##cl##Object::deleteDestroyCallback( I_dxj_Direct3dRMCallback *oC, IUnknown *args) \
  605. {return _DeleteDestroyCallback(m_##cl, oC, args);}
  606. extern "C" HRESULT _AddDestroyCallback(IDirect3DRMObject *iface, I_dxj_Direct3dRMCallback *oC,
  607. IUnknown *args);
  608. #define ADDDESTROYCALLBACK(cl) STDMETHODIMP C##cl##Object::AddDestroyCallback(I_dxj_Direct3dRMCallback *oC, IUnknown *args) \
  609. {return _AddDestroyCallback(m_##cl, oC, args);}
  610. #define ADDDESTROYCALLBACK_R(cl) STDMETHODIMP C##cl##Object::addDestroyCallback(I_dxj_Direct3dRMCallback *oC, IUnknown *args) \
  611. {return _AddDestroyCallback(m_##cl, oC, args);}
  612. #define CLONETO(clMe, cl, ifaceThat) STDMETHODIMP C##clMe##Object::Get##cl(I##cl **retval) \
  613. { typedef_##cl lp; if (m_##clMe->QueryInterface(ifaceThat, (void **) &lp) != S_OK) return S_FALSE; \
  614. INTERNAL_CREATE( cl, lp, retval); return S_OK; }
  615. #define CLONETO_RX(clMe, cl, ifaceThat) \
  616. STDMETHODIMP C##clMe##Object::getDirect3dRM##cl(I_dxj_Direct3dRM##cl **retval) \
  617. { \
  618. typedef__dxj_Direct3dRM##cl lp; \
  619. if (m_##clMe->QueryInterface(ifaceThat, (void **) &lp) != S_OK) \
  620. return S_FALSE; \
  621. INTERNAL_CREATE( _dxj_Direct3dRM##cl, lp, retval); \
  622. return S_OK; \
  623. }
  624. #define ISSAFEARRAY1D(ppsa,count) ((*ppsa) && ( ((SAFEARRAY*)*ppsa)->cDims==1) && (((SAFEARRAY*)*ppsa)->rgsabound[0].cElements >= count))
  625. /**********************************************************************************************/
  626. extern "C" BOOL ParseWaveResource(void *pvRes, WAVEFORMATEX **ppWaveHeader,
  627. BYTE **ppbWaveData,DWORD *pcbWaveSize);
  628. extern "C" BOOL GetWaveResource(HMODULE hModule, LPCTSTR lpName,
  629. WAVEFORMATEX **ppWaveHeader, BYTE **ppbWaveData, DWORD *pcbWaveSize);
  630. extern "C" DWORD bppToddbd(int bpp);
  631. extern "C" void UndoCallbackLink(GeneralCallback *e, GeneralCallback **h);
  632. extern "C" void PassBackUnicode(LPSTR str, BSTR *Name, DWORD cnt);
  633. extern "C" void ctojDSBufferDesc( LPDSBUFFERDESC lpdd,
  634. DSBufferDesc *ddsb, WaveFormatex *wave);
  635. extern "C" void jtocDSBufferDesc( LPDSBUFFERDESC lpdd,
  636. DSBufferDesc *ddsb, WaveFormatex *wave);
  637. extern "C" void ctojWaveFormatEx( LPWAVEFORMATEX lpdd, WaveFormatex *wave);
  638. extern "C" void CopyFloats(D3DVALUE *mat1, D3DVALUE *mat2, DWORD count);
  639. extern "C" void* CheckCallbackLink(void *current, void **head);
  640. extern "C" void* AddCallbackLink(void **ptr2, I_dxj_Direct3dRMCallback *enumC, void *args);
  641. extern "C" void* AddCallbackLinkRetVal(IUnknown *m_obj, void **ptr2, I_dxj_Direct3dRMCallback *enumC, void *args);
  642. extern "C" void SetStopFlag(IUnknown *m_obj, void** ptr2);
  643. extern "C" BOOL PASCAL myEnumSoundDriversCallback(GUID &SPGuid, LPSTR description,
  644. LPSTR module, void *lpArg);
  645. extern "C" void __cdecl myFrameMoveCallback( LPDIRECT3DRMFRAME lpf,
  646. void *lpArg, D3DVALUE delta);
  647. extern "C" void __cdecl myFrameMoveCallback2( LPDIRECT3DRMFRAME lpf,
  648. void *lpArg, D3DVALUE delta);
  649. extern "C" void __cdecl myFrameMoveCallback3( LPDIRECT3DRMFRAME3 lpf,
  650. void *lpArg, D3DVALUE delta);
  651. extern "C" HRESULT __cdecl myLoadTextureCallback(char *tex_name,
  652. void *lpArg,LPDIRECT3DRMTEXTURE * lpD3DRMTex);
  653. extern "C" HRESULT __cdecl myLoadTextureCallback3(char *tex_name,
  654. void *lpArg,LPDIRECT3DRMTEXTURE3 * lpD3DRMTex);
  655. extern "C" void __cdecl myAddUpdateCallback3(LPDIRECT3DRMDEVICE3 ref,
  656. void *lpArg, int rectCount, LPD3DRECT update);
  657. extern "C" void __cdecl myEnumerateObjectsCallback( LPDIRECT3DRMOBJECT lpo,void *lpArg);
  658. extern "C" int __cdecl myUserVisualCallback(LPDIRECT3DRMUSERVISUAL lpUV,void *lpArg,
  659. DWORD reason, LPDIRECT3DRMDEVICE lpD, LPDIRECT3DRMVIEWPORT lpV);
  660. extern "C" BOOL PASCAL myEnumServiceProvidersCallback(LPGUID lpSPGuid, LPWSTR lpFriendlyName,
  661. DWORD dwMajorVersion,DWORD dwMinorVersion, void *lpArg);
  662. extern "C" BOOL PASCAL myEnumPlayersCallback2(DPID dpid,
  663. DWORD dwPlayerType, LPCDPNAME lpName,
  664. DWORD dwFlags, LPVOID lpContext);
  665. extern "C" BOOL PASCAL myEnumSessionsCallback2(const DPSESSIONDESC2 *gameDesc,
  666. DWORD *timeout, DWORD dwFlags, void *lpArg);
  667. extern "C" BOOL PASCAL myEnumAddressCallback(LPGUID guidDataType,
  668. DWORD dwDataSize, LPCVOID lpData, LPVOID lpContext);
  669. extern "C" BOOL PASCAL myEnumAddressTypesCallback(LPGUID guidDataType,
  670. LPVOID lpContext, DWORD dwFlags);
  671. extern "C" BOOL PASCAL myEnumLocalApplicationsCallback(LPCDPLAPPINFO lpAppInfo,
  672. LPVOID lpContext, DWORD dwFlags);
  673. extern "C" BOOL PASCAL myEnumConnectionsCallback( LPCGUID lpguidSP,
  674. LPVOID lpConnection, DWORD dwConnectionSize, LPCDPNAME lpName,
  675. DWORD dwFlags, LPVOID lpContext);
  676. extern "C" HRESULT PASCAL myEnumSurfacesCallback(LPDIRECTDRAWSURFACE lpDDSurface,
  677. LPDDSURFACEDESC lpDDSurfaceDesc,void *lpContext);
  678. extern "C" HRESULT PASCAL myEnumModesCallback(LPDDSURFACEDESC lpDDSurfaceDesc,
  679. void *lpContext);
  680. extern "C" HRESULT myEnumOverlayZOrdersCallback(LPDIRECTDRAWSURFACE lpDDS,
  681. void *lpContext);
  682. extern "C" HRESULT PASCAL myEnumDevicesCallback( LPGUID Guid, LPSTR DevDesc,
  683. LPSTR DevName, LPD3DDEVICEDESC lpD3DHWDevDesc,
  684. LPD3DDEVICEDESC lpD3DHELDevDesc, void *lpArg);
  685. extern "C" void myd3dValidateCallback(void *lpArg, DWORD offset);
  686. extern "C" HRESULT myEnumTextureFormatsCallback(
  687. LPDDSURFACEDESC lpDdsd, void *lpArg);
  688. extern "C" void __cdecl myAddDestroyCallback(LPDIRECT3DRMOBJECT lpObj,void *lpArg);
  689. extern "C" void __cdecl myd3drmLoadCallback(LPDIRECT3DRMOBJECT lpo,
  690. REFIID ObjectGuid, LPVOID lpArg);
  691. extern "C" HRESULT WINAPI myEnumVideoCallback( LPDDVIDEOPORTCAPS lpDDVideoPortCaps, LPVOID lpContext );
  692. extern "C" BOOL WINAPI myDirectDrawEnumCallback( GUID FAR *lpGUID, LPSTR lpDriverDescription,
  693. LPSTR lpDriverName, LPVOID lpContext );
  694. extern "C" BOOL CALLBACK myEnumDeviceObjectsCallback( LPCDIDEVICEOBJECTINSTANCE pI, LPVOID lpArg ) ;
  695. extern "C" BOOL CALLBACK myEnumCreatedEffectObjectsCallback(LPDIRECTINPUTEFFECT peff, LPVOID lpArg );
  696. extern "C" BOOL CALLBACK myEnumEffectsCallback( LPCDIEFFECTINFO pdei, LPVOID lpArg );
  697. extern "C" BOOL CALLBACK myEnumInputDevicesCallback( LPDIDEVICEINSTANCE lpddi, LPVOID pvRef );
  698. //////////////////////////////////////////////////////////////////////////
  699. extern "C" TextureCallback *TextureCallbacks; //d3drmTexture3
  700. extern "C" TextureCallback3 *TextureCallbacks3; //d3drmTexture3
  701. extern "C" FrameMoveCallback3 *FrameMoveCallbacks3; //d3drmFrame3
  702. extern "C" DeviceUpdateCallback3 *DeviceUpdateCallbacks3;
  703. extern "C" EnumerateObjectsCallback *EnumCallbacks;
  704. extern "C" LoadCallback *LoadCallbacks;
  705. extern "C" DestroyCallback *DestroyCallbacks;
  706. extern HRESULT CopyInDDSuraceDesc2(DDSURFACEDESC2 *dOut,DDSurfaceDesc2 *d);
  707. extern HRESULT CopyInDDPixelFormat(DDPIXELFORMAT *pfOut, DDPixelFormat *pf);
  708. extern HRESULT CopyOutDDSurfaceDesc2(DDSurfaceDesc2 *dOut,DDSURFACEDESC2 *d);
  709. extern HRESULT CopyOutDDPixelFormat(DDPixelFormat *pfOut, DDPIXELFORMAT *pf);
  710. extern HRESULT CreateCoverObject(LPDIRECT3DRMOBJECT lp, I_dxj_Direct3dRMObject** f);
  711. extern HRESULT CreateCoverVisual(LPDIRECT3DRMOBJECT lp, I_dxj_Direct3dRMVisual** v);
  712. /*
  713. **********************************************************************
  714. * INTERNAL_CREATE(thisClass, var, retval)
  715. * thisClass class we are working on
  716. * var variable created in routine to get DirectX object
  717. * retval return value back to java
  718. *
  719. * wrap a DirectX object in one of ours and shove it in the return value
  720. ***********************************************************************
  721. * INTERNAL_CREATE_NOREL(thisClass, var, retval)
  722. * thisClass class we are working on
  723. * var variable created in routine to get DirectX object
  724. * retval return value back to java
  725. *
  726. * wrap a DirectX object in one of ours and shove it in the return value
  727. * If the layer obejct fails, DONT release the DirectX object
  728. ***********************************************************************
  729. * DO_GETOBJECT_NOTNULL(type,var,iface)
  730. * type type of variable we are creating
  731. * var variable we are creating
  732. * iface layer iface where we are getting the object from
  733. *
  734. * declare and get a DirectX object from a layer object
  735. ***********************************************************************
  736. * DO_GETOBJECT_NOTNULL(type,var,iface)
  737. * type type of variable we are creating
  738. * var variable we are creating
  739. * iface layer iface where we are getting the object from
  740. *
  741. * same as DO_GETOBJECT_NOTNULL except that we check for iface==NULL before calling
  742. ***********************************************************************
  743. * PASS_THROUGH[x](class,method,[...])
  744. * class this class
  745. * method method to call
  746. *
  747. * pass call straight through
  748. ***********************************************************************
  749. * PASS_THROUGH_CAST_[x](class,method,[...])
  750. * class this class
  751. * method method to call
  752. *
  753. * pass call straight through, casting the parameters to allow the call to pass
  754. ***********************************************************************
  755. * RETURN_NEW_ITEM(thisClass,method,OtherClass)
  756. * thisClass class being worked on
  757. * method method working on
  758. * otherClass class whose object we want
  759. *
  760. * call DirectX method to get the DirectX object, then wrap it in one of our layer
  761. * objects
  762. ***********************************************************************
  763. * RETURN_NEW_ITEM[1,2](thisClass,method,OtherClass,type)
  764. * thisClass class being worked on
  765. * method method working on
  766. * otherClass class whose object we want
  767. * type type of parameter
  768. *
  769. * Same as RETURN_NEWITEM except that there is an extra parameter (or two) BEFORE the
  770. * returned one
  771. ***********************************************************************
  772. * RETURN_NEW_ITEM_CAST_[1,2](thisClass,method,OtherClass,type)
  773. * thisClass class being worked on
  774. * method method working on
  775. * otherClass class whose object we want
  776. * type type of parameter
  777. *
  778. * Same as RETURN_NEW_ITEM[1,2] except that there the extra parameter(s) are type cast
  779. ******************************************************************************
  780. * RETURN_NEW_ITEM_NOREL(thisClass,method,OtherClass)
  781. * thisClass class being worked on
  782. * method method working on
  783. * otherClass class whose object we want
  784. *
  785. * same as RETURN_NEW_ITEM except that calls INTERNAL_CREATE_NOTREL instead of
  786. * INTERNAL_CREATE
  787. ******************************************************************************
  788. * GET_DIRECT(cl,met,t)
  789. * class class being worked on
  790. * method method being worked on
  791. * t type of the variable being returned
  792. *
  793. * DirectX returns value directly (no HRESULT), we get the value from Direct and
  794. * then return S_OK. (see CddSurfaceObject::Restore, may need to be added).
  795. * Note: the value is passed back via a pointer to that value.
  796. ******************************************************************************
  797. * GET_DIRECT[1,2](cl,met,t,t1)
  798. * class class being worked on
  799. * method method being worked on
  800. * t type of the variable being returned
  801. * t1 type of extra variable(s) BEFORE retval
  802. *
  803. * same as GET_DIRECT but there is another parameter (or two) BEFORE the returned one
  804. ****************************************************************************************
  805. * GET_DIRECTPTR(cl,met,t)
  806. * class class being worked on
  807. * method method being worked on
  808. * t type of the variable being returned
  809. *
  810. * DirectX returns a pointer to a value directly (no HRESULT), we get the value from
  811. * Direct and then return S_OK. In this case it is a pointer to a pointer.
  812. ***************************************************************************************
  813. * GET_DIRECTPTR[1,2](cl,met,t,t1)
  814. * class class being worked on
  815. * method method being worked on
  816. * t type of the variable being returned
  817. * t1 type of extra variable(s) BEFORE retval
  818. *
  819. * same as GET_DIRECTPTR but there is a parameter (or two) BEFORE the one returned.
  820. ***************************************************************************************
  821. * DO_GETOBJECT_ANDUSEIT(cl,me,iface)
  822. * class class being worked on
  823. * method method being worked on
  824. * iface secondary interface we are interested in
  825. *
  826. * get an internal object from iface and use it in the method. we return from the method
  827. ***************************************************************************************
  828. * DO_GETOBJECT_ANDUSEIT_CAST(cl,me,iface,type)
  829. * class class being worked on
  830. * method method being worked on
  831. * iface secondary interface we are interested in
  832. * type type to cast to in the actual call.
  833. * get an internal object from iface and use it in the method. we return from the method
  834. ***************************************************************************************
  835. * DO_GETOBJECT_ANDUSEIT[1,2](cl,me,iface,ty)
  836. * class class being worked on
  837. * method method being worked on
  838. * iface secondary interface we are interested in
  839. * type type of parameter BEFORE 2nd object
  840. *
  841. * same as DO_GETOBJECT_ANDUSEIT except there is another parameter (or two) BEFORE
  842. * the object one
  843. ************************************************************************************
  844. * CLONE(cl)
  845. * class class to clone
  846. *
  847. * >>>>>>> THIS IS A D3DRMOBJECT METHOD <<<<<<<<<<
  848. ************************************************************************************
  849. * GETNAME(cl)
  850. * class class to retive name of
  851. * >>>>>>> THIS IS A D3DRMOBJECT METHOD <<<<<<<<<<
  852. ************************************************************************************
  853. * GETCLASSNAME(cl)
  854. * class class to retive name of
  855. * >>>>>>> THIS IS A D3DRMOBJECT METHOD <<<<<<<<<<
  856. ************************************************************************************
  857. * DELETEDESTROYCALLBACK(cl)
  858. * class class to retive name of
  859. * >>>>>>> THIS IS A D3DRMOBJECT METHOD <<<<<<<<<<
  860. ************************************************************************************
  861. * QIOVERLOAD(cl, ifaceThat, clThat)
  862. * class class being worked on
  863. * iface iface of DIRECT object. Should really typedef_## this!
  864. * clThat object we are going to create
  865. *
  866. * this is really bright - overloading QI to get new objects
  867. ************************************************************************************
  868. * CLONETO(cl, clThat, ifaceThat)
  869. * class class being worked on
  870. * iface iface of DIRECT object. Should really typedef_## this!
  871. * clThat object we are going to create
  872. *
  873. * this is really bright - overloading QI to get new objects
  874. ************************************************************************************
  875. */
  876. extern void *g_dxj_DirectDraw7;
  877. extern void *g_dxj_Direct3dTexture7;
  878. extern void *g_dxj_DirectDrawSurface7;
  879. extern void *g_dxj_Direct3dDevice7;
  880. extern void *g_dxj_Direct3dVertexBuffer7;
  881. extern void *g_dxj_Direct3d7;
  882. extern void *g_dxj_DirectDrawSurface4;
  883. extern void *g_dxj_Direct3dDevice3;
  884. extern void *g_dxj_Direct3dLight;
  885. extern void *g_dxj_Direct3dMaterial3;
  886. extern void *g_dxj_Direct3dVertexBuffer;
  887. extern void *g_dxj_Direct3d3;
  888. extern void *g_dxj_Direct3dRMAnimation2;
  889. extern void *g_dxj_Direct3dRMAnimationSet2;
  890. extern void *g_dxj_Direct3dRMObjectArray;
  891. extern void *g_dxj_Direct3dRMDeviceArray;
  892. extern void *g_dxj_Direct3dRMDevice3;
  893. extern void *g_dxj_Direct3dRMFaceArray;
  894. extern void *g_dxj_Direct3dRMFace2;
  895. extern void *g_dxj_Direct3dRMFrameArray;
  896. extern void *g_dxj_Direct3dRMFrame3;
  897. extern void *g_dxj_Direct3dRMLightArray;
  898. extern void *g_dxj_Direct3dRMLight;
  899. extern void *g_dxj_Direct3dRMMaterial2;
  900. extern void *g_dxj_Direct3dRMMeshBuilder3;
  901. extern void *g_dxj_Direct3dRMMesh;
  902. extern void *g_dxj_Direct3dRMProgressiveMesh;
  903. extern void *g_dxj_Direct3dRMObject;
  904. extern void *g_dxj_Direct3dRMPickArray;
  905. extern void *g_dxj_Direct3dRMPick2Array;
  906. extern void *g_dxj_Direct3dRMShadow2;
  907. extern void *g_dxj_Direct3dRMTexture3;
  908. extern void *g_dxj_Direct3dRMUserVisual;
  909. extern void *g_dxj_Direct3dRMViewportArray;
  910. extern void *g_dxj_Direct3dRMVisualArray;
  911. extern void *g_dxj_Direct3dRMVisual;
  912. extern void *g_dxj_Direct3dRMClippedVisual;
  913. extern void *g_dxj_Direct3dRMWinDevice;
  914. extern void *g_dxj_Direct3dRMWrap;
  915. extern void *g_dxj_Direct3dTexture2;
  916. extern void *g_dxj_Direct3dViewport3;
  917. extern void *g_dxj_DirectDrawClipper;
  918. extern void *g_dxj_DirectDrawPalette;
  919. extern void *g_dxj_DirectDraw4;
  920. extern void *g_dxj_DDVideoPortContainer;
  921. extern void *g_dxj_DirectDrawVideoPort;
  922. extern void *g_dxj_DirectDrawColorControl;
  923. extern void *g_dxj_DirectSound3dListener;
  924. extern void *g_dxj_DirectSoundBuffer;
  925. extern void *g_dxj_DirectSound3dBuffer;
  926. extern void *g_dxj_DirectSound;
  927. extern void *g_dxj_DirectSoundCapture;
  928. extern void *g_dxj_DirectSoundCaptureBuffer;
  929. extern void *g_dxj_DirectSoundNotify;
  930. extern void *g_dxj_DirectPlay3;
  931. extern void *g_dxj_DirectPlayLobby2;
  932. extern void *g_dxj_Direct3dRM3;
  933. extern void *g_dxj_Direct3dRMViewport2;
  934. extern void *g_dxj_DirectInput;
  935. extern void *g_dxj_DirectInputDevice;
  936. extern void *g_dxj_DirectInputEffect;
  937. extern void *g_dxj_DPAddress;
  938. extern void *g_dxj_DPLConnection;
  939. extern void *g_dxj_DirectDrawGammaControl;
  940. extern void *g_dxj_DirectPlay4;
  941. extern void *g_dxj_DirectPlayLobby3;
  942. #define DXHEAPALLOC malloc
  943. #define DXSTACKALLOC lalloc
  944. #define DXHEAPFREE free
  945. #define DXALLOCBSTR SysAllocString