mirror of https://github.com/tongzx/nt5src
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
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;
|
|
}
|