FreeTDS API
Loading...
Searching...
No Matches
ctlib.h
1/* FreeTDS - Library of routines accessing Sybase and Microsoft databases
2 * Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004 Brian Bruns
3 *
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Library General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
8 *
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Library General Public License for more details.
13 *
14 * You should have received a copy of the GNU Library General Public
15 * License along with this library; if not, write to the
16 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17 * Boston, MA 02111-1307, USA.
18 */
19
20#ifndef _ctlib_h_
21#define _ctlib_h_
22
23#include <freetds/tds.h>
24#include <freetds/convert.h>
25#include <freetds/utils/string.h>
26#include <freetds/bool.h>
27
28/*
29 * Internal (not part of the exposed API) prototypes and such.
30 */
31
32#include <freetds/pushvis.h>
33
34#ifdef __cplusplus
35extern "C"
36{
37#if 0
38}
39#endif
40#endif
41
42/* Fix a problem with Windows headers */
43#undef small
44
45/*
46 * internal types
47 */
49{
50 short cs_expose_formats;
51};
52
53/* Code changed for error handling */
54/* Code changes starts here - CT_DIAG - 01 */
55
56/* This structure is used in CT_DIAG */
57
59{
60 struct cs_diag_msg_client *next;
61 CS_CLIENTMSG clientmsg;
62};
63
64typedef struct {
65 CS_MSGNUM msgnumber;
66 CS_INT state;
67 CS_INT severity;
68 CS_CHAR text[CS_MAX_MSG];
69 CS_INT textlen;
70 CS_CHAR svrname[132];
71 CS_INT svrnlen;
72 CS_CHAR proc[132];
73 CS_INT proclen;
74 CS_INT line;
75 CS_INT status;
76 CS_BYTE sqlstate[CS_SQLSTATE_SIZE];
77 CS_INT sqlstatelen;
79
80typedef struct {
81 CS_MSGNUM msgnumber;
82 CS_INT state;
83 CS_INT severity;
84 CS_CHAR text[CS_MAX_MSG];
85 CS_INT textlen;
86 CS_CHAR svrname[256];
87 CS_INT svrnlen;
88 CS_CHAR proc[256];
89 CS_INT proclen;
90 CS_INT line;
91 CS_INT status;
92 CS_BYTE sqlstate[CS_SQLSTATE_SIZE];
93 CS_INT sqlstatelen;
95
96typedef struct {
97 CS_MSGNUM msgnumber;
98 CS_INT state;
99 CS_INT severity;
100 CS_CHAR text[CS_MAX_MSG];
101 CS_INT textlen;
103
104typedef struct {
105 CS_INT line;
106 CS_INT status;
107 CS_BYTE sqlstate[CS_SQLSTATE_SIZE];
108 CS_INT sqlstatelen;
110
111typedef union
112{
113 CS_SERVERMSG_SMALL small;
114 CS_SERVERMSG_LARGE large;
116 CS_SERVERMSG user;
118
120{
121 struct cs_diag_msg_svr *next;
122 CS_SERVERMSG_INTERNAL servermsg;
123};
124
125/* Code changes ends here - CT_DIAG - 01 */
126
128{
129 CS_CLIENTMSG *msg;
130 struct cs_diag_msg *next;
131};
132
134{
135 CS_INT date_convert_fmt;
136 CS_INT cs_errhandletype;
137 CS_INT cs_diag_msglimit;
138
139 /* added for storing the maximum messages limit CT_DIAG */
140 /* code changes starts here - CT_DIAG - 02 */
141
142 CS_INT cs_diag_msglimit_client;
143 CS_INT cs_diag_msglimit_server;
144 CS_INT cs_diag_msglimit_total;
145 struct cs_diag_msg_client *clientstore;
146 struct cs_diag_msg_svr *svrstore;
147
148 /* code changes ends here - CT_DIAG - 02 */
149
150 struct cs_diag_msg *msgstore;
151 CS_CSLIBMSG_FUNC _cslibmsg_cb;
152 CS_CLIENTMSG_FUNC _clientmsg_cb;
153 CS_SERVERMSG_FUNC _servermsg_cb;
154 /* code changes start here - CS_CONFIG - 01*/
155 void *userdata;
156 int userdata_len;
157 /* code changes end here - CS_CONFIG - 01*/
158 TDSCONTEXT *tds_ctx;
159 CS_CONFIG config;
165};
166
167static inline size_t cs_servermsg_len(CS_CONTEXT *ctx)
168{
169 if (ctx->use_large_identifiers)
170 return sizeof(CS_SERVERMSG_LARGE);
171 return sizeof(CS_SERVERMSG_SMALL);
172}
173
174/*
175 * internal typedefs
176 */
177typedef struct _ct_colinfo
178{
179 TDS_SMALLINT *indicator;
180}
182
183typedef struct _cs_dynamic CS_DYNAMIC;
184
186{
187 CS_CONTEXT *ctx;
190 CS_CLIENTMSG_FUNC _clientmsg_cb;
191 CS_SERVERMSG_FUNC _servermsg_cb;
192 void *userdata;
193 int userdata_len;
194 CS_LOCALE *locale;
195 CS_COMMAND *cmds;
196 CS_DYNAMIC *dynlist;
197 char *server_addr;
198 bool network_auth;
199};
200
201/*
202 * Formerly CSREMOTE_PROC_PARAM, this structure can be used in other
203 * places, too.
204 */
205
206typedef struct _cs_param
207{
208 struct _cs_param *next;
209 char *name;
210 int status;
211 int datatype;
212 CS_INT maxlen;
213 CS_INT scale;
214 CS_INT precision;
215 CS_INT *datalen;
216 CS_SMALLINT *ind;
217 CS_BYTE *value;
218 int param_by_value;
219 CS_INT datalen_value;
220 CS_SMALLINT indicator_value;
221} CS_PARAM;
222
223/*
224 * Code added for RPC functionality - SUHA
225 * RPC Code changes starts here
226 */
227
229
230typedef struct _csremote_proc
231{
232 char *name;
233 CS_SMALLINT options;
234 CSREMOTE_PROC_PARAM *param_list;
236
237/*
238 * Structure CS_COMMAND changed for RPC functionality -SUHA
239 * Added CSREMOTE_PROC *rpc to CS_COMMAND structure
240 */
241
243
245{
246 struct _cs_dynamic *next;
247 char *id;
248 char *stmt;
249 CS_DYNAMIC_PARAM *param_list;
250 TDSDYNAMIC *tdsdyn;
251};
252
253/* specific FreeTDS commands */
254#define CS_DYNAMIC_CMD 160
255#define CS_CUR_CMD 161
256
257/* values for cs_command.results_state */
258
259#define _CS_RES_NONE -1
260#define _CS_RES_INIT 0
261#define _CS_RES_RESULTSET_EMPTY 1
262#define _CS_RES_RESULTSET_ROWS 2
263#define _CS_RES_STATUS 3
264#define _CS_RES_CMD_DONE 4
265#define _CS_RES_CMD_SUCCEED 5
266#define _CS_RES_END_RESULTS 6
267#define _CS_RES_DESCRIBE_RESULT 7
268
269/* values for cs_command.command_state */
270
271#define _CS_COMMAND_IDLE 0
272#define _CS_COMMAND_BUILDING 1
273#define _CS_COMMAND_READY 2
274#define _CS_COMMAND_SENT 3
275
276/* values for cs_command.cancel_state */
277#define _CS_CANCEL_NOCANCEL 0
278#define _CS_CANCEL_PENDING 1
279
281{
282 struct _cs_command *next;
283 CS_INT command_state;
284 CS_INT results_state;
285 CS_INT cancel_state;
286 CS_INT cursor_state;
287 CS_CONNECTION *con;
288 CS_INT command_type;
289 CS_CHAR *query;
290 short dynamic_cmd;
291 CS_DYNAMIC *dyn;
292 int row_prefetched;
293 int curr_result_type;
294 int bind_count;
295 int get_data_item;
296 int get_data_bytes_returned;
297 CS_IODESC *iodesc;
298 CS_INT send_data_started;
299 CSREMOTE_PROC *rpc;
300 CS_PARAM *input_params;
301 CS_INT client_cursor_id;
302 TDSCURSOR *cursor;
303 void *userdata;
304 int userdata_len;
305};
306
308{
309 TDSBCPINFO bcpinfo;
310};
311
312
313#define _CS_ERRHAND_INLINE 1
314#define _CS_ERRHAND_CB 2
315
317{
318 char *language;
319 char *charset;
320 char *time;
321 char *collate;
322};
323
324/* internal defines for cursor processing */
325
326#define _CS_CURS_TYPE_UNACTIONED 0
327#define _CS_CURS_TYPE_REQUESTED 1
328#define _CS_CURS_TYPE_SENT 2
329
330typedef struct {
331 CS_CHAR name[132];
332 CS_INT namelen;
333 CS_INT datatype;
334 CS_INT format;
335 CS_INT maxlength;
336 CS_INT scale;
337 CS_INT precision;
338 CS_INT status;
339 CS_INT count;
340 CS_INT usertype;
341 CS_LOCALE *locale;
343
344typedef struct {
345 CS_CHAR name[256];
346 CS_INT namelen;
347 CS_INT datatype;
348 CS_INT format;
349 CS_INT maxlength;
350 CS_INT scale;
351 CS_INT precision;
352 CS_INT status;
353 CS_INT count;
354 CS_INT usertype;
355 CS_LOCALE *locale;
357
358typedef struct {
359 CS_INT datatype;
360 CS_INT format;
361 CS_INT maxlength;
362 CS_INT scale;
363 CS_INT precision;
364 CS_INT status;
365 CS_INT count;
366 CS_INT usertype;
367 CS_LOCALE *locale;
369
370typedef union
371{
372 CS_DATAFMT_SMALL small;
373 CS_DATAFMT_LARGE large;
374 CS_DATAFMT user;
376
377/*
378 * internal prototypes
379 */
380TDSRET _ct_handle_server_message(const TDSCONTEXT * ctxptr, TDSSOCKET * tdsptr, TDSMESSAGE * msgptr);
381int _ct_handle_client_message(const TDSCONTEXT * ctxptr, TDSSOCKET * tdsptr, TDSMESSAGE * msgptr);
382TDS_SERVER_TYPE _ct_get_server_type(TDSSOCKET *tds, int datatype);
383int _ct_bind_data(CS_CONTEXT *ctx, TDSRESULTINFO * resinfo, TDSRESULTINFO *bindinfo, CS_INT offset);
384int _ct_get_client_type(const TDSCOLUMN *col, bool describe);
385void _ctclient_msg(CS_CONNECTION * con, const char *funcname, int layer, int origin, int severity, int number,
386 const char *fmt, ...);
387CS_INT _ct_diag_clearmsg(CS_CONTEXT * context, CS_INT type);
388void _cs_locale_free(CS_LOCALE *locale);
389CS_LOCALE *_cs_locale_copy(CS_LOCALE *orig);
390int _cs_locale_copy_inplace(CS_LOCALE *new_locale, CS_LOCALE *orig);
391
392int _cs_convert_not_client(CS_CONTEXT *ctx, const TDSCOLUMN *curcol, CONV_RESULT *convert_buffer, unsigned char **p_src);
393
394CS_RETCODE _cs_convert(CS_CONTEXT * ctx, const CS_DATAFMT_COMMON * srcfmt, CS_VOID * srcdata,
395 const CS_DATAFMT_COMMON * destfmt, CS_VOID * destdata, CS_INT * resultlen);
396bool _ct_is_large_identifiers_version(CS_INT version);
397const CS_DATAFMT_COMMON * _ct_datafmt_common(CS_CONTEXT * ctx, const CS_DATAFMT * datafmt);
398const CS_DATAFMT_LARGE *_ct_datafmt_conv_in(CS_CONTEXT * ctx, const CS_DATAFMT * datafmt, CS_DATAFMT_LARGE * fmtbuf);
399CS_DATAFMT_LARGE *_ct_datafmt_conv_prepare(CS_CONTEXT * ctx, CS_DATAFMT * datafmt, CS_DATAFMT_LARGE * fmtbuf);
400void _ct_datafmt_conv_back(CS_DATAFMT * datafmt, CS_DATAFMT_LARGE * fmtbuf);
401
402#ifdef __cplusplus
403#if 0
404{
405#endif
406}
407#endif
408
409#include <freetds/popvis.h>
410
411#endif
Main include file for libtds.
Definition cstypes.h:102
Definition cstypes.h:119
Definition cstypes.h:186
Definition cstypes.h:200
Definition ctlib.h:49
Definition ctlib.h:59
Definition ctlib.h:64
Definition ctlib.h:80
Definition ctlib.h:96
Definition ctlib.h:104
Definition ctlib.h:112
Definition ctlib.h:120
Definition ctlib.h:128
Definition ctlib.h:134
int login_timeout
not used unless positive
Definition ctlib.h:160
bool use_large_identifiers
structures uses large identifiers
Definition ctlib.h:164
int query_timeout
not used unless positive
Definition ctlib.h:161
Definition ctlib.h:178
Definition ctlib.h:186
Definition ctlib.h:207
Definition ctlib.h:231
Definition ctlib.h:245
Definition ctlib.h:281
Definition ctlib.h:308
Definition ctlib.h:317
Definition ctlib.h:330
Definition ctlib.h:344
Definition ctlib.h:358
Definition ctlib.h:371
Definition convert.h:34
Definition tds.h:518
Metadata about columns in regular and compute rows.
Definition tds.h:693
Hold information for any results.
Definition tds.h:773
Definition tds.h:880
Holds informations about a cursor.
Definition tds.h:941
Holds information for a dynamic (also called prepared) query.
Definition tds.h:981
Definition tds.h:1033
Information for a server connection.
Definition tds.h:1180
Definition tds.h:1700