Commit c3bc7f2c authored by Juan Lang's avatar Juan Lang Committed by Alexandre Julliard

crypt32: Simplify a function.

parent 59bcbb2d
...@@ -786,46 +786,41 @@ static BOOL CRYPT_EncodeValueWithType(DWORD dwCertEncodingType, ...@@ -786,46 +786,41 @@ static BOOL CRYPT_EncodeValueWithType(DWORD dwCertEncodingType,
if (value->end > value->start) if (value->end > value->start)
{ {
LONG i;
LPWSTR ptr;
nameValue.Value.pbData = CryptMemAlloc((value->end - value->start) * nameValue.Value.pbData = CryptMemAlloc((value->end - value->start) *
sizeof(WCHAR)); sizeof(WCHAR));
if (!nameValue.Value.pbData) if (!nameValue.Value.pbData)
{ {
SetLastError(ERROR_OUTOFMEMORY); SetLastError(ERROR_OUTOFMEMORY);
ret = FALSE; return FALSE;
}
}
if (ret)
{
if (value->end > value->start)
{
LONG i;
LPWSTR ptr = (LPWSTR)nameValue.Value.pbData;
for (i = 0; i < value->end - value->start; i++)
{
*ptr++ = value->start[i];
if (value->start[i] == '"')
i++;
}
nameValue.Value.cbData = (LPBYTE)ptr - nameValue.Value.pbData;
} }
ret = CryptEncodeObjectEx(dwCertEncodingType, X509_UNICODE_NAME_VALUE, ptr = (LPWSTR)nameValue.Value.pbData;
&nameValue, CRYPT_ENCODE_ALLOC_FLAG, NULL, &output->pbData, for (i = 0; i < value->end - value->start; i++)
&output->cbData);
if (!ret && ppszError)
{ {
if (type == CERT_RDN_NUMERIC_STRING && *ptr++ = value->start[i];
GetLastError() == CRYPT_E_INVALID_NUMERIC_STRING) if (value->start[i] == '"')
*ppszError = value->start + output->cbData; i++;
else if (type == CERT_RDN_PRINTABLE_STRING &&
GetLastError() == CRYPT_E_INVALID_PRINTABLE_STRING)
*ppszError = value->start + output->cbData;
else if (type == CERT_RDN_IA5_STRING &&
GetLastError() == CRYPT_E_INVALID_IA5_STRING)
*ppszError = value->start + output->cbData;
} }
CryptMemFree(nameValue.Value.pbData); nameValue.Value.cbData = (LPBYTE)ptr - nameValue.Value.pbData;
}
ret = CryptEncodeObjectEx(dwCertEncodingType, X509_UNICODE_NAME_VALUE,
&nameValue, CRYPT_ENCODE_ALLOC_FLAG, NULL, &output->pbData,
&output->cbData);
if (!ret && ppszError)
{
if (type == CERT_RDN_NUMERIC_STRING &&
GetLastError() == CRYPT_E_INVALID_NUMERIC_STRING)
*ppszError = value->start + output->cbData;
else if (type == CERT_RDN_PRINTABLE_STRING &&
GetLastError() == CRYPT_E_INVALID_PRINTABLE_STRING)
*ppszError = value->start + output->cbData;
else if (type == CERT_RDN_IA5_STRING &&
GetLastError() == CRYPT_E_INVALID_IA5_STRING)
*ppszError = value->start + output->cbData;
} }
CryptMemFree(nameValue.Value.pbData);
return ret; return ret;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment