8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-24 06:03:02 +01:00

Fixed CORE-3489 - Blob transliteration may not happen inside the union.

This commit is contained in:
asfernandes 2011-05-31 00:54:35 +00:00
parent 66545fdb17
commit 0bda6ba36f

View File

@ -6304,17 +6304,17 @@ static void process_map(thread_db* tdbb, CompilerScratch* csb, jrd_nod* map,
} }
dsc* desc = &format->fmt_desc[id]; dsc* desc = &format->fmt_desc[id];
CMP_get_desc(tdbb, csb, assignment->nod_arg[e_asgn_from], &desc2); CMP_get_desc(tdbb, csb, assignment->nod_arg[e_asgn_from], &desc2);
const USHORT min = MIN(desc->dsc_dtype, desc2.dsc_dtype); const USHORT min = MIN(desc->dsc_dtype, desc2.dsc_dtype);
const USHORT max = MAX(desc->dsc_dtype, desc2.dsc_dtype); const USHORT max = MAX(desc->dsc_dtype, desc2.dsc_dtype);
if (!min) { // eg: dtype_unknown
if (!min) // eg: dtype_unknown
*desc = desc2; *desc = desc2;
} else if (max == dtype_blob)
else if (max == dtype_blob) { {
desc->dsc_dtype = dtype_blob; USHORT subtype = DataTypeUtil::getResultBlobSubType(desc, &desc2);
desc->dsc_length = sizeof(ISC_QUAD); USHORT ttype = DataTypeUtil::getResultTextType(desc, &desc2);
desc->dsc_scale = 0; desc->makeBlob(subtype, ttype);
desc->dsc_sub_type = DataTypeUtil::getResultBlobSubType(desc, &desc2);
desc->dsc_flags = 0;
} }
else if (min <= dtype_any_text) { // either field a text field? else if (min <= dtype_any_text) { // either field a text field?
const USHORT len1 = DSC_string_length(desc); const USHORT len1 = DSC_string_length(desc);