//*************************************************************************** // // Copyright (c) 1997-2002 Microsoft Corporation, All Rights Reserved // //*************************************************************************** #include "precomp.h" #include "wmicom.h" #include "wmimap.h" #include #include /* These are the types we support CIM_SINT8 = 16, CIM_UINT8 = 17, CIM_SINT16 = 2, CIM_UINT16 = 18, CIM_SINT32 = 3, CIM_UINT32 = 19, CIM_SINT64 = 20, CIM_UINT64 = 21, CIM_REAL32 = 4, CIM_REAL64 = 5, CIM_BOOLEAN = 11, CIM_STRING = 8, CIM_DATETIME = 101, CIM_REFERENCE = 102, CIM_CHAR16 = 103, CIM_OBJECT = 13, CIM_FLAG_ARRAY = 0x2000 */ BOOL ValidateDateTime(WCHAR * wcsValue) { BOOL fRc = FALSE; // Pre-test // ======== WCHAR * psz = wcsValue; if( psz ) { if(wcslen(psz) == 25){ if(psz[14] != L'.' && psz[14] != L'*'){ goto ExitValidateTime; } if(psz[21] != L':' && psz[21] != L'-' && psz[21] != L'+' && psz[21] != L'*'){ goto ExitValidateTime; } for(int i = 0; i < 25; i++){ if(i == 21 || i == 14) continue; if(psz[i] != L'*' && !wbem_iswdigit(psz[i])){ goto ExitValidateTime; } } // Passed pre-test. Check if any stars were specified // ================================================== if(wcschr(psz, L'*')) { // No further checking fRc = TRUE; goto ExitValidateTime; } if(psz[21] == L':'){ // Interval -- no checking fRc = TRUE; goto ExitValidateTime; } WCHAR wcsTmp[SIZEOFWBEMDATETIME+2]; StringCchCopyW(wcsTmp,SIZEOFWBEMDATETIME+2,wcsValue); CWbemTime Time; fRc = Time.SetDMTF(wcsTmp); } } ExitValidateTime: return fRc; } //============================================================= BOOL CWMIDataTypeMap::ConvertDWORDToWMIDataTypeAndWriteItToBlock(DWORD dwLong, int nSize ) { BOOL fRc = FALSE; if( NaturallyAlignData( nSize, WRITE_IT)){ if( nSize == sizeof(BYTE) ){ m_pWMIBlockInfo->SetByte((BYTE)dwLong); } else if( nSize == sizeof(short)){ m_pWMIBlockInfo->SetWord((WORD)dwLong); } else{ m_pWMIBlockInfo->SetDWORD(dwLong); } fRc = TRUE; } return fRc; } //============================================================= DWORD CWMIDataTypeMap::ConvertWMIDataTypeToDWORD(int nSize) { DWORD dwLong = 0L; if( nSize == sizeof(BYTE) ){ BYTE bByte; m_pWMIBlockInfo->GetByte(bByte); dwLong = (DWORD) bByte; } else if( nSize == sizeof(short)){ WORD nInt; m_pWMIBlockInfo->GetWord(nInt); dwLong = (DWORD) nInt; } else{ m_pWMIBlockInfo->GetDWORD(dwLong); } return dwLong; } //============================================================= BOOL CWMIDataTypeMap::SetDefaultMissingQualifierValue( CVARIANT & v, long lType, CVARIANT & vToSet ) { BOOL fRc = TRUE; switch (lType){ // CIM_SINT16 = 2, // CIM_CHAR16 case CIM_CHAR16: break; // CIM_SINT8 = 16, case VT_I1: case VT_I2: vToSet.Clear(); vToSet.SetShort(v.GetShort()); break; // CIM_SINT32 = 3, // CIM_UINT32 = 19, // CIM_UINT16 = 18, case VT_UI2: case VT_I4: case VT_UI4: vToSet.Clear(); vToSet.SetLONG(v.GetLONG()); break; // CIM_REAL32 = 4, case VT_R4: case VT_R8: vToSet.Clear(); vToSet.SetDouble(v.GetDouble()); break; // CIM_SINT64 = 20, // CIM_UINT64 = 21, case VT_I8: case VT_UI8: vToSet.Clear(); vToSet.SetStr(v.GetStr()); break; // CIM_DATETIME = 101, case CIM_DATETIME: break; // CIM_STRING = 8, // CIM_REFERENCE = 102, // CIM_OBJECT = 13, // CIM_FLAG_ARRAY = 0x2000 case VT_BSTR: break; // CIM_BOOLEAN = 11, case VT_BOOL: vToSet.Clear(); vToSet.SetBool(v.GetBool()); break; // CIM_UINT8 = 17, case VT_UI1: vToSet.Clear(); vToSet.SetByte(v.GetByte()); break; default: fRc = FALSE; } return fRc; } //============================================================= BOOL CWMIDataTypeMap::MissingQualifierValueMatches( CSAFEARRAY * pSafe, long i, CVARIANT & v, long lType, CVARIANT & vToCompare ) { BOOL fRc = FALSE; switch (lType){ // CIM_SINT16 = 2, // CIM_CHAR16 case CIM_CHAR16: break; // CIM_SINT8 = 16, case VT_I1: case VT_I2: { short v1 = 0; if( pSafe ) { if( S_OK != pSafe->Get(i, &v1)) { return FALSE; } } else { v1 = (short) v.GetShort(); } short v2 = (short)vToCompare.GetShort(); if( v1 == v2){ fRc = TRUE; } break; } // CIM_SINT32 = 3, // CIM_UINT32 = 19, // CIM_UINT16 = 18, case VT_UI2: case VT_I4: case VT_UI4: { long v1 = 0; if( pSafe ) { if( S_OK != pSafe->Get(i, &v1)) { return FALSE; } } else { v1 = (long)v.GetLONG(); } long v2 = (long)vToCompare.GetLONG(); if( v1 == v2){ fRc = TRUE; } break; } // CIM_REAL32 = 4, case VT_R4: case VT_R8: { double v1 = 0; if( pSafe ) { if( S_OK != pSafe->Get(i, &v1)) { return FALSE; } } else { v1 = (double)v.GetDouble(); } double v2 = (double)vToCompare.GetDouble(); if( v1 == v2 ){ fRc = TRUE; } break; } // CIM_SINT64 = 20, // CIM_UINT64 = 21, case VT_UI8: { unsigned __int64 I1 = 0L, I2 = 0L; CBSTR bstr2; CBSTR bstr1; if( pSafe ) { if( S_OK != pSafe->Get(i, &bstr1)) { return FALSE; } } else { bstr1.SetStr(v.GetStr()); } bstr2.SetStr(vToCompare.GetStr()); if( bstr1 && bstr2) { I1 =(unsigned __int64) _wtoi64(bstr1); I2 =(unsigned __int64)_wtoi64(bstr2); if( I1 == I2 ){ fRc = TRUE; } } break; } case VT_I8: { __int64 I1 = 0L, I2 = 0L; CBSTR bstr2; CBSTR bstr1; if( pSafe ) { if( S_OK != pSafe->Get(i, &bstr1)) { return FALSE; } } else { bstr1.SetStr(v.GetStr()); } bstr2.SetStr(vToCompare.GetStr()); if( bstr1 && bstr2) { I1 = _wtoi64(bstr1); I2 = _wtoi64(bstr2); if( I1 == I2 ){ fRc = TRUE; } } break; } // CIM_DATETIME = 101, case CIM_DATETIME: break; // CIM_STRING = 8, // CIM_REFERENCE = 102, // CIM_OBJECT = 13, // CIM_FLAG_ARRAY = 0x2000 case VT_BSTR: break; // CIM_BOOLEAN = 11, case VT_BOOL: { BOOL v1 = 0; if( pSafe ) { if( S_OK != pSafe->Get(i, &v1)) { return FALSE; } } else { v1 = (BOOL)v.GetBool(); } BOOL v2 = (BOOL)vToCompare.GetBool(); if( v1 == v2 ) { fRc = TRUE; } break; } // CIM_UINT8 = 17, case VT_UI1: { BYTE v1 = 0; if( pSafe ) { if( S_OK != pSafe->Get(i, &v1)) { return FALSE; } } else { v1 = (BYTE) v.GetByte(); } BYTE v2 = (BYTE)vToCompare.GetByte(); if( v1 == v2){ fRc = TRUE; } break; } default: fRc = FALSE; } return fRc; } //============================================================= DWORD CWMIDataTypeMap::ArraySize(long lType,CVARIANT & var) { DWORD dwCount = 0; switch( lType ){ case VT_I2: case VT_UI2: dwCount = (DWORD) var.GetShort(); break; case VT_I4: case VT_UI4: case VT_R4: dwCount = (DWORD) var.GetLONG(); break; case VT_UI1: case VT_I1: dwCount = (DWORD) var.GetByte(); break; } return dwCount; } //============================================================= BOOL CWMIDataTypeMap::SetDataInDataBlock(CSAFEARRAY * pSafe, int i, CVARIANT & v, long lType, int nSize) { BOOL fRc = TRUE; switch (lType){ // CIM_SINT16 = 2, // CIM_CHAR16 case CIM_CHAR16: case VT_I2: { SHORT iShort; if( pSafe ){ if( S_OK != pSafe->Get(i, &iShort)){ return FALSE; } } else{ iShort = v.GetShort(); } if( NaturallyAlignData( sizeof(WORD), WRITE_IT)){ m_pWMIBlockInfo->SetWord(iShort); } break; } // CIM_SINT32 = 3, // CIM_UINT32 = 19, // CIM_UINT16 = 18, case VT_UI2: case VT_I4: case VT_UI4: { DWORD dwLong = 0L; if( pSafe ){ if( S_OK != pSafe->Get(i, &dwLong)){ return FALSE; } } else{ dwLong = v.GetLONG(); } ConvertDWORDToWMIDataTypeAndWriteItToBlock(dwLong,nSize); break; } // CIM_REAL32 = 4, case VT_R4: { float fFloat; if( pSafe ){ if( S_OK != pSafe->Get(i, &fFloat)){ return FALSE; } } else{ fFloat =(float) v.GetDouble(); } if( NaturallyAlignData( sizeof(WORD), WRITE_IT )){ m_pWMIBlockInfo->SetFloat(fFloat); } break; } // CIM_REAL64 = 5, case VT_R8: { DOUBLE dDouble; if( pSafe ){ if( S_OK != pSafe->Get(i, &dDouble)){ return FALSE; } } else{ dDouble = v.GetDouble(); } if( NaturallyAlignData( sizeof(DOUBLE),WRITE_IT)){ m_pWMIBlockInfo->SetDouble(dDouble); } break; } // CIM_SINT64 = 20, case VT_I8: { __int64 Int64 = 0L; CBSTR bstr; if( pSafe ) { if( S_OK != pSafe->Get(i, &bstr)) { return FALSE; } } else { bstr.SetStr(v.GetStr()); } if( bstr ) { Int64 = _wtoi64(bstr); } if( NaturallyAlignData( sizeof(__int64), WRITE_IT )) { m_pWMIBlockInfo->SetSInt64(Int64); } break; } // CIM_UINT64 = 21, case VT_UI8: { unsigned __int64 Int64 = 0L; CBSTR bstr; if( pSafe ) { if( S_OK != pSafe->Get(i, &bstr)) { return FALSE; } } else { bstr.SetStr(v.GetStr()); } if( bstr ) { Int64 = (unsigned __int64) _wtoi64(bstr); } if( NaturallyAlignData( sizeof(unsigned __int64),WRITE_IT)) { m_pWMIBlockInfo->SetUInt64(Int64); } break; } // CIM_DATETIME = 101, case CIM_DATETIME: { WORD wCount=0; CBSTR bstr; WCHAR wDateTime[SIZEOFWBEMDATETIME+2]; memset( wDateTime,NULL,SIZEOFWBEMDATETIME+2 ); BOOL fContinue = TRUE; if( pSafe ) { if( S_OK != pSafe->Get(i, &bstr)) { return FALSE; } } else { bstr.SetStr(v.GetStr()); } //========================================================= // Initialize buffer //========================================================= if( bstr != NULL ) { if( ValidateDateTime(bstr)) { StringCchCopyW(wDateTime, SIZEOFWBEMDATETIME+2, bstr); } else { fContinue = FALSE; } } else { StringCchCopyW(wDateTime, SIZEOFWBEMDATETIME+2, L"00000000000000.000000:000"); } if( fContinue ) { if( NaturallyAlignData( SIZEOFWBEMDATETIME, WRITE_IT)) { m_pWMIBlockInfo->SetString(wDateTime,SIZEOFWBEMDATETIME); } } else { return FALSE ; } break; } // CIM_STRING = 8, // CIM_REFERENCE = 102, // CIM_OBJECT = 13, // CIM_FLAG_ARRAY = 0x2000 case VT_BSTR: { WORD wCount=0; CBSTR bstr; if( pSafe ) { if( S_OK != pSafe->Get(i, &bstr)) { return FALSE; } } else { bstr.SetStr(v.GetStr()); } if( bstr != NULL ) { wCount = (wcslen(bstr))* sizeof(WCHAR); } if( NaturallyAlignData( sizeof ( WORD ), WRITE_IT ) ) { m_pWMIBlockInfo->SetWord(wCount); } if( bstr ) { if( S_OK != m_pWMIBlockInfo->GetBufferReady ( wCount ) ) { return FALSE; } m_pWMIBlockInfo->SetString(bstr,wCount); *m_pdwAccumulativeSizeOfBlock += wCount; } break; } // CIM_BOOLEAN = 11, case VT_BOOL: { BYTE bByte; if( pSafe ){ BOOL bTmp; if( S_OK != pSafe->Get(i, &bTmp)){ return FALSE; } bByte = (BYTE) bTmp; } else{ bByte =(BYTE) v.GetBool(); } if( NaturallyAlignData( sizeof(BYTE), WRITE_IT )){ m_pWMIBlockInfo->SetByte(bByte); } break; } // CIM_UINT8 = 17, case VT_UI1: { BYTE bByte; if( pSafe ){ if( S_OK != pSafe->Get(i, &bByte)){ return FALSE; } } else{ bByte = v.GetByte(); } if( NaturallyAlignData( 1, WRITE_IT )){ m_pWMIBlockInfo->SetByte(bByte); } break; } // CIM_SINT8 = 16, case VT_I1: { short tmpShort; if( pSafe ){ if( S_OK != pSafe->Get(i, &tmpShort)){ return FALSE; } } else{ tmpShort = v.GetShort(); } if( NaturallyAlignData( 1, WRITE_IT )){ BYTE bByte = (signed char)tmpShort; m_pWMIBlockInfo->SetByte(bByte); } break; } default: fRc = FALSE; } return fRc; } /////////////////////////////////////////////////////////////////////////////////////////////////////////////// HRESULT CWMIDataTypeMap::GetDataFromDataBlock(IWbemObjectAccess * p, long lHandle, long lType, int nSize) { HRESULT hr = S_OK; switch (lType){ // CIM_SINT32 = 3, // CIM_UINT32 = 19, case VT_I4: case VT_UI4: if( NaturallyAlignData( nSize, READ_IT )){ hr = p->WriteDWORD(lHandle,ConvertWMIDataTypeToDWORD(nSize)); } break; case VT_I8: case VT_UI8: if( NaturallyAlignData( nSize, READ_IT )) { unsigned __int64 uInt64; m_pWMIBlockInfo->GetQWORD(uInt64); hr = p->WriteQWORD(lHandle,uInt64); } break; // CIM_UINT16 = 18, // CIM_SINT16 = 2, // CIM_CHAR16 = 103, case VT_I2: case VT_UI2: case CIM_CHAR16: if( NaturallyAlignData( nSize, READ_IT )){ WORD wWord; m_pWMIBlockInfo->GetWord(wWord); // Read but don't assign to anything } break; // CIM_REAL32 = 4, case VT_R4: if( NaturallyAlignData( nSize, READ_IT)){ float fFloat; m_pWMIBlockInfo->GetFloat(fFloat); // Read but don't assign to anything } break; // CIM_REAL64 = 5, case VT_R8: if( NaturallyAlignData( nSize, READ_IT )){ DOUBLE dDouble; m_pWMIBlockInfo->GetDouble(dDouble); // Read but don't assign to anything } break; // CIM_DATETIME = 101, which is 25 WCHARS case CIM_DATETIME: if( NaturallyAlignData( SIZEOFWBEMDATETIME, READ_IT )) { WORD wSize = SIZEOFWBEMDATETIME + 2 ; WCHAR Buffer[SIZEOFWBEMDATETIME + 2] ; m_pWMIBlockInfo->GetString(Buffer,SIZEOFWBEMDATETIME,wSize); // Read but don't assign to anything } break; // CIM_REFERENCE = 102, // CIM_STRING = 8, case VT_BSTR: if( NaturallyAlignData( 2, READ_IT )){ WORD wCount=0; WCHAR * pBuffer=NULL; // Get the size of the string m_pWMIBlockInfo->GetWord(wCount); if( wCount > 0 ) { if( m_pWMIBlockInfo->CurrentPtrOk((ULONG)(wCount)) ) { WORD wSize = wCount + 2; pBuffer = new WCHAR[wSize]; if( pBuffer ) { try { m_pWMIBlockInfo->GetString(pBuffer,wCount,wSize); // Read but don't assign to anything SAFE_DELETE_ARRAY(pBuffer); *m_pdwAccumulativeSizeOfBlock += wCount; } catch(...) { hr = WBEM_E_UNEXPECTED; SAFE_DELETE_ARRAY(pBuffer); throw; } } } else { hr = WBEM_E_INVALID_OBJECT; } } } break; // CIM_BOOLEAN = 11, case VT_BOOL: if( NaturallyAlignData( nSize, READ_IT )){ BYTE bByte=0; m_pWMIBlockInfo->GetByte(bByte); // Read but don't assign to anything } break; // CIM_SINT8 = 16, // CIM_UINT8 = 17, case VT_UI1: case VT_I1: if( NaturallyAlignData( nSize, READ_IT )){ BYTE bByte=0; m_pWMIBlockInfo->GetByte(bByte); // Read but don't assign to anything } break; default: return WBEM_E_INVALID_OBJECT; } return hr; } /////////////////////////////////////////////////////////////////////////////////////////////////////////////// HRESULT CWMIDataTypeMap::GetDataFromDataBlock(CVARIANT & v, long lType, int nSize ) { HRESULT hr = WBEM_E_INVALID_OBJECT; switch (lType){ // CIM_SINT16 = 2, // CIM_CHAR16 = 103, case VT_I2: case CIM_CHAR16: if( NaturallyAlignData( nSize, READ_IT )){ hr = WBEM_S_NO_ERROR; WORD wWord; m_pWMIBlockInfo->GetWord(wWord); v.SetShort(wWord); } break; // CIM_SINT32 = 3, // CIM_UINT16 = 18, // CIM_UINT32 = 19, case VT_I4: case VT_UI2: case VT_UI4: if( NaturallyAlignData( nSize, READ_IT )){ hr = WBEM_S_NO_ERROR; v.SetLONG(ConvertWMIDataTypeToDWORD(nSize)); } break; // CIM_REAL32 = 4, case VT_R4: if( NaturallyAlignData( nSize, READ_IT)){ hr = WBEM_S_NO_ERROR; float fFloat; m_pWMIBlockInfo->GetFloat(fFloat); v.SetDouble(fFloat); } break; // CIM_REAL64 = 5, case VT_R8: if( NaturallyAlignData( nSize, READ_IT )){ hr = WBEM_S_NO_ERROR; DOUBLE dDouble; m_pWMIBlockInfo->GetDouble(dDouble); v.SetDouble(dDouble); } break; // CIM_SINT64 = 20, case VT_I8: if( NaturallyAlignData( nSize, READ_IT )){ hr = WBEM_S_NO_ERROR; WCHAR pwcsBuffer[256]; memset(pwcsBuffer,NULL,256); if ( SUCCEEDED ( hr = m_pWMIBlockInfo->GetSInt64 ( pwcsBuffer, 256 ) ) ) { v.SetStr(pwcsBuffer); } } break; // CIM_UINT64 = 21, case VT_UI8: if( NaturallyAlignData( nSize, READ_IT )){ hr = WBEM_S_NO_ERROR; WCHAR pwcsBuffer[256]; memset(pwcsBuffer,NULL,256); if ( SUCCEEDED ( hr = m_pWMIBlockInfo->GetUInt64 ( pwcsBuffer, 256 ) ) ) { v.SetStr(pwcsBuffer); } } break; // CIM_DATETIME = 101, which is 25 WCHARS case CIM_DATETIME: v.SetStr(NULL); if( NaturallyAlignData( SIZEOFWBEMDATETIME, READ_IT )) { hr = WBEM_S_NO_ERROR; WORD wSize = SIZEOFWBEMDATETIME + 2 ; WCHAR Buffer[SIZEOFWBEMDATETIME + 2] ; m_pWMIBlockInfo->GetString(Buffer,SIZEOFWBEMDATETIME,wSize); if( wbem_wcsicmp(Buffer,L"00000000000000.000000:000") != 0 ){ v.SetStr(Buffer); } } break; // CIM_REFERENCE = 102, // CIM_STRING = 8, case VT_BSTR: v.SetStr(NULL); if( NaturallyAlignData( 2, READ_IT )){ WORD wCount=0; WCHAR * pBuffer=NULL; // Get the size of the string m_pWMIBlockInfo->GetWord(wCount); hr = WBEM_S_NO_ERROR; if( wCount > 0 ){ if( m_pWMIBlockInfo->CurrentPtrOk((ULONG)(wCount)) ){ WORD wSize = wCount + 2; pBuffer = new WCHAR[wSize]; if( pBuffer ) { try { m_pWMIBlockInfo->GetString(pBuffer,wCount,wSize); v.SetStr(pBuffer); SAFE_DELETE_ARRAY(pBuffer); *m_pdwAccumulativeSizeOfBlock += wCount; } catch(...) { hr = WBEM_E_UNEXPECTED; SAFE_DELETE_ARRAY(pBuffer); throw; } } } else{ hr = WBEM_E_INVALID_OBJECT; } } else{ v.SetStr(NULL); } } break; // CIM_BOOLEAN = 11, case VT_BOOL: if( NaturallyAlignData( nSize, READ_IT )){ hr = WBEM_S_NO_ERROR; BYTE bByte=0; m_pWMIBlockInfo->GetByte(bByte); v.SetBool((BOOL)bByte); } break; // CIM_SINT8 = 16, // CIM_UINT8 = 17, case VT_UI1: case VT_I1: if( NaturallyAlignData( nSize, READ_IT )){ hr = WBEM_S_NO_ERROR; BYTE bByte=0; m_pWMIBlockInfo->GetByte(bByte); if( lType == VT_I1 ){ v.SetShort((signed char)bByte); } else{ v.SetByte(bByte); } } break; default: return WBEM_E_INVALID_OBJECT; } return hr; } ////////////////////////////////////////////////////////////////////// int CWMIDataTypeMap::GetWMISize(long lType) { int nWMISize = 0; switch(lType){ // CIM_SINT8 = 16, // CIM_UINT8 = 17, case VT_I1: case VT_UI1: nWMISize = sizeof(BYTE); break; // CIM_SINT16 = 2, // CIM_UINT16 = 18, case VT_I2: case CIM_CHAR16: case VT_UI2: nWMISize = sizeof(short); break; // CIM_SINT32 = 3, // CIM_UINT32 = 19, case VT_I4: case VT_UI4: nWMISize = sizeof(DWORD); break; // CIM_SINT64 = 20, // CIM_UINT64 = 21, case VT_I8: case VT_UI8: nWMISize = sizeof(__int64); break; // CIM_REAL32 = 4, case VT_R4: nWMISize = sizeof(float); break; // CIM_REAL64 = 5, case VT_R8: nWMISize = sizeof(double); break; // CIM_BOOLEAN = 11, case VT_BOOL: nWMISize = sizeof(BYTE); break; case CIM_DATETIME: nWMISize = SIZEOFWBEMDATETIME; break; case CIM_STRING: nWMISize = 2; break; default: // CIM_STRING = 8, // CIM_REFERENCE = 102, // CIM_OBJECT = 13, // CIM_FLAG_ARRAY = 0x2000 nWMISize = 0; } return nWMISize; } /////////////////////////////////////////////////////////////// long CWMIDataTypeMap::GetVariantType(WCHAR * wcsType) { long lType; // CIM_SINT8 = 16, if( 0 == wbem_wcsicmp( L"sint8",wcsType) ){ lType = VT_I1; } // CIM_UINT8 = 17, else if( 0 == wbem_wcsicmp( L"uint8",wcsType) ){ lType = VT_UI1; } // CIM_CHAR16 = 103, else if( 0 == wbem_wcsicmp( L"char16",wcsType) ){ lType = VT_I2; } // CIM_SINT16 = 2, else if( 0 == wbem_wcsicmp( L"sint16",wcsType) ){ lType = VT_I2; } // CIM_UINT16 = 18, else if( 0 == wbem_wcsicmp( L"uint16",wcsType) ){ lType = VT_UI2; } // CIM_SINT32 = 3, else if( 0 == wbem_wcsicmp( L"sint32",wcsType) ){ lType = VT_I4; } // CIM_UINT32 = 19, else if( 0 == wbem_wcsicmp( L"uint32",wcsType) ){ lType = VT_UI4; } // CIM_SINT64 = 20, else if( 0 == wbem_wcsicmp( L"sint64",wcsType) ){ lType = VT_I8; } // CIM_UINT64 = 21, else if( 0 == wbem_wcsicmp( L"uint64",wcsType) ){ lType = VT_UI8; } // CIM_REAL32 = 4, else if( 0 == wbem_wcsicmp( L"real32",wcsType) ){ lType = VT_R4; } // CIM_REAL64 = 5, else if( 0 == wbem_wcsicmp( L"real64",wcsType) ){ lType = VT_R8; } // CIM_BOOLEAN = 11, else if( 0 == wbem_wcsicmp( L"boolean",wcsType) ){ lType = VT_BOOL; } // CIM_DATETIME = 101, else if( 0 == wbem_wcsicmp( L"datetime",wcsType) ){ lType = CIM_DATETIME; } // CIM_STRING = 8, // CIM_REFERENCE = 102, // CIM_OBJECT = 13, // CIM_FLAG_ARRAY = 0x2000 else{ lType = VT_BSTR; } return lType; } /////////////////////////////////////////////////////////////// WCHAR * CWMIDataTypeMap::SetVariantType(long lType) { if( lType & CIM_FLAG_ARRAY ){ lType = lType &~ CIM_FLAG_ARRAY; } switch(lType){ // CIM_SINT8 = 16, case VT_I1: return L"sint8"; // CIM_UINT8 = 17, case VT_UI1: return L"uint8"; // CIM_SINT16 = 2, case VT_I2: return L"sint16"; // CIM_UINT16 = 18, case VT_UI2: return L"uint16"; // CIM_SINT32 = 3, case VT_I4: return L"sint32"; // CIM_UINT32 = 19, case VT_UI4: return L"uint32"; // CIM_SINT64 = 20, case VT_I8: return L"sint64"; // CIM_UINT64 = 21, case VT_UI8: return L"uint64"; // CIM_REAL32 = 4, case VT_R4: return L"real32"; // CIM_REAL64 = 5, case VT_R8: return L"real64"; // CIM_BOOLEAN = 11, case VT_BOOL: return L"boolean"; // CIM_STRING = 8, case VT_BSTR: return L"string"; // CIM_CHAR16 = 103, case CIM_CHAR16: return L"char16"; // CIM_OBJECT = 13, case CIM_OBJECT: return L"object"; // CIM_REFERENCE = 102, case CIM_REFERENCE: return L"ref"; // CIM_DATETIME = 101, case CIM_DATETIME: return L"datetime"; default: return NULL; } } //////////////////////////////////////////////////////////////// void CWMIDataTypeMap::GetSizeAndType( WCHAR * wcsType, IDOrder * p, long & lType, int & nWMISize ) { BOOL fArray = FALSE; if( lType & CIM_FLAG_ARRAY ){ fArray = TRUE; } DWORD dwSizeObject = wcslen(L"object:"); if( 0 == wbem_wcsnicmp( L"object:",wcsType,dwSizeObject ) ) { //============================================ // Extract out the object name //============================================ WCHAR * pName = & wcsType [ dwSizeObject ]; p->SetEmbeddedName(pName); lType = VT_UNKNOWN; nWMISize = 0; } else{ lType = GetVariantType(wcsType); nWMISize = GetWMISize(lType); } if( fArray ){ lType |= CIM_FLAG_ARRAY; } } ///////////////////////////////////////////////////////////////////// long CWMIDataTypeMap::ConvertType(long lType ) { long lConvert = lType; switch (lType){ // CIM_SINT16 = 2, // CIM_UINT16 = 18, // CIM_SINT8 case VT_I1: case VT_I2: lConvert = VT_I2; break; case VT_UI2: lConvert = VT_I4; break; // CIM_SINT32 = 3, // CIM_UINT32 = 19, case VT_I4: case VT_UI4: lConvert = VT_I4; break; // CIM_REAL32 = 4, // CIM_REAL64 = 5, case VT_R4: case VT_R8: lConvert = VT_R8; break; // CIM_SINT64 = 20, // CIM_UINT64 = 21, // CIM_STRING = 8, // CIM_DATETIME = 101, // CIM_REFERENCE = 102, // CIM_CHAR16 = 103, // CIM_OBJECT = 13, // CIM_FLAG_ARRAY = 0x2000 case VT_I8: case VT_UI8: case VT_BSTR: case CIM_DATETIME: lConvert = VT_BSTR; break; // CIM_BOOLEAN = 11, case VT_BOOL: lConvert = VT_BOOL; break; // CIM_UINT8 = 17, case VT_UI1: lConvert = VT_UI1; break; case VT_UNKNOWN: lConvert = VT_UNKNOWN; break; default: break; } return lConvert; } ///////////////////////////////////////////////////////////////////// HRESULT CWMIDataTypeMap::PutInArray(SAFEARRAY * & psa,long * pi, long & lType, VARIANT * pVar) { HRESULT hr = WBEM_E_INVALID_OBJECT; VARIANT v = *pVar; switch (lType){ // CIM_SINT16 = 2, // CIM_UINT16 = 18, // CIM_SINT8 case VT_I1: case VT_I2: lType = V_VT(&v) = VT_I2; hr = SafeArrayPutElement(psa,pi,&V_I2(&v)); break; case VT_UI2: lType = V_VT(&v) = VT_I4; hr = SafeArrayPutElement(psa,pi,&V_I4(&v)); break; // CIM_SINT32 = 3, // CIM_UINT32 = 19, case VT_I4: case VT_UI4: lType = V_VT(&v) = VT_I4; hr = SafeArrayPutElement(psa,pi,&V_I4(&v)); break; // CIM_REAL32 = 4, // CIM_REAL64 = 5, case VT_R4: case VT_R8: lType = V_VT(&v) = VT_R8; hr = SafeArrayPutElement(psa,pi,&V_R8(&v)); break; // CIM_SINT64 = 20, // CIM_UINT64 = 21, // CIM_STRING = 8, // CIM_DATETIME = 101, // CIM_REFERENCE = 102, // CIM_CHAR16 = 103, // CIM_OBJECT = 13, // CIM_FLAG_ARRAY = 0x2000 case VT_I8: case VT_UI8: case VT_BSTR: case CIM_DATETIME: lType = V_VT(&v) = VT_BSTR; hr = SafeArrayPutElement(psa,pi,V_BSTR(&v)); break; // CIM_BOOLEAN = 11, case VT_BOOL: lType = V_VT(&v) = VT_BOOL; hr = SafeArrayPutElement(psa,pi,&V_BOOL(&v)); break; // CIM_UINT8 = 17, case VT_UI1: lType = V_VT(&v) = VT_UI1; hr = SafeArrayPutElement(psa,pi,&V_UI1(&v)); break; case VT_UNKNOWN: lType = V_VT(&v) = VT_UNKNOWN; hr = SafeArrayPutElement(psa,pi,V_UNKNOWN(&v)); break; default: break; } return hr; } ////////////////////////////////////////////////////////////////////// BOOL CWMIDataTypeMap::NaturallyAlignData( int nSize, BOOL fRead ) { BOOL fRc = FALSE; DWORD dwBytesToPad = 0; if( *m_pdwAccumulativeSizeOfBlock != 0 ){ DWORD dwMod; int nNewSize = nSize; if( nSize == SIZEOFWBEMDATETIME ){ nNewSize = 2; } dwMod = *m_pdwAccumulativeSizeOfBlock % nNewSize; if( dwMod > 0 ){ dwBytesToPad = (DWORD)nNewSize - dwMod; } } if( fRead ){ if( m_pWMIBlockInfo->CurrentPtrOk((ULONG)(dwBytesToPad+nSize)) ){ fRc = TRUE; } else{ dwBytesToPad = 0; } } else{ fRc = TRUE; } m_pWMIBlockInfo->AddPadding(dwBytesToPad); *m_pdwAccumulativeSizeOfBlock += nSize + dwBytesToPad; return fRc; }