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.
 
 
 
 
 
 

351 lines
6.5 KiB

//---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1992 - 1996
//
// File: varconv.cxx
//
// Contents: Ansi to Unicode conversions
//
// History: SWilson Nov 1996
//----------------------------------------------------------------------------
#define INC_OLE2
#include "precomp.h"
#pragma hdrstop
#include "client.h"
#include "pubprn.hxx"
#include "varconv.hxx"
#include "property.hxx"
#include "dsutil.hxx"
HRESULT
PackString2Variant(
LPCWSTR lpszData,
VARIANT * pvData
)
{
BSTR bstrData = NULL;
WCHAR String[] = L"";
LPCWSTR pStr;
pStr = lpszData ? lpszData : (LPCWSTR) String;
VariantInit(pvData);
pvData->vt = VT_BSTR;
bstrData = SysAllocString(pStr);
if (!bstrData) {
return MAKE_HRESULT(SEVERITY_ERROR,
FACILITY_WIN32,
ERROR_OUTOFMEMORY);
}
pvData->vt = VT_BSTR;
pvData->bstrVal = bstrData;
return ERROR_SUCCESS;
}
HRESULT
UnpackStringfromVariant(
VARIANT varSrcData,
BSTR * pbstrDestString
)
{
HRESULT hr = E_POINTER;
if (pbstrDestString)
{
if (varSrcData.vt != VT_BSTR)
{
hr = E_ADS_CANT_CONVERT_DATATYPE;
}
else
{
*pbstrDestString = SysAllocString(V_BSTR(&varSrcData) ? V_BSTR(&varSrcData) : L"");
hr = *pbstrDestString ? S_OK : E_OUTOFMEMORY;
}
}
return hr;
}
HRESULT
UnpackDispatchfromVariant(
VARIANT varSrcData,
IDispatch **ppDispatch
)
{
HRESULT hr = S_OK;
if( varSrcData.vt != VT_DISPATCH) {
return E_ADS_CANT_CONVERT_DATATYPE;
}
if (!V_DISPATCH(&varSrcData)) {
*ppDispatch = NULL;
return S_OK;
}
*ppDispatch = V_DISPATCH(&varSrcData);
return hr;
}
HRESULT
PackDispatch2Variant(
IDispatch *pDispatch,
VARIANT *pvData
)
{
if (!pvData)
return E_FAIL;
V_VT(pvData) = VT_DISPATCH;
V_DISPATCH(pvData) = pDispatch;
return S_OK;
}
HRESULT
PackDWORD2Variant(
DWORD dwData,
VARIANT * pvData
)
{
if (!pvData) {
return(E_FAIL);
}
pvData->vt = VT_I4;
pvData->lVal = dwData;
return S_OK;
}
HRESULT
PackBOOL2Variant(
BOOL fData,
VARIANT * pvData
)
{
pvData->vt = VT_BOOL;
V_BOOL(pvData) = (BYTE) fData;
return S_OK;
}
HRESULT
PackVARIANTinVariant(
VARIANT vaValue,
VARIANT *pvarInputData
)
{
VariantInit(pvarInputData);
pvarInputData->vt = VT_VARIANT;
return VariantCopy( pvarInputData, &vaValue );
}
HRESULT
MakeVariantFromStringArray(
BSTR *bstrList,
VARIANT *pvVariant
)
{
HRESULT hr = S_OK;
SAFEARRAY *aList = NULL;
SAFEARRAYBOUND aBound;
long i = 0;
long j = 0;
long nCount;
if ( (bstrList != NULL) && (*bstrList != 0) ) {
for (nCount = 0 ; bstrList[nCount] ; ++nCount)
;
if ( nCount == 1 ) {
VariantInit( pvVariant );
V_VT(pvVariant) = VT_BSTR;
if (!(V_BSTR(pvVariant) = SysAllocString( bstrList[0]))) {
hr = E_OUTOFMEMORY;
BAIL_ON_FAILURE(hr);
}
return hr;
}
aBound.lLbound = 0;
aBound.cElements = nCount;
aList = SafeArrayCreate( VT_VARIANT, 1, &aBound );
if ( aList == NULL ) {
hr = E_OUTOFMEMORY;
BAIL_ON_FAILURE(hr);
}
for (i = 0 ; bstrList[i] ; ++i) {
VARIANT v;
VariantInit(&v);
V_VT(&v) = VT_BSTR;
if (!(V_BSTR(&v) = SysAllocString(bstrList[i]))) {
hr = E_OUTOFMEMORY;
BAIL_ON_FAILURE(hr);
}
hr = SafeArrayPutElement( aList,
&i,
&v );
BAIL_ON_FAILURE(hr);
}
VariantInit( pvVariant );
V_VT(pvVariant) = VT_ARRAY | VT_VARIANT;
V_ARRAY(pvVariant) = aList;
} else {
aBound.lLbound = 0;
aBound.cElements = 0;
aList = SafeArrayCreate( VT_VARIANT, 1, &aBound );
if ( aList == NULL ) {
hr = E_OUTOFMEMORY;
BAIL_ON_FAILURE(hr);
}
VariantInit( pvVariant );
V_VT(pvVariant) = VT_ARRAY | VT_VARIANT;
V_ARRAY(pvVariant) = aList;
}
return S_OK;
error:
if ( aList )
SafeArrayDestroy( aList );
return hr;
}
HRESULT
PrintVariantArray(VARIANT var)
{
LONG dwSLBound = 0;
LONG dwSUBound = 0;
VARIANT v;
LONG i;
HRESULT hr = S_OK;
if ( !( (V_VT(&var) & VT_VARIANT) && V_ISARRAY(&var)) )
BAIL_ON_FAILURE(hr = E_FAIL);
// Check that there is only one dimension in this array
if ((V_ARRAY(&var))->cDims != 1)
BAIL_ON_FAILURE(hr = E_FAIL);
// Check that there is atleast one element in this array
if ((V_ARRAY(&var))->rgsabound[0].cElements == 0)
BAIL_ON_FAILURE(hr = E_FAIL);
// We know that this is a valid single dimension array
hr = SafeArrayGetLBound(V_ARRAY(&var), 1, (long FAR *)&dwSLBound);
BAIL_ON_FAILURE(hr);
hr = SafeArrayGetUBound(V_ARRAY(&var), 1, (long FAR *)&dwSUBound);
BAIL_ON_FAILURE(hr);
for (i = dwSLBound; i <= dwSUBound; i++)
{
VariantInit(&v);
hr = SafeArrayGetElement(V_ARRAY(&var), (long FAR *)&i, &v);
if ( FAILED(hr) )
continue;
}
hr = S_OK;
error:
return hr;
}
HRESULT
UI1Array2IID(
VARIANT var,
IID *pIID
)
{
LONG dwSLBound = 0;
LONG dwSUBound = 0;
LONG i;
HRESULT hr = S_OK;
UCHAR pGUID[16];
if ( !( (V_VT(&var) & VT_UI1) && V_ISARRAY(&var)) )
BAIL_ON_FAILURE(hr = E_FAIL);
// Check that there is only one dimension in this array
if ((V_ARRAY(&var))->cDims != 1)
BAIL_ON_FAILURE(hr = E_FAIL);
// Check that there is at least one element in this array
if ((V_ARRAY(&var))->rgsabound[0].cElements != 16) {
BAIL_ON_FAILURE(hr = E_FAIL);
}
// We know that this is a valid single dimension array
hr = SafeArrayGetLBound(V_ARRAY(&var), 1, (long FAR *)&dwSLBound);
BAIL_ON_FAILURE(hr);
hr = SafeArrayGetUBound(V_ARRAY(&var), 1, (long FAR *)&dwSUBound);
BAIL_ON_FAILURE(hr);
for (i = dwSLBound; i <= dwSUBound; i++)
{
hr = SafeArrayGetElement(V_ARRAY(&var), (long FAR *)&i, pGUID + i - dwSLBound);
if ( FAILED(hr) )
continue;
}
*pIID = *(IID *) pGUID;
hr = S_OK;
error:
return hr;
}