mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-24 06:43:03 +01:00
Fixed CORE-1094.
This commit is contained in:
parent
25a69d4ded
commit
561c3816bc
@ -4978,10 +4978,26 @@ static UCHAR* var_info(
|
|||||||
if (!message || !message->msg_index)
|
if (!message || !message->msg_index)
|
||||||
return info;
|
return info;
|
||||||
|
|
||||||
for (const dsql_par* param = message->msg_par_ordered; param;
|
Firebird::HalfStaticArray<const dsql_par*, 16> parameters;
|
||||||
param = param->par_ordered)
|
|
||||||
|
for (const dsql_par* param = message->msg_parameters; param;
|
||||||
|
param = param->par_next)
|
||||||
{
|
{
|
||||||
if (param->par_index && param->par_index >= first_index)
|
if (param->par_index)
|
||||||
|
{
|
||||||
|
if (param->par_index > parameters.getCount())
|
||||||
|
parameters.grow(param->par_index);
|
||||||
|
fb_assert(!parameters[param->par_index - 1]);
|
||||||
|
parameters[param->par_index - 1] = param;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < parameters.getCount(); i++)
|
||||||
|
{
|
||||||
|
const dsql_par* param = parameters[i];
|
||||||
|
fb_assert(param);
|
||||||
|
|
||||||
|
if (param->par_index >= first_index)
|
||||||
{
|
{
|
||||||
sql_len = param->par_desc.dsc_length;
|
sql_len = param->par_desc.dsc_length;
|
||||||
sql_sub_type = 0;
|
sql_sub_type = 0;
|
||||||
|
@ -594,7 +594,6 @@ class dsql_msg : public pool_alloc<dsql_type_msg>
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
dsql_par* msg_parameters; //!< Parameter list
|
dsql_par* msg_parameters; //!< Parameter list
|
||||||
dsql_par* msg_par_ordered; //!< Ordered parameter list
|
|
||||||
UCHAR* msg_buffer; //!< Message buffer
|
UCHAR* msg_buffer; //!< Message buffer
|
||||||
USHORT msg_number; //!< Message number
|
USHORT msg_number; //!< Message number
|
||||||
USHORT msg_length; //!< Message length
|
USHORT msg_length; //!< Message length
|
||||||
@ -608,7 +607,6 @@ class dsql_par : public pool_alloc<dsql_type_par>
|
|||||||
public:
|
public:
|
||||||
dsql_msg* par_message; //!< Parent message
|
dsql_msg* par_message; //!< Parent message
|
||||||
dsql_par* par_next; //!< Next parameter in linked list
|
dsql_par* par_next; //!< Next parameter in linked list
|
||||||
dsql_par* par_ordered; //!< Next parameter in order of index
|
|
||||||
dsql_par* par_null; //!< Null parameter, if used
|
dsql_par* par_null; //!< Null parameter, if used
|
||||||
dsql_nod* par_node; //!< Associated value node, if any
|
dsql_nod* par_node; //!< Associated value node, if any
|
||||||
dsql_ctx* par_dbkey_ctx; //!< Context of internally requested dbkey
|
dsql_ctx* par_dbkey_ctx; //!< Context of internally requested dbkey
|
||||||
|
@ -1909,10 +1909,6 @@ dsql_par* MAKE_parameter(dsql_msg* message, bool sqlda_flag, bool null_flag,
|
|||||||
dsql_par* parameter = FB_NEW(*tdsql->getDefaultPool()) dsql_par;
|
dsql_par* parameter = FB_NEW(*tdsql->getDefaultPool()) dsql_par;
|
||||||
parameter->par_message = message;
|
parameter->par_message = message;
|
||||||
parameter->par_next = message->msg_parameters;
|
parameter->par_next = message->msg_parameters;
|
||||||
if (parameter->par_next != 0)
|
|
||||||
parameter->par_next->par_ordered = parameter;
|
|
||||||
else
|
|
||||||
message->msg_par_ordered = parameter;
|
|
||||||
message->msg_parameters = parameter;
|
message->msg_parameters = parameter;
|
||||||
parameter->par_parameter = message->msg_parameter++;
|
parameter->par_parameter = message->msg_parameter++;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user