8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-25 04:43:03 +01:00
firebird-mirror/src/dsql/movd.cpp

108 lines
2.3 KiB
C++
Raw Normal View History

2001-05-23 15:26:42 +02:00
/*
* PROGRAM: Dynamic SQL runtime support
2001-05-23 15:26:42 +02:00
* MODULE: movd.c
* DESCRIPTION: Data mover and converter and comparator, etc.
*
* The contents of this file are subject to the Interbase Public
* License Version 1.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy
* of the License at http://www.Inprise.com/IPL.html
*
* Software distributed under the License is distributed on an
* "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express
* or implied. See the License for the specific language governing
* rights and limitations under the License.
*
* The Original Code was created by Inprise Corporation
* and its predecessors. Portions created by Inprise Corporation are
* Copyright (C) Inprise Corporation.
*
* All Rights Reserved.
* Contributor(s): ______________________________________.
*/
#include "firebird.h"
2001-05-23 15:26:42 +02:00
#include "../jrd/common.h"
#include "../jrd/ib_stdio.h"
#include <stdarg.h>
#include <string.h>
#include "../dsql/dsql.h"
#include "gen/codes.h"
2001-05-23 15:26:42 +02:00
#include "../jrd/iberr.h"
#include "../dsql/errd_proto.h"
#include "../dsql/movd_proto.h"
#include "../jrd/cvt_proto.h"
#include "../jrd/thd_proto.h"
2003-04-10 08:32:58 +02:00
static void post_error(ISC_STATUS, ...);
2001-05-23 15:26:42 +02:00
/**
MOVD_move
@brief Move (and possible convert) something to something else.
@param from
@param to
**/
2003-10-05 08:27:16 +02:00
void MOVD_move(const dsc* from, dsc* to)
2001-05-23 15:26:42 +02:00
{
CVT_move(from, to, post_error);
2001-05-23 15:26:42 +02:00
}
/**
post_error
@brief A conversion error occurred. Complain.
@param status
@param
**/
2003-04-10 08:32:58 +02:00
static void post_error( ISC_STATUS status, ...)
2001-05-23 15:26:42 +02:00
{
2003-04-16 12:18:51 +02:00
ISC_STATUS *v, *v_end, *temp;
ISC_STATUS_ARRAY temp_status;
2001-05-23 15:26:42 +02:00
2003-10-05 08:27:16 +02:00
TSQL tdsql = GET_THREAD_DATA;
2001-05-23 15:26:42 +02:00
/* copy into a temporary array any other arguments which may
* have been handed to us, then post the error.
* N.B., the last supplied error should be a 0.
*/
STUFF_STATUS(temp_status, status);
v = tdsql->tsql_status;
v_end = v + 20;
*v++ = gds_arg_gds;
*v++ = gds_dsql_error;
2001-05-23 15:26:42 +02:00
*v++ = gds_arg_gds;
*v++ = gds_sqlerr;
2001-05-23 15:26:42 +02:00
*v++ = gds_arg_number;
*v++ = -303;
for (temp = temp_status; v < v_end && (*v = *temp) != gds_arg_end;
v++, temp++)
switch (*v) {
case gds_arg_cstring:
*++v = *++temp;
*++v = *++temp;
break;
default:
*++v = *++temp;
break;
};
ERRD_punt();
}
2003-10-05 08:27:16 +02:00