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.

359 lines
6.6 KiB

  1. //---------------------------------------------------------------------------
  2. //
  3. // Microsoft Windows
  4. // Copyright (C) Microsoft Corporation, 1992 - 1995
  5. //
  6. // File: object.cxx
  7. //
  8. // Contents: Windows NT 3.5 Enumerator Code
  9. //
  10. // History:
  11. //----------------------------------------------------------------------------
  12. #include "ldap.hxx"
  13. #pragma hdrstop
  14. ObjectTypeList::ObjectTypeList()
  15. {
  16. _pObjList = NULL;
  17. _dwCurrentIndex = 0;
  18. _dwMaxElements = 0;
  19. _dwUBound = 0;
  20. _dwLBound = 0;
  21. }
  22. HRESULT
  23. ObjectTypeList::CreateObjectTypeList(
  24. VARIANT vFilter,
  25. ObjectTypeList ** ppObjectTypeList
  26. )
  27. {
  28. ObjectTypeList * pObjectTypeList = NULL;
  29. HRESULT hr = S_OK;
  30. pObjectTypeList = new ObjectTypeList;
  31. if (!pObjectTypeList) {
  32. hr = E_OUTOFMEMORY;
  33. BAIL_ON_FAILURE(hr);
  34. }
  35. hr = BuildObjectArray(
  36. vFilter,
  37. &pObjectTypeList->_pObjList,
  38. &pObjectTypeList->_dwMaxElements
  39. );
  40. if (FAILED(hr)) {
  41. hr = BuildDefaultObjectArray(
  42. gpFilters,
  43. gdwMaxFilters,
  44. &pObjectTypeList->_pObjList,
  45. &pObjectTypeList->_dwMaxElements
  46. );
  47. BAIL_ON_FAILURE(hr);
  48. }
  49. hr = SafeArrayGetUBound(
  50. pObjectTypeList->_pObjList,
  51. 1,
  52. (long FAR *)&pObjectTypeList->_dwUBound
  53. );
  54. BAIL_ON_FAILURE(hr);
  55. hr = SafeArrayGetLBound(
  56. pObjectTypeList->_pObjList,
  57. 1,
  58. (long FAR *)&pObjectTypeList->_dwLBound
  59. );
  60. BAIL_ON_FAILURE(hr);
  61. pObjectTypeList->_dwCurrentIndex = pObjectTypeList->_dwLBound;
  62. *ppObjectTypeList = pObjectTypeList;
  63. RRETURN(S_OK);
  64. error:
  65. if (pObjectTypeList) {
  66. delete pObjectTypeList;
  67. }
  68. RRETURN(hr);
  69. }
  70. ObjectTypeList::~ObjectTypeList()
  71. {
  72. HRESULT hr = S_OK;
  73. if (_pObjList) {
  74. hr = SafeArrayDestroy(_pObjList);
  75. }
  76. }
  77. HRESULT
  78. ObjectTypeList::GetCurrentObject(
  79. PDWORD pdwObject
  80. )
  81. {
  82. HRESULT hr = S_OK;
  83. if (_dwCurrentIndex > _dwUBound) {
  84. return(E_FAIL);
  85. }
  86. hr = SafeArrayGetElement(
  87. _pObjList,
  88. (long FAR *)&_dwCurrentIndex,
  89. (void *)pdwObject
  90. );
  91. RRETURN(hr);
  92. }
  93. HRESULT
  94. ObjectTypeList::Next()
  95. {
  96. HRESULT hr = S_OK;
  97. _dwCurrentIndex++;
  98. if (_dwCurrentIndex > _dwUBound) {
  99. return(E_FAIL);
  100. }
  101. return(hr);
  102. }
  103. HRESULT
  104. ObjectTypeList::Reset()
  105. {
  106. HRESULT hr = S_OK;
  107. return(hr);
  108. }
  109. HRESULT
  110. IsValidFilter(
  111. LPTSTR ObjectName,
  112. DWORD *pdwFilterId,
  113. PFILTERS pFilters,
  114. DWORD dwMaxFilters
  115. )
  116. {
  117. DWORD i = 0;
  118. for (i = 0; i < dwMaxFilters; i++) {
  119. if (!_tcsicmp(ObjectName, (pFilters + i)->szObjectName)) {
  120. *pdwFilterId = (pFilters + i)->dwFilterId;
  121. RRETURN(S_OK);
  122. }
  123. }
  124. *pdwFilterId = 0;
  125. RRETURN(E_FAIL);
  126. }
  127. HRESULT
  128. BuildDefaultObjectArray(
  129. PFILTERS pFilters,
  130. DWORD dwMaxFilters,
  131. SAFEARRAY ** ppFilter,
  132. DWORD * pdwNumElements
  133. )
  134. {
  135. DWORD i;
  136. HRESULT hr = S_OK;
  137. SAFEARRAYBOUND sabNewArray;
  138. SAFEARRAY * pFilter = NULL;
  139. sabNewArray.cElements = dwMaxFilters;
  140. sabNewArray.lLbound = 0;
  141. pFilter = SafeArrayCreate(
  142. VT_I4,
  143. 1,
  144. &sabNewArray
  145. );
  146. if (!pFilter){
  147. hr = E_OUTOFMEMORY;
  148. BAIL_ON_FAILURE(hr);
  149. }
  150. for (i = 0; i < dwMaxFilters; i++) {
  151. hr = SafeArrayPutElement(
  152. pFilter,
  153. (long *)&i,
  154. (void *)&((pFilters + i)->dwFilterId)
  155. );
  156. BAIL_ON_FAILURE(hr);
  157. }
  158. *ppFilter = pFilter;
  159. *pdwNumElements = dwMaxFilters;
  160. RRETURN(S_OK);
  161. error:
  162. if (pFilter) {
  163. SafeArrayDestroy(pFilter);
  164. }
  165. *ppFilter = NULL;
  166. *pdwNumElements = 0;
  167. RRETURN(hr);
  168. }
  169. HRESULT
  170. BuildObjectArray(
  171. VARIANT var,
  172. SAFEARRAY ** ppFilter,
  173. DWORD * pdwNumElements
  174. )
  175. {
  176. LONG uDestCount = 0;
  177. LONG dwSLBound = 0;
  178. LONG dwSUBound = 0;
  179. VARIANT v;
  180. VARIANT varDest;
  181. LONG i;
  182. HRESULT hr = S_OK;
  183. SAFEARRAYBOUND sabNewArray;
  184. DWORD dwFilterId;
  185. SAFEARRAY * pFilter = NULL;
  186. if(!(V_VT(&var) == (VT_VARIANT|VT_ARRAY))) {
  187. RRETURN(E_FAIL);
  188. }
  189. //
  190. // Check that there is only one dimension in this array
  191. //
  192. if ((V_ARRAY(&var))->cDims != 1) {
  193. hr = E_FAIL;
  194. BAIL_ON_FAILURE(hr);
  195. }
  196. //
  197. // Check that there is atleast one element in this array
  198. //
  199. if ((V_ARRAY(&var))->rgsabound[0].cElements == 0){
  200. hr = E_FAIL;
  201. BAIL_ON_FAILURE(hr);
  202. }
  203. //
  204. // We know that this is a valid single dimension array
  205. //
  206. hr = SafeArrayGetLBound(V_ARRAY(&var),
  207. 1,
  208. (long FAR *)&dwSLBound
  209. );
  210. BAIL_ON_FAILURE(hr);
  211. hr = SafeArrayGetUBound(V_ARRAY(&var),
  212. 1,
  213. (long FAR *)&dwSUBound
  214. );
  215. BAIL_ON_FAILURE(hr);
  216. sabNewArray.cElements = dwSUBound - dwSLBound + 1;
  217. sabNewArray.lLbound = dwSLBound;
  218. pFilter = SafeArrayCreate(
  219. VT_I4,
  220. 1,
  221. &sabNewArray
  222. );
  223. if (!pFilter) {
  224. hr = E_OUTOFMEMORY;
  225. BAIL_ON_FAILURE(hr);
  226. }
  227. for (i = dwSLBound; i <= dwSUBound; i++) {
  228. VariantInit(&v);
  229. hr = SafeArrayGetElement(V_ARRAY(&var),
  230. (long FAR *)&i,
  231. &v
  232. );
  233. if (FAILED(hr)) {
  234. continue;
  235. }
  236. hr = IsValidFilter(
  237. V_BSTR(&v),
  238. &dwFilterId,
  239. gpFilters,
  240. gdwMaxFilters
  241. );
  242. if (FAILED(hr)) {
  243. VariantClear(&v);
  244. continue;
  245. }
  246. VariantClear(&v);
  247. hr = SafeArrayPutElement(
  248. pFilter,
  249. (long*)&uDestCount,
  250. (void *)&dwFilterId
  251. );
  252. if(FAILED(hr)){
  253. continue;
  254. }
  255. uDestCount++;
  256. }
  257. //
  258. // There was nothing of value that could be retrieved from the
  259. // filter.
  260. //
  261. if (!uDestCount ) {
  262. hr = E_FAIL;
  263. BAIL_ON_FAILURE(hr);
  264. }
  265. *pdwNumElements = uDestCount;
  266. *ppFilter = pFilter;
  267. RRETURN(S_OK);
  268. error:
  269. if (pFilter) {
  270. SafeArrayDestroy(pFilter);
  271. }
  272. *ppFilter = NULL;
  273. *pdwNumElements = 0;
  274. RRETURN(hr);
  275. }