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.

1298 lines
32 KiB

  1. /*++
  2. Copyright (C) 1996-2001 Microsoft Corporation
  3. Module Name:
  4. TEXTCONV.CPP
  5. Abstract:
  6. History:
  7. --*/
  8. #include "precomp.h"
  9. #include <float.h>
  10. #include <textconv.h>
  11. #include <WT_wstring.h>
  12. #include <bstring.h>
  13. #include <wbemidl.h>
  14. #include "WT_converter.h"
  15. char *g_aValidPropTypes[] =
  16. {
  17. "CIM_UINT8",
  18. "CIM_SINT8",
  19. "CIM_SINT16",
  20. "CIM_UINT16",
  21. "CIM_SINT32",
  22. "CIM_UINT32",
  23. "CIM_SINT64",
  24. "CIM_UINT64",
  25. "CIM_STRING",
  26. "CIM_BOOLEAN",
  27. "CIM_REAL32",
  28. "CIM_REAL64",
  29. "CIM_DATETIME",
  30. "CIM_REFERENCE",
  31. "CIM_OBJECT",
  32. "CIM_CHAR16",
  33. "CIM_EMPTY",
  34. };
  35. const int g_nNumValidPropTypes = sizeof(g_aValidPropTypes) / sizeof(char *);
  36. LPWSTR CreateUnicode(LPSTR sz)
  37. {
  38. int len = strlen(sz);
  39. WCHAR* wsz = new WCHAR[len+1];
  40. if (wsz == 0)
  41. return 0;
  42. mbstowcs(wsz, sz, len+1);
  43. wsz[len] = L'\0';
  44. return wsz;
  45. }
  46. LPSTR TypeToString(int nType)
  47. {
  48. static char *pCIM_EMPTY = "CIM_EMPTY";
  49. static char *pCIM_UINT8 = "CIM_UINT8";
  50. static char *pCIM_SINT8 = "CIM_SINT8";
  51. static char *pCIM_SINT16 = "CIM_SINT16";
  52. static char *pCIM_UINT16 = "CIM_UINT16";
  53. static char *pCIM_SINT32 = "CIM_SINT32";
  54. static char *pCIM_UINT32 = "CIM_UINT32";
  55. static char *pCIM_SINT64 = "CIM_SINT64";
  56. static char *pCIM_UINT64 = "CIM_UINT64";
  57. static char *pCIM_REAL32 = "CIM_REAL32";
  58. static char *pCIM_REAL64 = "CIM_REAL64";
  59. static char *pCIM_BOOLEAN = "CIM_BOOLEAN";
  60. static char *pCIM_STRING = "CIM_STRING";
  61. static char *pCIM_DATETIME = "CIM_DATETIME";
  62. static char *pCIM_REFERENCE = "CIM_REFERENCE";
  63. static char *pCIM_OBJECT = "CIM_OBJECT";
  64. static char *pCIM_CHAR16 = "CIM_CHAR16";
  65. static char *pCIM_UINT8_ARRAY = "CIM_UINT8 | CIM_FLAG_ARRAY";
  66. static char *pCIM_SINT8_ARRAY = "CIM_SINT8 | CIM_FLAG_ARRAY";
  67. static char *pCIM_SINT16_ARRAY = "CIM_SINT16 | CIM_FLAG_ARRAY";
  68. static char *pCIM_UINT16_ARRAY = "CIM_UINT16 | CIM_FLAG_ARRAY";
  69. static char *pCIM_SINT32_ARRAY = "CIM_SINT32 | CIM_FLAG_ARRAY";
  70. static char *pCIM_UINT32_ARRAY = "CIM_UINT32 | CIM_FLAG_ARRAY";
  71. static char *pCIM_SINT64_ARRAY = "CIM_SINT64 | CIM_FLAG_ARRAY";
  72. static char *pCIM_UINT64_ARRAY = "CIM_UINT64 | CIM_FLAG_ARRAY";
  73. static char *pCIM_REAL32_ARRAY = "CIM_REAL32 | CIM_FLAG_ARRAY";
  74. static char *pCIM_REAL64_ARRAY = "CIM_REAL64 | CIM_FLAG_ARRAY";
  75. static char *pCIM_BOOLEAN_ARRAY = "CIM_BOOLEA | CIM_FLAG_ARRAY";
  76. static char *pCIM_STRING_ARRAY = "CIM_STRING | CIM_FLAG_ARRAY";
  77. static char *pCIM_DATETIME_ARRAY = "CIM_DATETIME | CIM_FLAG_ARRAY";
  78. static char *pCIM_REFERENCE_ARRAY = "CIM_REFERENCE | CIM_FLAG_ARRAY";
  79. static char *pCIM_OBJECT_ARRAY = "CIM_OBJECT | CIM_FLAG_ARRAY";
  80. static char *pCIM_CHAR16_ARRAY = "CIM_CHAR16 | CIM_FLAG_ARRAY";
  81. char *pRetVal = "<unknown>";
  82. switch (nType)
  83. {
  84. case CIM_UINT8: pRetVal = pCIM_UINT8; break;
  85. case CIM_SINT16: pRetVal = pCIM_SINT16; break;
  86. case CIM_SINT32: pRetVal = pCIM_SINT32; break;
  87. case CIM_SINT8: pRetVal = pCIM_SINT8; break;
  88. case CIM_UINT16: pRetVal = pCIM_UINT16; break;
  89. case CIM_UINT32: pRetVal = pCIM_UINT32; break;
  90. case CIM_UINT64: pRetVal = pCIM_UINT64; break;
  91. case CIM_SINT64: pRetVal = pCIM_SINT64; break;
  92. case CIM_REAL32: pRetVal = pCIM_REAL32; break;
  93. case CIM_REAL64: pRetVal = pCIM_REAL64; break;
  94. case CIM_BOOLEAN: pRetVal = pCIM_BOOLEAN; break;
  95. case CIM_STRING: pRetVal = pCIM_STRING; break;
  96. case CIM_DATETIME: pRetVal = pCIM_DATETIME; break;
  97. case CIM_REFERENCE: pRetVal = pCIM_REFERENCE; break;
  98. case CIM_OBJECT: pRetVal = pCIM_OBJECT; break;
  99. case CIM_CHAR16: pRetVal = pCIM_CHAR16; break;
  100. case CIM_UINT8|CIM_FLAG_ARRAY: pRetVal = pCIM_UINT8_ARRAY; break;
  101. case CIM_SINT16|CIM_FLAG_ARRAY: pRetVal = pCIM_SINT16_ARRAY; break;
  102. case CIM_SINT32|CIM_FLAG_ARRAY: pRetVal = pCIM_SINT32_ARRAY; break;
  103. case CIM_SINT8|CIM_FLAG_ARRAY: pRetVal = pCIM_SINT8_ARRAY; break;
  104. case CIM_UINT16|CIM_FLAG_ARRAY: pRetVal = pCIM_UINT16_ARRAY; break;
  105. case CIM_UINT32|CIM_FLAG_ARRAY: pRetVal = pCIM_UINT32_ARRAY; break;
  106. case CIM_UINT64|CIM_FLAG_ARRAY: pRetVal = pCIM_UINT64_ARRAY; break;
  107. case CIM_SINT64|CIM_FLAG_ARRAY: pRetVal = pCIM_SINT64_ARRAY; break;
  108. case CIM_REAL32|CIM_FLAG_ARRAY: pRetVal = pCIM_REAL32_ARRAY; break;
  109. case CIM_REAL64|CIM_FLAG_ARRAY: pRetVal = pCIM_REAL64_ARRAY; break;
  110. case CIM_BOOLEAN|CIM_FLAG_ARRAY: pRetVal = pCIM_BOOLEAN_ARRAY; break;
  111. case CIM_STRING|CIM_FLAG_ARRAY: pRetVal = pCIM_STRING_ARRAY; break;
  112. case CIM_DATETIME|CIM_FLAG_ARRAY: pRetVal = pCIM_DATETIME_ARRAY; break;
  113. case CIM_REFERENCE|CIM_FLAG_ARRAY: pRetVal = pCIM_REFERENCE_ARRAY;break;
  114. case CIM_OBJECT|CIM_FLAG_ARRAY: pRetVal = pCIM_OBJECT_ARRAY; break;
  115. case CIM_CHAR16|CIM_FLAG_ARRAY: pRetVal = pCIM_CHAR16_ARRAY; break;
  116. }
  117. return pRetVal;
  118. }
  119. // Returns 0 on error
  120. int StringToType(LPSTR pString)
  121. {
  122. if(pString == NULL)
  123. return 0;
  124. if (_stricmp(pString, "CIM_STRING") == 0)
  125. return CIM_STRING;
  126. if (_stricmp(pString, "CIM_UINT8") == 0)
  127. return CIM_UINT8;
  128. if (_stricmp(pString, "CIM_SINT16") == 0)
  129. return CIM_SINT16;
  130. if (_stricmp(pString, "CIM_SINT32") == 0)
  131. return CIM_SINT32;
  132. if (_stricmp(pString, "CIM_SINT8") == 0)
  133. return CIM_SINT8;
  134. if (_stricmp(pString, "CIM_UINT16") == 0)
  135. return CIM_UINT16;
  136. if (_stricmp(pString, "CIM_UINT32") == 0)
  137. return CIM_UINT32;
  138. if (_stricmp(pString, "CIM_UINT64") == 0)
  139. return CIM_UINT64;
  140. if (_stricmp(pString, "CIM_SINT64") == 0)
  141. return CIM_SINT64;
  142. if (_stricmp(pString, "CIM_BOOLEAN") == 0)
  143. return CIM_BOOLEAN;
  144. if (_stricmp(pString, "CIM_DATETIME") == 0)
  145. return CIM_DATETIME;
  146. if (_stricmp(pString, "CIM_REFERENCE") == 0)
  147. return CIM_REFERENCE;
  148. if (_stricmp(pString, "CIM_REAL32") == 0)
  149. return CIM_REAL32;
  150. if (_stricmp(pString, "CIM_REAL64") == 0)
  151. return CIM_REAL64;
  152. if (_stricmp(pString, "CIM_EMPTY") == 0)
  153. return CIM_EMPTY;
  154. if (_stricmp(pString, "CIM_OBJECT") == 0)
  155. return CIM_OBJECT;
  156. if (_stricmp(pString, "CIM_CHAR16") == 0)
  157. return CIM_CHAR16;
  158. return 0;
  159. }
  160. // The functions does a preliminary check on arrays looking for leading commas,
  161. // multiple commas, and trailing commas
  162. bool PrelimCheck(LPSTR pStr)
  163. {
  164. int iNumCommaSinceLastNum = 3;
  165. for(; *pStr; pStr++)
  166. {
  167. // If not a space or comma, assume we are in a number
  168. if(!isspace(*pStr) && *pStr != ',')
  169. iNumCommaSinceLastNum = 0;
  170. if(*pStr == ',')
  171. {
  172. if(iNumCommaSinceLastNum > 0)
  173. return false;
  174. iNumCommaSinceLastNum++;
  175. }
  176. }
  177. if(iNumCommaSinceLastNum > 0)
  178. return false;
  179. else
  180. return true;
  181. }
  182. CVarVector* GetVT_I8Array(LPSTR pStr)
  183. {
  184. if(!PrelimCheck(pStr))
  185. return NULL;
  186. CVarVector *pVec = new CVarVector(VT_BSTR);
  187. char buf[TEMP_BUF];
  188. int n = 0;
  189. buf[0] = 0;
  190. char* pc = pStr;
  191. while(*pc)
  192. {
  193. if(*pc == ',')
  194. {
  195. buf[n] = 0;
  196. if(n == 0)
  197. {
  198. delete pVec;
  199. return NULL;
  200. }
  201. WString s = buf;
  202. pVec->Add(CVar(VT_BSTR, s));
  203. n = 0;
  204. buf[0] = 0;
  205. }
  206. else if(!isspace(*pc) && *pc != '"')
  207. {
  208. buf[n++] = *pc;
  209. }
  210. pc++;
  211. }
  212. if(n != 0)
  213. {
  214. buf[n] = 0;
  215. WString s = buf;
  216. pVec->Add(CVar(VT_BSTR, s));
  217. n = 0;
  218. }
  219. return pVec;
  220. }
  221. CVarVector* GetVT_BSTRArray(LPSTR pStr)
  222. {
  223. CVarVector *pVec = new CVarVector(VT_BSTR);
  224. char buf[TEMP_BUF];
  225. int n = 0;
  226. BOOL bInString = FALSE;
  227. while (*pStr)
  228. {
  229. if (*pStr == '\"')
  230. {
  231. if (bInString)
  232. {
  233. WString s = buf;
  234. pVec->Add(CVar(VT_BSTR, s));
  235. n = 0;
  236. bInString = FALSE;
  237. pStr++;
  238. }
  239. else {
  240. bInString = TRUE;
  241. pStr++;
  242. n=0;
  243. buf[0] = 0;
  244. }
  245. continue;
  246. }
  247. // Allow for \" escape sequence to include quotes in strings.
  248. // ==========================================================
  249. if (*pStr == '\\' && (*(pStr+1) == '\"' || (*(pStr+1) == '\\'))) {
  250. buf[n] = *(pStr+1);
  251. buf[++n] = 0;
  252. pStr += 2;
  253. continue;
  254. }
  255. if (!bInString)
  256. {
  257. if (isspace(*pStr) || *pStr == ',') {
  258. pStr++;
  259. continue;
  260. }
  261. // Error in array element separators
  262. delete pVec;
  263. return 0;
  264. }
  265. else
  266. {
  267. buf[n] = *pStr++;
  268. buf[++n] = 0;
  269. }
  270. }
  271. if(pVec->Size() < 1)
  272. {
  273. delete pVec;
  274. return 0;
  275. }
  276. return pVec;
  277. }
  278. CVarVector* GetVT_BOOLArray(LPSTR pStr)
  279. {
  280. if(!PrelimCheck(pStr))
  281. return NULL;
  282. CVarVector *pVec = new CVarVector(VT_BOOL);
  283. char buf[TEMP_BUF];
  284. int n = 0;
  285. BOOL bPending = FALSE;
  286. while (*pStr)
  287. {
  288. if (isspace(*pStr))
  289. pStr++;
  290. else if (*pStr == ',')
  291. {
  292. if (_stricmp(buf, "TRUE") == 0 ||
  293. _stricmp(buf, "1") == 0 ||
  294. _stricmp(buf, "-1") == 0)
  295. pVec->Add(CVar((VARIANT_BOOL) -1, VT_BOOL));
  296. else if (_stricmp(buf, "FALSE") == 0 || _stricmp(buf, "0") == 0)
  297. pVec->Add(CVar((VARIANT_BOOL) 0, VT_BOOL));
  298. else
  299. {
  300. delete pVec;
  301. return NULL;
  302. }
  303. pStr++;
  304. bPending = FALSE;
  305. n = 0;
  306. buf[n] = 0;
  307. }
  308. else
  309. {
  310. buf[n] = *pStr++;
  311. buf[++n] = 0;
  312. bPending = TRUE;
  313. }
  314. }
  315. if (bPending)
  316. {
  317. if (_stricmp(buf, "TRUE") == 0 ||
  318. _stricmp(buf, "1") == 0 ||
  319. _stricmp(buf, "-1") == 0)
  320. pVec->Add(CVar((VARIANT_BOOL) -1, VT_BOOL));
  321. else if (_stricmp(buf, "FALSE") == 0 || _stricmp(buf, "0") == 0)
  322. pVec->Add(CVar((VARIANT_BOOL) 0, VT_BOOL));
  323. else
  324. {
  325. delete pVec;
  326. return NULL;
  327. }
  328. }
  329. return pVec;
  330. }
  331. CVarVector* GetVT_I4Array(LPSTR pStr)
  332. {
  333. if(!PrelimCheck(pStr))
  334. return NULL;
  335. CVarVector *pVec = new CVarVector(VT_I4);
  336. char buf[TEMP_BUF];
  337. int n = 0;
  338. BOOL bInNum = FALSE;
  339. while (*pStr)
  340. {
  341. if (isdigit(*pStr) || *pStr == '-')
  342. {
  343. bInNum = TRUE;
  344. buf[n] = *pStr++;
  345. buf[++n] = 0;
  346. continue;
  347. }
  348. else // Non digit
  349. {
  350. if (bInNum)
  351. {
  352. pVec->Add(CVar((LONG) atol(buf)));
  353. n = 0;
  354. bInNum = FALSE;
  355. pStr++;
  356. }
  357. else // A separator or trash
  358. {
  359. if (*pStr == ',' || isspace(*pStr))
  360. pStr++;
  361. else
  362. {
  363. delete pVec;
  364. return 0;
  365. }
  366. }
  367. }
  368. }
  369. if (bInNum)
  370. pVec->Add(CVar((LONG) atol(buf)));
  371. return pVec;
  372. }
  373. CVarVector* GetVT_I2Array(LPSTR pStr)
  374. {
  375. if(!PrelimCheck(pStr))
  376. return NULL;
  377. CVarVector *pVec = new CVarVector(VT_I2);
  378. char buf[TEMP_BUF];
  379. int n = 0;
  380. BOOL bInNum = FALSE;
  381. while (*pStr)
  382. {
  383. if (isdigit(*pStr) || *pStr == '-')
  384. {
  385. bInNum = TRUE;
  386. buf[n] = *pStr++;
  387. buf[++n] = 0;
  388. continue;
  389. }
  390. else // Non digit
  391. {
  392. if (bInNum)
  393. {
  394. pVec->Add(CVar((SHORT) atol(buf)));
  395. n = 0;
  396. bInNum = FALSE;
  397. pStr++;
  398. }
  399. else // A separator or trash
  400. {
  401. if (*pStr == ',' || isspace(*pStr))
  402. pStr++;
  403. else
  404. {
  405. delete pVec;
  406. return 0;
  407. }
  408. }
  409. }
  410. }
  411. if (bInNum)
  412. pVec->Add(CVar((SHORT) atol(buf)));
  413. return pVec;
  414. }
  415. CVarVector* GetVT_UI1Array(LPSTR pStr)
  416. {
  417. if(!PrelimCheck(pStr))
  418. return NULL;
  419. CVarVector *pVec = new CVarVector(VT_UI1);
  420. char buf[TEMP_BUF];
  421. int n = 0;
  422. BOOL bPending = FALSE,
  423. fFailedConvert = FALSE;
  424. while ( !fFailedConvert && *pStr )
  425. {
  426. if (isspace(*pStr))
  427. pStr++;
  428. else if (*pStr == ',')
  429. {
  430. BYTE b = 0;
  431. int nRes = sscanf(buf, "'%c'", &b);
  432. if (nRes == 0)
  433. {
  434. int n2 = 0;
  435. nRes = sscanf(buf, "0x%X", &n2);
  436. if (nRes == 0)
  437. {
  438. nRes = sscanf(buf, "%d", &n2);
  439. // check that n is in the byte range
  440. if ( n2 >= 0 && n2 <= 0xFF )
  441. {
  442. b = (BYTE)n2;
  443. }
  444. else
  445. {
  446. fFailedConvert = TRUE;
  447. }
  448. }
  449. else b = (BYTE)n2;
  450. }
  451. if ( !fFailedConvert )
  452. {
  453. pVec->Add(CVar(b));
  454. pStr++;
  455. bPending = FALSE;
  456. n = 0;
  457. buf[n] = 0;
  458. }
  459. }
  460. else
  461. {
  462. buf[n] = *pStr++;
  463. buf[++n] = 0;
  464. bPending = TRUE;
  465. }
  466. }
  467. if ( !fFailedConvert && bPending )
  468. {
  469. BYTE b = 0;
  470. int nRes = sscanf(buf, "'%c'", &b);
  471. if (nRes == 0)
  472. {
  473. int n2 = 0;
  474. nRes = sscanf(buf, "0x%X", &n2);
  475. if (nRes == 0)
  476. {
  477. nRes = sscanf(buf, "%d", &n2);
  478. // check that n is in the byte range
  479. if ( n2 >= 0 && n2 <= 0xFF )
  480. {
  481. b = (BYTE)n2;
  482. }
  483. else
  484. {
  485. fFailedConvert = TRUE;
  486. }
  487. }
  488. else b = (BYTE)n2;
  489. }
  490. // Don't set the value if the conversion failed
  491. if ( !fFailedConvert )
  492. {
  493. pVec->Add(CVar(b));
  494. }
  495. }
  496. // Check that we didn't fail conversion
  497. if ( fFailedConvert )
  498. {
  499. delete pVec;
  500. pVec = NULL;
  501. }
  502. return pVec;
  503. }
  504. CVarVector* GetVT_R4Array(LPSTR pStr)
  505. {
  506. int iNumConv;
  507. if(!PrelimCheck(pStr))
  508. return NULL;
  509. CVarVector *pVec = new CVarVector(VT_R4);
  510. char buf[TEMP_BUF];
  511. int n = 0;
  512. BOOL bInNum = FALSE;
  513. while (*pStr)
  514. {
  515. if (*pStr != ',' && !isspace(*pStr))
  516. {
  517. bInNum = TRUE;
  518. buf[n] = *pStr++;
  519. buf[++n] = 0;
  520. continue;
  521. }
  522. else // Non digit
  523. {
  524. if (bInNum)
  525. {
  526. double d = 0.0;
  527. iNumConv = sscanf(buf, "%lG", &d);
  528. if (!_finite(d) || iNumConv == 0)
  529. {
  530. delete pVec;
  531. return NULL;
  532. }
  533. pVec->Add(CVar((float) d));
  534. n = 0;
  535. bInNum = FALSE;
  536. pStr++;
  537. }
  538. else // A separator or trash
  539. {
  540. if (*pStr == ',' || isspace(*pStr))
  541. pStr++;
  542. else
  543. {
  544. delete pVec;
  545. return 0;
  546. }
  547. }
  548. }
  549. }
  550. if (bInNum)
  551. {
  552. double d = 0.0;
  553. iNumConv = sscanf(buf, "%lG", &d);
  554. if (!_finite(d) || iNumConv == 0)
  555. {
  556. delete pVec;
  557. return NULL;
  558. }
  559. pVec->Add(CVar(float(d)));
  560. }
  561. return pVec;
  562. }
  563. CVarVector* GetVT_R8Array(LPSTR pStr)
  564. {
  565. int iNumConv;
  566. if(!PrelimCheck(pStr))
  567. return NULL;
  568. CVarVector *pVec = new CVarVector(VT_R8);
  569. char buf[TEMP_BUF];
  570. int n = 0;
  571. BOOL bInNum = FALSE;
  572. while (*pStr)
  573. {
  574. if (*pStr != ',' && !isspace(*pStr))
  575. {
  576. bInNum = TRUE;
  577. buf[n] = *pStr++;
  578. buf[++n] = 0;
  579. continue;
  580. }
  581. else // Non digit
  582. {
  583. if (bInNum)
  584. {
  585. double d = 0.0;
  586. iNumConv = sscanf(buf, "%lG", &d);
  587. if (!_finite(d) || iNumConv == 0)
  588. {
  589. delete pVec;
  590. return NULL;
  591. }
  592. pVec->Add(CVar(d));
  593. n = 0;
  594. bInNum = FALSE;
  595. pStr++;
  596. }
  597. else // A separator or trash
  598. {
  599. if (*pStr == ',' || isspace(*pStr))
  600. pStr++;
  601. else
  602. {
  603. delete pVec;
  604. return 0;
  605. }
  606. }
  607. }
  608. }
  609. if (bInNum)
  610. {
  611. double d = 0.0;
  612. iNumConv = sscanf(buf, "%lG", &d);
  613. if (!_finite(d) || iNumConv ==0)
  614. {
  615. delete pVec;
  616. return NULL;
  617. }
  618. pVec->Add(CVar(d));
  619. }
  620. return pVec;
  621. }
  622. // Allocates a new copy which must be deleted.
  623. CVar* StringToValue(LPSTR pString, int nValType)
  624. {
  625. char g;
  626. CVar *pRet = 0;
  627. if (pString == 0)
  628. return 0;
  629. switch (nValType)
  630. {
  631. case CIM_EMPTY:
  632. pRet = new CVar;
  633. pRet->SetAsNull();
  634. break;
  635. case CIM_CHAR16:
  636. {
  637. long l;
  638. if(sscanf(pString, "%d %c", &l, &g) != 1 && g != '(')
  639. return NULL;
  640. pRet = new CVar;
  641. pRet->SetLong(l);
  642. }
  643. break;
  644. case CIM_UINT8:
  645. case CIM_SINT8:
  646. case CIM_SINT16:
  647. case CIM_UINT16:
  648. case CIM_SINT32:
  649. case CIM_UINT32:
  650. {
  651. pRet = new CVar;
  652. UINT uRetVal = CConverter::Convert(pString, nValType, pRet);
  653. if (ERR_NOERROR != uRetVal)
  654. return NULL;
  655. }
  656. break;
  657. case CIM_REAL32:
  658. {
  659. double d;
  660. if(sscanf(pString, "%lG %c", &d, &g) != 1)
  661. return NULL;
  662. if (!_finite(d))
  663. return NULL;
  664. if ((d > 3.4E+38) || (d < 3.4E-38))
  665. return NULL;
  666. pRet = new CVar;
  667. pRet->SetFloat(float(d));
  668. }
  669. break;
  670. case CIM_REAL64:
  671. {
  672. double d;
  673. if(sscanf(pString, "%lG %c", &d, &g) != 1)
  674. return NULL;
  675. if (!_finite(d))
  676. return NULL;
  677. pRet = new CVar;
  678. pRet->SetDouble(d);
  679. }
  680. break;
  681. case CIM_BOOLEAN:
  682. {
  683. pRet = new CVar;
  684. pRet->SetBool(0); // False by default
  685. if (_stricmp(pString, "TRUE") == 0)
  686. pRet->SetBool(-1);
  687. else if (_stricmp(pString, "FALSE") == 0)
  688. pRet->SetBool(0);
  689. else if (atoi(pString) == 1)
  690. pRet->SetBool(-1);
  691. else if (atoi(pString) == 0)
  692. pRet->SetBool(0);
  693. else
  694. return NULL;
  695. }
  696. break;
  697. case CIM_SINT64:
  698. case CIM_UINT64:
  699. case CIM_STRING:
  700. case CIM_DATETIME:
  701. case CIM_REFERENCE:
  702. {
  703. pRet = new CVar;
  704. wchar_t * wbuf = CreateUnicode(pString);
  705. if (wbuf != 0)
  706. {
  707. CBString bsTemp(wbuf);
  708. pRet->SetBSTR(bsTemp.GetString());
  709. delete wbuf;
  710. }
  711. }
  712. break;
  713. // Array types.
  714. // ============
  715. case CIM_SINT64|CIM_FLAG_ARRAY:
  716. case CIM_UINT64|CIM_FLAG_ARRAY:
  717. {
  718. CVarVector *pVec = GetVT_I8Array(pString);
  719. if (!pVec)
  720. return 0;
  721. pRet = new CVar;
  722. pRet->SetVarVector(pVec, TRUE);
  723. }
  724. break;
  725. case CIM_STRING|CIM_FLAG_ARRAY:
  726. case CIM_DATETIME|CIM_FLAG_ARRAY:
  727. case CIM_REFERENCE|CIM_FLAG_ARRAY:
  728. {
  729. CVarVector *pVec = GetVT_BSTRArray(pString);
  730. if (!pVec)
  731. return 0;
  732. pRet = new CVar;
  733. pRet->SetVarVector(pVec, TRUE);
  734. }
  735. break;
  736. case CIM_BOOLEAN|CIM_FLAG_ARRAY:
  737. {
  738. CVarVector *pVec = GetVT_BOOLArray(pString);
  739. if (!pVec)
  740. return 0;
  741. pRet = new CVar;
  742. pRet->SetVarVector(pVec, TRUE);
  743. }
  744. break;
  745. case CIM_UINT8|CIM_FLAG_ARRAY:
  746. case CIM_SINT8|CIM_FLAG_ARRAY:
  747. case CIM_UINT16|CIM_FLAG_ARRAY:
  748. case CIM_SINT16|CIM_FLAG_ARRAY:
  749. case CIM_UINT32|CIM_FLAG_ARRAY:
  750. case CIM_SINT32|CIM_FLAG_ARRAY:
  751. {
  752. CVarVector *pVec = new CVarVector;
  753. UINT uRes = CConverter::Convert(pString, (nValType & ~CIM_FLAG_ARRAY), pVec);
  754. if (ERR_NOERROR != uRes)
  755. return NULL;
  756. pRet = new CVar;
  757. pRet->SetVarVector(pVec, TRUE);
  758. }break;
  759. case CIM_CHAR16|CIM_FLAG_ARRAY:
  760. {
  761. CVarVector *pVec = GetVT_I2Array(pString);
  762. if (!pVec)
  763. return 0;
  764. pRet = new CVar;
  765. pRet->SetVarVector(pVec, TRUE);
  766. }
  767. break;
  768. case CIM_REAL32|CIM_FLAG_ARRAY:
  769. {
  770. CVarVector *pVec = GetVT_R4Array(pString);
  771. if (!pVec)
  772. return 0;
  773. pRet = new CVar;
  774. pRet->SetVarVector(pVec, TRUE);
  775. }
  776. break;
  777. case CIM_REAL64|CIM_FLAG_ARRAY:
  778. {
  779. CVarVector *pVec = GetVT_R8Array(pString);
  780. if (!pVec)
  781. return 0;
  782. pRet = new CVar;
  783. pRet->SetVarVector(pVec, TRUE);
  784. }
  785. break;
  786. }
  787. return pRet;
  788. }
  789. LPSTR ValueToString(CVar *pValue, int vt)
  790. {
  791. static char buf[LARGE_BUF];
  792. char* sz = ValueToNewString(pValue, vt);
  793. strcpy(buf, sz);
  794. return buf;
  795. }
  796. LPSTR ValueToNewString(CVar *pValue, int vt)
  797. {
  798. WString wsOut;
  799. char buf[LARGE_BUF];
  800. int nType = 0;
  801. if(pValue->GetType() == VT_NULL)
  802. {
  803. nType = CIM_EMPTY;
  804. }
  805. else if(vt != 0)
  806. {
  807. nType = vt;
  808. }
  809. else if (pValue->GetType() == VT_EX_CVARVECTOR)
  810. {
  811. nType = pValue->GetVarVector()->GetType();
  812. nType |= CIM_FLAG_ARRAY;
  813. }
  814. else
  815. {
  816. nType = pValue->GetType();
  817. }
  818. buf[0] = 0;
  819. switch (nType)
  820. {
  821. case CIM_EMPTY:
  822. sprintf(buf, "<null>");
  823. break;
  824. case CIM_OBJECT:
  825. if(pValue->GetEmbeddedObject() != NULL)
  826. sprintf(buf, "<embedded object>");
  827. else
  828. buf[0] = 0;
  829. break;
  830. case CIM_BOOLEAN:
  831. {
  832. VARIANT_BOOL b = pValue->GetBool();
  833. if (!b)
  834. sprintf(buf, "FALSE");
  835. else
  836. sprintf(buf, "TRUE");
  837. }
  838. break;
  839. case CIM_UINT8:
  840. {
  841. BYTE b = pValue->GetByte();
  842. sprintf(buf, "%d", (long)b);
  843. }
  844. break;
  845. case CIM_SINT8:
  846. {
  847. signed char b = (signed char)pValue->GetByte();
  848. sprintf(buf, "%d", (long)b);
  849. }
  850. break;
  851. case CIM_SINT16:
  852. case CIM_CHAR16:
  853. {
  854. SHORT i = pValue->GetShort();
  855. sprintf(buf, "%d (0x%04hx)", i, i);
  856. }
  857. break;
  858. case CIM_UINT16:
  859. {
  860. USHORT i = (USHORT)pValue->GetShort();
  861. sprintf(buf, "%d (0x%X)", (long)i, (long)i);
  862. }
  863. break;
  864. case CIM_SINT32:
  865. {
  866. LONG l = pValue->GetLong();
  867. sprintf(buf, "%d (0x%X)", l, l);
  868. }
  869. break;
  870. case CIM_UINT32:
  871. {
  872. ULONG l = (ULONG)pValue->GetLong();
  873. sprintf(buf, "%lu (0x%X)", l, l);
  874. }
  875. break;
  876. case CIM_REAL32:
  877. {
  878. float f = pValue->GetFloat();
  879. sprintf(buf, "%G", f);
  880. }
  881. break;
  882. case CIM_REAL64:
  883. {
  884. double d = pValue->GetDouble();
  885. sprintf(buf, "%G", d);
  886. }
  887. break;
  888. case CIM_SINT64:
  889. case CIM_UINT64:
  890. case CIM_STRING:
  891. case CIM_DATETIME:
  892. case CIM_REFERENCE:
  893. {
  894. LPWSTR pWStr = pValue->GetLPWSTR();
  895. wsOut += pWStr;
  896. *buf = 0;
  897. }
  898. break;
  899. case CIM_SINT64|CIM_FLAG_ARRAY:
  900. case CIM_UINT64|CIM_FLAG_ARRAY:
  901. case CIM_STRING|CIM_FLAG_ARRAY:
  902. case CIM_DATETIME|CIM_FLAG_ARRAY:
  903. case CIM_REFERENCE|CIM_FLAG_ARRAY:
  904. {
  905. CVarVector *pVec = pValue->GetVarVector();
  906. BOOL bFirst = TRUE;
  907. for (int i = 0; i < pVec->Size(); i++)
  908. {
  909. if (!bFirst)
  910. wsOut += L",";
  911. CVar v;
  912. pVec->FillCVarAt( i, v );
  913. LPWSTR pTmp = v.GetLPWSTR();
  914. wsOut += L"\"";
  915. LPWSTR pTmp2 = new WCHAR[ lstrlenW(pTmp)+1000 ];
  916. int nIdx = 0;
  917. // Add '\' before any "'s or '\'s
  918. // ==============================
  919. while(*pTmp) {
  920. if(*pTmp == '\"' || *pTmp == '\\') {
  921. pTmp2[nIdx++] = '\\';
  922. }
  923. pTmp2[nIdx++] = *pTmp++;
  924. }
  925. pTmp2[nIdx] = 0;
  926. wsOut += pTmp2;
  927. wsOut += L"\"";
  928. bFirst = FALSE;
  929. delete[] pTmp2;
  930. }
  931. *buf = 0;
  932. }
  933. break;
  934. case CIM_UINT8|CIM_FLAG_ARRAY:
  935. {
  936. CVarVector *pVec = pValue->GetVarVector();
  937. BOOL bFirst = TRUE;
  938. for (int i = 0; i < pVec->Size(); i++)
  939. {
  940. if (!bFirst)
  941. wsOut += L",";
  942. CVar v;
  943. pVec->FillCVarAt( i, v );
  944. BYTE b = v.GetByte();
  945. wchar_t buf2[128];
  946. swprintf(buf2, L"%d", (long)b);
  947. wsOut += buf2;
  948. bFirst = FALSE;
  949. }
  950. *buf = 0;
  951. }
  952. break;
  953. case CIM_SINT8|CIM_FLAG_ARRAY:
  954. {
  955. CVarVector *pVec = pValue->GetVarVector();
  956. BOOL bFirst = TRUE;
  957. for (int i = 0; i < pVec->Size(); i++)
  958. {
  959. if (!bFirst)
  960. wsOut += L",";
  961. CVar v;
  962. pVec->FillCVarAt( i, v );
  963. signed char b = (signed char)v.GetByte();
  964. wchar_t buf2[128];
  965. swprintf(buf2, L"%d", (long)b);
  966. wsOut += buf2;
  967. bFirst = FALSE;
  968. }
  969. *buf = 0;
  970. }
  971. break;
  972. case CIM_BOOLEAN|CIM_FLAG_ARRAY:
  973. {
  974. CVarVector *pVec = pValue->GetVarVector();
  975. BOOL bFirst = TRUE;
  976. for (int i = 0; i < pVec->Size(); i++)
  977. {
  978. if (!bFirst)
  979. wsOut += L",";
  980. CVar v;
  981. pVec->FillCVarAt( i, v );
  982. VARIANT_BOOL b = v.GetBool();
  983. if (b)
  984. wsOut += L"TRUE";
  985. else
  986. wsOut += L"FALSE";
  987. bFirst = FALSE;
  988. }
  989. *buf = 0;
  990. }
  991. break;
  992. case CIM_SINT16|CIM_FLAG_ARRAY:
  993. case CIM_CHAR16|CIM_FLAG_ARRAY:
  994. {
  995. CVarVector *pVec = pValue->GetVarVector();
  996. BOOL bFirst = TRUE;
  997. for (int i = 0; i < pVec->Size(); i++)
  998. {
  999. if (!bFirst)
  1000. wsOut += L",";
  1001. CVar v;
  1002. pVec->FillCVarAt( i, v );
  1003. SHORT Tmp = v.GetShort();
  1004. wchar_t buf2[128];
  1005. swprintf(buf2, L"%ld", (long)Tmp);
  1006. wsOut += buf2;
  1007. bFirst = FALSE;
  1008. }
  1009. *buf = 0;
  1010. }
  1011. break;
  1012. case CIM_UINT16|CIM_FLAG_ARRAY:
  1013. {
  1014. CVarVector *pVec = pValue->GetVarVector();
  1015. BOOL bFirst = TRUE;
  1016. for (int i = 0; i < pVec->Size(); i++)
  1017. {
  1018. if (!bFirst)
  1019. wsOut += L",";
  1020. CVar v;
  1021. pVec->FillCVarAt( i, v );
  1022. USHORT Tmp = (USHORT)v.GetShort();
  1023. wchar_t buf2[128];
  1024. swprintf(buf2, L"%ld", (long)Tmp);
  1025. wsOut += buf2;
  1026. bFirst = FALSE;
  1027. }
  1028. *buf = 0;
  1029. }
  1030. break;
  1031. case CIM_SINT32|CIM_FLAG_ARRAY:
  1032. {
  1033. CVarVector *pVec = pValue->GetVarVector();
  1034. BOOL bFirst = TRUE;
  1035. for (int i = 0; i < pVec->Size(); i++)
  1036. {
  1037. if (!bFirst)
  1038. wsOut += L",";
  1039. CVar v;
  1040. pVec->FillCVarAt( i, v );
  1041. LONG Tmp = v.GetLong();
  1042. wchar_t buf2[128];
  1043. swprintf(buf2, L"%d", Tmp);
  1044. wsOut += buf2;
  1045. bFirst = FALSE;
  1046. }
  1047. *buf = 0;
  1048. }
  1049. break;
  1050. case CIM_UINT32|CIM_FLAG_ARRAY:
  1051. {
  1052. CVarVector *pVec = pValue->GetVarVector();
  1053. BOOL bFirst = TRUE;
  1054. for (int i = 0; i < pVec->Size(); i++)
  1055. {
  1056. if (!bFirst)
  1057. wsOut += L",";
  1058. CVar v;
  1059. pVec->FillCVarAt( i, v );
  1060. ULONG Tmp = (ULONG)v.GetLong();
  1061. wchar_t buf2[128];
  1062. swprintf(buf2, L"%lu", Tmp);
  1063. wsOut += buf2;
  1064. bFirst = FALSE;
  1065. }
  1066. *buf = 0;
  1067. }
  1068. break;
  1069. case CIM_REAL32|CIM_FLAG_ARRAY:
  1070. {
  1071. CVarVector *pVec = pValue->GetVarVector();
  1072. BOOL bFirst = TRUE;
  1073. for (int i = 0; i < pVec->Size(); i++)
  1074. {
  1075. if (!bFirst)
  1076. wsOut += L",";
  1077. CVar v;
  1078. pVec->FillCVarAt( i, v );
  1079. double d = v.GetFloat();
  1080. wchar_t buf2[128];
  1081. swprintf(buf2, L"%G", d);
  1082. wsOut += buf2;
  1083. bFirst = FALSE;
  1084. }
  1085. *buf = 0;
  1086. }
  1087. break;
  1088. case CIM_REAL64|CIM_FLAG_ARRAY:
  1089. {
  1090. CVarVector *pVec = pValue->GetVarVector();
  1091. BOOL bFirst = TRUE;
  1092. for (int i = 0; i < pVec->Size(); i++)
  1093. {
  1094. if (!bFirst)
  1095. wsOut += L",";
  1096. CVar v;
  1097. pVec->FillCVarAt( i, v );
  1098. double d = v.GetDouble();
  1099. wchar_t buf2[128];
  1100. swprintf(buf2, L"%G", d);
  1101. wsOut += buf2;
  1102. bFirst = FALSE;
  1103. }
  1104. *buf = 0;
  1105. }
  1106. break;
  1107. case CIM_OBJECT|CIM_FLAG_ARRAY:
  1108. if(pValue->GetVarVector() != NULL)
  1109. sprintf(buf, "<array of embedded objects>");
  1110. else
  1111. buf[0] = 0;
  1112. break;
  1113. default:
  1114. sprintf(buf, "<error>");
  1115. }
  1116. wsOut += WString(buf);
  1117. return wsOut.GetLPSTR();
  1118. }
  1119. void StripTrailingWs(LPSTR pVal)
  1120. {
  1121. if (!pVal || strlen(pVal) == 0)
  1122. return;
  1123. for (int i = strlen(pVal) - 1; i >= 0; i--)
  1124. if (isspace(pVal[i])) pVal[i] = 0;
  1125. else break;
  1126. }
  1127. void StripTrailingWs(LPWSTR pVal)
  1128. {
  1129. if (!pVal || wcslen(pVal) == 0)
  1130. return;
  1131. for (int i = wcslen(pVal) - 1; i >= 0; i--)
  1132. if (iswspace(pVal[i])) pVal[i] = 0;
  1133. else break;
  1134. }