FreeTDS API
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
tds.h
Go to the documentation of this file.
1 /* FreeTDS - Library of routines accessing Sybase and Microsoft databases
2  * Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005 Brian Bruns
3  * Copyright (C) 2010, 2011 Frediano Ziglio
4  *
5  * This library is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU Library General Public
7  * License as published by the Free Software Foundation; either
8  * version 2 of the License, or (at your option) any later version.
9  *
10  * This library is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13  * Library General Public License for more details.
14  *
15  * You should have received a copy of the GNU Library General Public
16  * License along with this library; if not, write to the
17  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18  * Boston, MA 02111-1307, USA.
19  */
20 
21 #ifndef _tds_h_
22 #define _tds_h_
23 
24 /* $Id: tds.h,v 1.352.2.4 2011-08-12 16:29:36 freddy77 Exp $ */
25 
26 #include <stdarg.h>
27 #include <stdio.h>
28 #include <time.h>
29 
30 #if HAVE_NETINET_IN_H
31 #include <netinet/in.h>
32 #endif /* HAVE_NET_INET_IN_H */
33 #if HAVE_ARPA_INET_H
34 #include <arpa/inet.h>
35 #endif /* HAVE_ARPA_INET_H */
36 
37 /* forward declaration */
38 typedef struct tdsiconvinfo TDSICONV;
39 typedef struct tds_socket TDSSOCKET;
40 
41 #include "tdsver.h"
42 #include "tds_sysdep_public.h"
43 #ifdef _FREETDS_LIBRARY_SOURCE
44 #include "tds_sysdep_private.h"
45 #endif /* _FREETDS_LIBRARY_SOURCE */
46 
47 #if defined(__GNUC__) && __GNUC__ >= 4 && !defined(__MINGW32__)
48 #pragma GCC visibility push(hidden)
49 #endif
50 
51 #ifdef __cplusplus
52 extern "C"
53 {
54 #if 0
55 }
56 #endif
57 #endif
58 
65 {
66  const char *freetds_version; /* release version of FreeTDS */
67  const char *sysconfdir; /* location of freetds.conf */
68  const char *last_update; /* latest software_version date among the modules */
69  int msdblib; /* for MS style dblib */
70  int sybase_compat; /* enable increased Open Client binary compatibility */
71  int threadsafe; /* compile for thread safety default=no */
72  int libiconv; /* search for libiconv in DIR/include and DIR/lib */
73  const char *tdsver; /* TDS protocol version (4.2/4.6/5.0/7.0/8.0) 5.0 */
74  int iodbc; /* build odbc driver against iODBC in DIR */
75  int unixodbc; /* build odbc driver against unixODBC in DIR */
76 
78 
79 typedef struct tds_dstr {
80  char *dstr_s;
81  size_t dstr_size;
82 } DSTR;
83 
99 /*
100  * All references to data that touch the wire should use the following typedefs.
101  *
102  * If you have problems on 64-bit machines and the code is
103  * using a native datatype, please change it to use
104  * these. (In the TDS layer only, the API layers have their
105  * own typedefs which equate to these).
106  */
107 typedef char TDS_CHAR; /* 8-bit char */
108 typedef unsigned char TDS_UCHAR; /* 8-bit uchar */
109 typedef unsigned char TDS_TINYINT; /* 8-bit unsigned */
110 typedef tds_sysdep_int16_type TDS_SMALLINT; /* 16-bit int */
111 typedef unsigned tds_sysdep_int16_type TDS_USMALLINT; /* 16-bit unsigned */
112 typedef tds_sysdep_int32_type TDS_INT; /* 32-bit int */
113 typedef unsigned tds_sysdep_int32_type TDS_UINT; /* 32-bit unsigned */
114 typedef tds_sysdep_real32_type TDS_REAL; /* 32-bit real */
115 typedef tds_sysdep_real64_type TDS_FLOAT; /* 64-bit real */
116 typedef tds_sysdep_int64_type TDS_INT8; /* 64-bit integer */
117 typedef unsigned tds_sysdep_int64_type TDS_UINT8; /* 64-bit unsigned */
118 typedef tds_sysdep_intptr_type TDS_INTPTR;
119 
120 typedef struct tdsnumeric
121 {
122  unsigned char precision;
123  unsigned char scale;
124  unsigned char array[33];
125 } TDS_NUMERIC;
126 
127 typedef struct tdsoldmoney
128 {
129  TDS_INT mnyhigh;
130  TDS_UINT mnylow;
131 } TDS_OLD_MONEY;
132 
133 typedef union tdsmoney
134 {
136  TDS_INT8 mny;
137 } TDS_MONEY;
138 
139 typedef struct tdsmoney4
140 {
141  TDS_INT mny4;
142 } TDS_MONEY4;
143 
144 typedef struct tdsdatetime
145 {
146  TDS_INT dtdays;
147  TDS_INT dttime;
148 } TDS_DATETIME;
149 
150 typedef struct tdsdatetime4
151 {
152  TDS_USMALLINT days;
153  TDS_USMALLINT minutes;
154 } TDS_DATETIME4;
155 
156 typedef struct tdsvarbinary
157 {
158  TDS_SMALLINT len;
159  TDS_CHAR array[256];
160 } TDS_VARBINARY;
161 typedef struct tdsvarchar
162 {
163  TDS_SMALLINT len;
164  TDS_CHAR array[256];
165 } TDS_VARCHAR;
166 
167 typedef struct tdsunique
168 {
169  TDS_UINT Data1;
170  TDS_USMALLINT Data2;
171  TDS_USMALLINT Data3;
172  TDS_UCHAR Data4[8];
173 } TDS_UNIQUE;
174 
176 typedef struct tdsdaterec
177 {
178  TDS_INT year;
179  TDS_INT quarter;
180  TDS_INT month;
181  TDS_INT day;
182  TDS_INT dayofyear;
183  TDS_INT week;
184  TDS_INT weekday;
185  TDS_INT hour;
186  TDS_INT minute;
187  TDS_INT second;
188  TDS_INT millisecond;
189  TDS_INT tzone;
190 } TDSDATEREC;
191 
197 extern const int tds_numeric_bytes_per_prec[];
198 
199 #define TDS_SUCCEED 1
200 #define TDS_FAIL 0
201 #define TDS_NO_MORE_RESULTS 2
202 #define TDS_CANCELLED 3
203 
204 #define TDS_INT_CONTINUE 1
205 #define TDS_INT_CANCEL 2
206 #define TDS_INT_TIMEOUT 3
207 
208 
209 #define TDS_NO_COUNT -1
210 
211 #define TDS_ROW_RESULT 4040
212 #define TDS_PARAM_RESULT 4042
213 #define TDS_STATUS_RESULT 4043
214 #define TDS_MSG_RESULT 4044
215 #define TDS_COMPUTE_RESULT 4045
216 #define TDS_CMD_DONE 4046
217 #define TDS_CMD_SUCCEED 4047
218 #define TDS_CMD_FAIL 4048
219 #define TDS_ROWFMT_RESULT 4049
220 #define TDS_COMPUTEFMT_RESULT 4050
221 #define TDS_DESCRIBE_RESULT 4051
222 #define TDS_DONE_RESULT 4052
223 #define TDS_DONEPROC_RESULT 4053
224 #define TDS_DONEINPROC_RESULT 4054
225 #define TDS_OTHERS_RESULT 4055
226 
227 enum tds_token_results
228 {
229  TDS_TOKEN_RES_OTHERS,
230  TDS_TOKEN_RES_ROWFMT,
231  TDS_TOKEN_RES_COMPUTEFMT,
232  TDS_TOKEN_RES_PARAMFMT,
233  TDS_TOKEN_RES_DONE,
234  TDS_TOKEN_RES_ROW,
235  TDS_TOKEN_RES_COMPUTE,
236  TDS_TOKEN_RES_PROC,
237  TDS_TOKEN_RES_MSG
238 };
239 
240 #define TDS_TOKEN_FLAG(flag) TDS_RETURN_##flag = (1 << (TDS_TOKEN_RES_##flag*2)), TDS_STOPAT_##flag = (2 << (TDS_TOKEN_RES_##flag*2))
241 
242 enum tds_token_flags
243 {
244  TDS_HANDLE_ALL = 0,
245  TDS_TOKEN_FLAG(OTHERS),
246  TDS_TOKEN_FLAG(ROWFMT),
247  TDS_TOKEN_FLAG(COMPUTEFMT),
248  TDS_TOKEN_FLAG(PARAMFMT),
249  TDS_TOKEN_FLAG(DONE),
250  TDS_TOKEN_FLAG(ROW),
251  TDS_TOKEN_FLAG(COMPUTE),
252  TDS_TOKEN_FLAG(PROC),
253  TDS_TOKEN_FLAG(MSG),
254  TDS_TOKEN_RESULTS = TDS_RETURN_ROWFMT|TDS_RETURN_COMPUTEFMT|TDS_RETURN_DONE|TDS_STOPAT_ROW|TDS_STOPAT_COMPUTE|TDS_RETURN_PROC,
255  TDS_TOKEN_TRAILING = TDS_STOPAT_ROWFMT|TDS_STOPAT_COMPUTEFMT|TDS_STOPAT_ROW|TDS_STOPAT_COMPUTE|TDS_STOPAT_MSG|TDS_STOPAT_OTHERS
256 };
257 
262 {
265  , TDS_DONE_ERROR = 0x02
266  , TDS_DONE_INXACT = 0x04
267  , TDS_DONE_PROC = 0x08
268  , TDS_DONE_COUNT = 0x10
270  , TDS_DONE_EVENT = 0x40 /* part of an event notification. */
271  , TDS_DONE_SRVERROR = 0x100
273  /* after the above flags, a TDS_DONE packet has a field describing the state of the transaction */
274  , TDS_DONE_NO_TRAN = 0 /* No transaction in effect */
275  , TDS_DONE_TRAN_SUCCEED = 1 /* Transaction completed successfully */
276  , TDS_DONE_TRAN_PROGRESS= 2 /* Transaction in progress */
277  , TDS_DONE_STMT_ABORT = 3 /* A statement aborted */
278  , TDS_DONE_TRAN_ABORT = 4 /* Transaction aborted */
279 };
280 
281 
282 /*
283  * TDSERRNO is emitted by libtds to the client library's error handler
284  * (which may in turn call the client's error handler).
285  * These match the db-lib msgno, because the same values have the same meaning
286  * in db-lib and ODBC. ct-lib maps them to ct-lib numbers (todo).
287  */
288 typedef enum { TDSEOK = TDS_SUCCEED,
289  TDSEVERDOWN = 100,
290  TDSEICONVIU = 2400,
291  TDSEICONVAVAIL = 2401,
292  TDSEICONVO = 2402,
293  TDSEICONVI = 2403,
294  TDSEICONV2BIG = 2404,
295  TDSEPORTINSTANCE = 2500,
296  TDSESYNC = 20001,
297  TDSEFCON = 20002,
298  TDSETIME = 20003,
299  TDSEREAD = 20004,
300  TDSEWRIT = 20006,
301  TDSESOCK = 20008,
302  TDSECONN = 20009,
303  TDSEMEM = 20010,
304  TDSEINTF = 20012, /* Server name not found in interface file */
305  TDSEUHST = 20013, /* Unknown host machine name. */
306  TDSEPWD = 20014,
307  TDSESEOF = 20017,
308  TDSERPND = 20019,
309  TDSEBTOK = 20020,
310  TDSEOOB = 20022,
311  TDSECLOS = 20056,
312  TDSEUSCT = 20058,
313  TDSEUTDS = 20146,
314  TDSEEUNR = 20185,
315  TDSECAP = 20203,
316  TDSENEG = 20210,
317  TDSEUMSG = 20212,
318  TDSECAPTYP = 20213,
319  TDSEBPROBADTYP = 20250,
320  TDSECLOSEIN = 20292
321 } TDSERRNO;
322 
323 #define TDS5_PARAMFMT2_TOKEN 32 /* 0x20 */
324 #define TDS_LANGUAGE_TOKEN 33 /* 0x21 TDS 5.0 only */
325 #define TDS_ORDERBY2_TOKEN 34 /* 0x22 */
326 #define TDS_ROWFMT2_TOKEN 97 /* 0x61 TDS 5.0 only */
327 #define TDS_LOGOUT_TOKEN 113 /* 0x71 TDS 5.0 only? ct_close() */
328 #define TDS_RETURNSTATUS_TOKEN 121 /* 0x79 */
329 #define TDS_PROCID_TOKEN 124 /* 0x7C TDS 4.2 only - TDS_PROCID */
330 #define TDS7_RESULT_TOKEN 129 /* 0x81 TDS 7.0 only */
331 #define TDS7_COMPUTE_RESULT_TOKEN 136 /* 0x88 TDS 7.0 only */
332 #define TDS_COLNAME_TOKEN 160 /* 0xA0 TDS 4.2 only */
333 #define TDS_COLFMT_TOKEN 161 /* 0xA1 TDS 4.2 only - TDS_COLFMT */
334 #define TDS_DYNAMIC2_TOKEN 163 /* 0xA3 */
335 #define TDS_TABNAME_TOKEN 164 /* 0xA4 */
336 #define TDS_COLINFO_TOKEN 165 /* 0xA5 */
337 #define TDS_OPTIONCMD_TOKEN 166 /* 0xA6 */
338 #define TDS_COMPUTE_NAMES_TOKEN 167 /* 0xA7 */
339 #define TDS_COMPUTE_RESULT_TOKEN 168 /* 0xA8 */
340 #define TDS_ORDERBY_TOKEN 169 /* 0xA9 TDS_ORDER */
341 #define TDS_ERROR_TOKEN 170 /* 0xAA */
342 #define TDS_INFO_TOKEN 171 /* 0xAB */
343 #define TDS_PARAM_TOKEN 172 /* 0xAC RETURNVALUE? */
344 #define TDS_LOGINACK_TOKEN 173 /* 0xAD */
345 #define TDS_CONTROL_TOKEN 174 /* 0xAE TDS_CONTROL */
346 #define TDS_ROW_TOKEN 209 /* 0xD1 */
347 #define TDS_NBC_ROW_TOKEN 210 /* 0xD2 as of TDS 7.3.B */ /* not implemented */
348 #define TDS_CMP_ROW_TOKEN 211 /* 0xD3 */
349 #define TDS5_PARAMS_TOKEN 215 /* 0xD7 TDS 5.0 only */
350 #define TDS_CAPABILITY_TOKEN 226 /* 0xE2 */
351 #define TDS_ENVCHANGE_TOKEN 227 /* 0xE3 */
352 #define TDS_EED_TOKEN 229 /* 0xE5 */
353 #define TDS_DBRPC_TOKEN 230 /* 0xE6 */
354 #define TDS5_DYNAMIC_TOKEN 231 /* 0xE7 TDS 5.0 only */
355 #define TDS5_PARAMFMT_TOKEN 236 /* 0xEC TDS 5.0 only */
356 #define TDS_AUTH_TOKEN 237 /* 0xED TDS 7.0 only */
357 #define TDS_RESULT_TOKEN 238 /* 0xEE */
358 #define TDS_DONE_TOKEN 253 /* 0xFD TDS_DONE */
359 #define TDS_DONEPROC_TOKEN 254 /* 0xFE TDS_DONEPROC */
360 #define TDS_DONEINPROC_TOKEN 255 /* 0xFF TDS_DONEINPROC */
361 
362 /* CURSOR support: TDS 5.0 only*/
363 #define TDS_CURCLOSE_TOKEN 128 /* 0x80 TDS 5.0 only */
364 #define TDS_CURDELETE_TOKEN 129 /* 0x81 TDS 5.0 only */
365 #define TDS_CURFETCH_TOKEN 130 /* 0x82 TDS 5.0 only */
366 #define TDS_CURINFO_TOKEN 131 /* 0x83 TDS 5.0 only */
367 #define TDS_CUROPEN_TOKEN 132 /* 0x84 TDS 5.0 only */
368 #define TDS_CURDECLARE_TOKEN 134 /* 0x86 TDS 5.0 only */
369 
370 enum {
371  TDS_CUR_ISTAT_UNUSED = 0x00,
372  TDS_CUR_ISTAT_DECLARED = 0x01,
373  TDS_CUR_ISTAT_OPEN = 0x02,
374  TDS_CUR_ISTAT_CLOSED = 0x04,
375  TDS_CUR_ISTAT_RDONLY = 0x08,
376  TDS_CUR_ISTAT_UPDATABLE = 0x10,
377  TDS_CUR_ISTAT_ROWCNT = 0x20,
378  TDS_CUR_ISTAT_DEALLOC = 0x40
379 };
380 
381 /* http://jtds.sourceforge.net/apiCursors.html */
382 /* Cursor scroll option, must be one of 0x01 - 0x10, OR'd with other bits */
383 enum {
384  TDS_CUR_TYPE_KEYSET = 0x0001, /* default */
385  TDS_CUR_TYPE_DYNAMIC = 0x0002,
386  TDS_CUR_TYPE_FORWARD = 0x0004,
387  TDS_CUR_TYPE_STATIC = 0x0008,
388  TDS_CUR_TYPE_FASTFORWARDONLY = 0x0010,
389  TDS_CUR_TYPE_PARAMETERIZED = 0x1000,
390  TDS_CUR_TYPE_AUTO_FETCH = 0x2000
391 };
392 
393 enum {
394  TDS_CUR_CONCUR_READ_ONLY = 1,
395  TDS_CUR_CONCUR_SCROLL_LOCKS = 2,
396  TDS_CUR_CONCUR_OPTIMISTIC = 4, /* default */
397  TDS_CUR_CONCUR_OPTIMISTIC_VALUES = 8
398 };
399 
400 /* environment type field */
401 #define TDS_ENV_DATABASE 1
402 #define TDS_ENV_LANG 2
403 #define TDS_ENV_CHARSET 3
404 #define TDS_ENV_PACKSIZE 4
405 #define TDS_ENV_LCID 5
406 #define TDS_ENV_SQLCOLLATION 7
407 #define TDS_ENV_BEGINTRANS 8
408 #define TDS_ENV_COMMITTRANS 9
409 #define TDS_ENV_ROLLBACKTRANS 10
410 
411 /* string types */
412 #define TDS_NULLTERM -9
413 
414 /* Microsoft internal stored procedure id's */
415 
416 #define TDS_SP_CURSOR 1
417 #define TDS_SP_CURSOROPEN 2
418 #define TDS_SP_CURSORPREPARE 3
419 #define TDS_SP_CURSOREXECUTE 4
420 #define TDS_SP_CURSORPREPEXEC 5
421 #define TDS_SP_CURSORUNPREPARE 6
422 #define TDS_SP_CURSORFETCH 7
423 #define TDS_SP_CURSOROPTION 8
424 #define TDS_SP_CURSORCLOSE 9
425 #define TDS_SP_EXECUTESQL 10
426 #define TDS_SP_PREPARE 11
427 #define TDS_SP_EXECUTE 12
428 #define TDS_SP_PREPEXEC 13
429 #define TDS_SP_PREPEXECRPC 14
430 #define TDS_SP_UNPREPARE 15
431 /*
432  * <rant> Sybase does an awful job of this stuff, non null ints of size 1 2
433  * and 4 have there own codes but nullable ints are lumped into INTN
434  * sheesh! </rant>
435  */
436 typedef enum
437 {
438  SYBCHAR = 47, /* 0x2F */
439 #define SYBCHAR SYBCHAR
440  SYBVARCHAR = 39, /* 0x27 */
441 #define SYBVARCHAR SYBVARCHAR
442  SYBINTN = 38, /* 0x26 */
443 #define SYBINTN SYBINTN
444  SYBINT1 = 48, /* 0x30 */
445 #define SYBINT1 SYBINT1
446  SYBINT2 = 52, /* 0x34 */
447 #define SYBINT2 SYBINT2
448  SYBINT4 = 56, /* 0x38 */
449 #define SYBINT4 SYBINT4
450  SYBFLT8 = 62, /* 0x3E */
451 #define SYBFLT8 SYBFLT8
452  SYBDATETIME = 61, /* 0x3D */
453 #define SYBDATETIME SYBDATETIME
454  SYBBIT = 50, /* 0x32 */
455 #define SYBBIT SYBBIT
456  SYBTEXT = 35, /* 0x23 */
457 #define SYBTEXT SYBTEXT
458  SYBNTEXT = 99, /* 0x63 */
459 #define SYBNTEXT SYBNTEXT
460  SYBIMAGE = 34, /* 0x22 */
461 #define SYBIMAGE SYBIMAGE
462  SYBMONEY4 = 122, /* 0x7A */
463 #define SYBMONEY4 SYBMONEY4
464  SYBMONEY = 60, /* 0x3C */
465 #define SYBMONEY SYBMONEY
466  SYBDATETIME4 = 58, /* 0x3A */
467 #define SYBDATETIME4 SYBDATETIME4
468  SYBREAL = 59, /* 0x3B */
469 #define SYBREAL SYBREAL
470  SYBBINARY = 45, /* 0x2D */
471 #define SYBBINARY SYBBINARY
472  SYBVOID = 31, /* 0x1F */
473 #define SYBVOID SYBVOID
474  SYBVARBINARY = 37, /* 0x25 */
475 #define SYBVARBINARY SYBVARBINARY
476  SYBBITN = 104, /* 0x68 */
477 #define SYBBITN SYBBITN
478  SYBNUMERIC = 108, /* 0x6C */
479 #define SYBNUMERIC SYBNUMERIC
480  SYBDECIMAL = 106, /* 0x6A */
481 #define SYBDECIMAL SYBDECIMAL
482  SYBFLTN = 109, /* 0x6D */
483 #define SYBFLTN SYBFLTN
484  SYBMONEYN = 110, /* 0x6E */
485 #define SYBMONEYN SYBMONEYN
486  SYBDATETIMN = 111, /* 0x6F */
487 #define SYBDATETIMN SYBDATETIMN
488 
489 /*
490  * MS only types
491  */
492  SYBNVARCHAR = 103, /* 0x67 */
493 #define SYBNVARCHAR SYBNVARCHAR
494  SYBINT8 = 127, /* 0x7F */
495 #define SYBINT8 SYBINT8
496  XSYBCHAR = 175, /* 0xAF */
497 #define XSYBCHAR XSYBCHAR
498  XSYBVARCHAR = 167, /* 0xA7 */
499 #define XSYBVARCHAR XSYBVARCHAR
500  XSYBNVARCHAR = 231, /* 0xE7 */
501 #define XSYBNVARCHAR XSYBNVARCHAR
502  XSYBNCHAR = 239, /* 0xEF */
503 #define XSYBNCHAR XSYBNCHAR
504  XSYBVARBINARY = 165, /* 0xA5 */
505 #define XSYBVARBINARY XSYBVARBINARY
506  XSYBBINARY = 173, /* 0xAD */
507 #define XSYBBINARY XSYBBINARY
508  SYBUNIQUE = 36, /* 0x24 */
509 #define SYBUNIQUE SYBUNIQUE
510  SYBVARIANT = 98, /* 0x62 */
511 #define SYBVARIANT SYBVARIANT
512  SYBMSUDT = 240, /* 0xF0 */
513 #define SYBMSUDT SYBMSUDT
514  SYBMSXML = 241, /* 0xF1 */
515 #define SYBMSXML SYBMSXML
516 
517 /*
518  * Sybase only types
519  */
520  SYBLONGBINARY = 225, /* 0xE1 */
521 #define SYBLONGBINARY SYBLONGBINARY
522  SYBUINT1 = 64, /* 0x40 */
523 #define SYBUINT1 SYBUINT1
524  SYBUINT2 = 65, /* 0x41 */
525 #define SYBUINT2 SYBUINT2
526  SYBUINT4 = 66, /* 0x42 */
527 #define SYBUINT4 SYBUINT4
528  SYBUINT8 = 67, /* 0x43 */
529 #define SYBUINT8 SYBUINT8
530  SYBBLOB = 36, /* 0x24 */
531 #define SYBBLOB SYBBLOB
532  SYBBOUNDARY = 104, /* 0x68 */
533 #define SYBBOUNDARY SYBBOUNDARY
534  SYBDATE = 49, /* 0x31 */
535 #define SYBDATE SYBDATE
536  SYBDATEN = 123, /* 0x7B */
537 #define SYBDATEN SYBDATEN
538  SYB5INT8 = 191, /* 0xBF */
539 #define SYB5INT8 SYB5INT8
540  SYBINTERVAL = 46, /* 0x2E */
541 #define SYBINTERVAL SYBINTERVAL
542  SYBLONGCHAR = 175, /* 0xAF */
543 #define SYBLONGCHAR SYBLONGCHAR
544  SYBSENSITIVITY = 103, /* 0x67 */
545 #define SYBSENSITIVITY SYBSENSITIVITY
546  SYBSINT1 = 176, /* 0xB0 */
547 #define SYBSINT1 SYBSINT1
548  SYBTIME = 51, /* 0x33 */
549 #define SYBTIME SYBTIME
550  SYBTIMEN = 147, /* 0x93 */
551 #define SYBTIMEN SYBTIMEN
552  SYBUINTN = 68, /* 0x44 */
553 #define SYBUINTN SYBUINTN
554  SYBUNITEXT = 174, /* 0xAE */
555 #define SYBUNITEXT SYBUNITEXT
556  SYBXML = 163, /* 0xA3 */
557 #define SYBXML SYBXML
558 
559 } TDS_SERVER_TYPE;
560 
561 
562 typedef enum
563 {
564  USER_UNICHAR_TYPE = 34, /* 0x22 */
565  USER_UNIVARCHAR_TYPE = 35 /* 0x23 */
566 } TDS_USER_TYPE;
567 
568 #define SYBAOPCNT 0x4b
569 #define SYBAOPCNTU 0x4c
570 #define SYBAOPSUM 0x4d
571 #define SYBAOPSUMU 0x4e
572 #define SYBAOPAVG 0x4f
573 #define SYBAOPAVGU 0x50
574 #define SYBAOPMIN 0x51
575 #define SYBAOPMAX 0x52
576 
577 /* mssql2k compute operator */
578 #define SYBAOPCNT_BIG 0x09
579 #define SYBAOPSTDEV 0x30
580 #define SYBAOPSTDEVP 0x31
581 #define SYBAOPVAR 0x32
582 #define SYBAOPVARP 0x33
583 #define SYBAOPCHECKSUM_AGG 0x72
584 
585 
589 typedef enum
590 {
591  TDS_OPT_SET = 1 /* Set an option. */
592  , TDS_OPT_DEFAULT = 2 /* Set option to its default value. */
593  , TDS_OPT_LIST = 3 /* Request current setting of a specific option. */
594  , TDS_OPT_INFO = 4 /* Report current setting of a specific option. */
596 
597 typedef enum
598 {
599  TDS_OPT_DATEFIRST = 1 /* 0x01 */
600  , TDS_OPT_TEXTSIZE = 2 /* 0x02 */
601  , TDS_OPT_STAT_TIME = 3 /* 0x03 */
602  , TDS_OPT_STAT_IO = 4 /* 0x04 */
603  , TDS_OPT_ROWCOUNT = 5 /* 0x05 */
604  , TDS_OPT_NATLANG = 6 /* 0x06 */
605  , TDS_OPT_DATEFORMAT = 7 /* 0x07 */
606  , TDS_OPT_ISOLATION = 8 /* 0x08 */
607  , TDS_OPT_AUTHON = 9 /* 0x09 */
608  , TDS_OPT_CHARSET = 10 /* 0x0a */
609  , TDS_OPT_SHOWPLAN = 13 /* 0x0d */
610  , TDS_OPT_NOEXEC = 14 /* 0x0e */
611  , TDS_OPT_ARITHIGNOREON = 15 /* 0x0f */
612  , TDS_OPT_ARITHABORTON = 17 /* 0x11 */
613  , TDS_OPT_PARSEONLY = 18 /* 0x12 */
614  , TDS_OPT_GETDATA = 20 /* 0x14 */
615  , TDS_OPT_NOCOUNT = 21 /* 0x15 */
616  , TDS_OPT_FORCEPLAN = 23 /* 0x17 */
617  , TDS_OPT_FORMATONLY = 24 /* 0x18 */
618  , TDS_OPT_CHAINXACTS = 25 /* 0x19 */
619  , TDS_OPT_CURCLOSEONXACT = 26 /* 0x1a */
620  , TDS_OPT_FIPSFLAG = 27 /* 0x1b */
621  , TDS_OPT_RESTREES = 28 /* 0x1c */
622  , TDS_OPT_IDENTITYON = 29 /* 0x1d */
623  , TDS_OPT_CURREAD = 30 /* 0x1e */
624  , TDS_OPT_CURWRITE = 31 /* 0x1f */
625  , TDS_OPT_IDENTITYOFF = 32 /* 0x20 */
626  , TDS_OPT_AUTHOFF = 33 /* 0x21 */
627  , TDS_OPT_ANSINULL = 34 /* 0x22 */
628  , TDS_OPT_QUOTED_IDENT = 35 /* 0x23 */
629  , TDS_OPT_ARITHIGNOREOFF = 36 /* 0x24 */
630  , TDS_OPT_ARITHABORTOFF = 37 /* 0x25 */
631  , TDS_OPT_TRUNCABORT = 38 /* 0x26 */
632 } TDS_OPTION;
633 
634 typedef union tds_option_arg
635 {
636  TDS_TINYINT ti;
637  TDS_INT i;
638  TDS_CHAR *c;
640 
641 enum {
642  TDS_OPT_ARITHOVERFLOW = 0x01,
643  TDS_OPT_NUMERICTRUNC = 0x02
644 };
645 
646 enum TDS_OPT_DATEFIRST_CHOICE
647 {
648  TDS_OPT_MONDAY = 1, TDS_OPT_TUESDAY = 2, TDS_OPT_WEDNESDAY = 3, TDS_OPT_THURSDAY = 4, TDS_OPT_FRIDAY = 5, TDS_OPT_SATURDAY =
649  6, TDS_OPT_SUNDAY = 7
650 };
651 
652 enum TDS_OPT_DATEFORMAT_CHOICE
653 {
654  TDS_OPT_FMTMDY = 1, TDS_OPT_FMTDMY = 2, TDS_OPT_FMTYMD = 3, TDS_OPT_FMTYDM = 4, TDS_OPT_FMTMYD = 5, TDS_OPT_FMTDYM = 6
655 };
656 enum TDS_OPT_ISOLATION_CHOICE
657 {
658  TDS_OPT_LEVEL1 = 1, TDS_OPT_LEVEL3 = 3
659 };
660 
661 typedef enum tds_packet_type
662 {
663  TDS_QUERY = 1,
664  TDS_LOGIN = 2,
665  TDS_RPC = 3,
666  TDS_REPLY = 4,
667  TDS_CANCEL = 6,
668  TDS_BULK = 7,
669  TDS_NORMAL = 15,
670  TDS7_LOGIN = 16,
671  TDS7_AUTH = 17,
672  TDS8_PRELOGIN = 18
673 } TDS_PACKET_TYPE;
674 
675 typedef enum tds_encryption_level {
676  TDS_ENCRYPTION_OFF, TDS_ENCRYPTION_REQUEST, TDS_ENCRYPTION_REQUIRE
677 } TDS_ENCRYPTION_LEVEL;
678 
679 #define TDS_ZERO_FREE(x) do {free((x)); (x) = NULL;} while(0)
680 #define TDS_VECTOR_SIZE(x) (sizeof(x)/sizeof(x[0]))
681 
682 #if defined(__GNUC__) && __GNUC__ >= 3
683 # define TDS_LIKELY(x) __builtin_expect(!!(x), 1)
684 # define TDS_UNLIKELY(x) __builtin_expect(!!(x), 0)
685 #else
686 # define TDS_LIKELY(x) (x)
687 # define TDS_UNLIKELY(x) (x)
688 #endif
689 
690 /*
691  * TODO use system macros for optimization
692  * See mcrypt for reference and linux kernel source for optimization
693  * check if unaligned access and use fast write/read when implemented
694  */
695 #define TDS_BYTE_SWAP16(value) \
696  (((((unsigned short)value)<<8) & 0xFF00) | \
697  ((((unsigned short)value)>>8) & 0x00FF))
698 
699 #define TDS_BYTE_SWAP32(value) \
700  (((((unsigned long)value)<<24) & 0xFF000000) | \
701  ((((unsigned long)value)<< 8) & 0x00FF0000) | \
702  ((((unsigned long)value)>> 8) & 0x0000FF00) | \
703  ((((unsigned long)value)>>24) & 0x000000FF))
704 
705 #define is_end_token(x) (x==TDS_DONE_TOKEN || \
706  x==TDS_DONEPROC_TOKEN || \
707  x==TDS_DONEINPROC_TOKEN)
708 
709 #define is_hard_end_token(x) (x==TDS_DONE_TOKEN || \
710  x==TDS_DONEPROC_TOKEN)
711 
712 #define is_msg_token(x) (x==TDS_INFO_TOKEN || \
713  x==TDS_ERROR_TOKEN || \
714  x==TDS_EED_TOKEN)
715 
716 #define is_result_token(x) (x==TDS_RESULT_TOKEN || \
717  x==TDS_ROWFMT2_TOKEN || \
718  x==TDS7_RESULT_TOKEN || \
719  x==TDS_COLFMT_TOKEN || \
720  x==TDS_COLNAME_TOKEN || \
721  x==TDS_RETURNSTATUS_TOKEN)
722 
723 /* FIXME -- not a complete list */
724 #define is_fixed_type(x) (x==SYBINT1 || \
725  x==SYBINT2 || \
726  x==SYBINT4 || \
727  x==SYBINT8 || \
728  x==SYBREAL || \
729  x==SYBFLT8 || \
730  x==SYBDATETIME || \
731  x==SYBDATETIME4 || \
732  x==SYBBIT || \
733  x==SYBMONEY || \
734  x==SYBMONEY4 || \
735  x==SYBVOID || \
736  x==SYBUNIQUE)
737 #define is_nullable_type(x) ( \
738  x==SYBBITN || \
739  x==SYBINTN || \
740  x==SYBFLTN || \
741  x==SYBMONEYN || \
742  x==SYBDATETIMN || \
743  x==SYBVARCHAR || \
744  x==SYBBINARY || \
745  x==SYBVARBINARY || \
746  x==SYBTEXT || \
747  x==SYBNTEXT || \
748  x==SYBIMAGE)
749 
750 #define is_variable_type(x) ( \
751  (x)==SYBTEXT || \
752  (x)==SYBIMAGE || \
753  (x)==SYBNTEXT || \
754  (x)==SYBCHAR || \
755  (x)==SYBVARCHAR || \
756  (x)==SYBBINARY || \
757  (x)==SYBVARBINARY || \
758  (x)==SYBLONGBINARY || \
759  (x)==XSYBCHAR || \
760  (x)==XSYBVARCHAR || \
761  (x)==XSYBNVARCHAR || \
762  (x)==XSYBNCHAR)
763 
764 #define is_blob_type(x) (x==SYBTEXT || x==SYBIMAGE || x==SYBNTEXT)
765 #define is_blob_col(x) ((x)->column_varint_size > 2)
766 /* large type means it has a two byte size field */
767 /* define is_large_type(x) (x>128) */
768 #define is_numeric_type(x) (x==SYBNUMERIC || x==SYBDECIMAL)
769 #define is_unicode_type(x) (x==XSYBNVARCHAR || x==XSYBNCHAR || x==SYBNTEXT || x==SYBMSXML)
770 #define is_collate_type(x) (x==XSYBVARCHAR || x==XSYBCHAR || x==SYBTEXT || x==XSYBNVARCHAR || x==XSYBNCHAR || x==SYBNTEXT)
771 #define is_ascii_type(x) ( x==XSYBCHAR || x==XSYBVARCHAR || x==SYBTEXT || x==SYBCHAR || x==SYBVARCHAR)
772 #define is_char_type(x) (is_unicode_type(x) || is_ascii_type(x))
773 #define is_similar_type(x, y) ((is_char_type(x) && is_char_type(y)) || ((is_unicode_type(x) && is_unicode_type(y))))
774 
775 
776 #define TDS_MAX_CAPABILITY 22
777 #define MAXPRECISION 77
778 #define TDS_MAX_CONN 4096
779 #define TDS_MAX_DYNID_LEN 30
780 
781 /* defaults to use if no others are found */
782 #define TDS_DEF_SERVER "SYBASE"
783 #define TDS_DEF_BLKSZ 512
784 #define TDS_DEF_CHARSET "iso_1"
785 #define TDS_DEF_LANG "us_english"
786 #if TDS42
787 #define TDS_DEFAULT_VERSION 0x402
788 #define TDS_DEF_PORT 1433
789 #elif TDS46
790 #define TDS_DEFAULT_VERSION 0x406
791 #define TDS_DEF_PORT 4000
792 #elif TDS70
793 #define TDS_DEFAULT_VERSION 0x700
794 #define TDS_DEF_PORT 1433
795 #elif TDS71
796 #define TDS_DEFAULT_VERSION 0x701
797 #define TDS_DEF_PORT 1433
798 #elif TDS72
799 #define TDS_DEFAULT_VERSION 0x702
800 #define TDS_DEF_PORT 1433
801 #else
802 #define TDS_DEFAULT_VERSION 0x500
803 #define TDS_DEF_PORT 4000
804 #endif
805 
806 /* normalized strings from freetds.conf file */
807 #define TDS_STR_VERSION "tds version"
808 #define TDS_STR_BLKSZ "initial block size"
809 #define TDS_STR_SWAPDT "swap broken dates"
810 #define TDS_STR_DUMPFILE "dump file"
811 #define TDS_STR_DEBUGLVL "debug level"
812 #define TDS_STR_DEBUGFLAGS "debug flags"
813 #define TDS_STR_TIMEOUT "timeout"
814 #define TDS_STR_QUERY_TIMEOUT "query timeout"
815 #define TDS_STR_CONNTIMEOUT "connect timeout"
816 #define TDS_STR_HOSTNAME "hostname"
817 #define TDS_STR_HOST "host"
818 #define TDS_STR_PORT "port"
819 #define TDS_STR_TEXTSZ "text size"
820 /* for big endian hosts */
821 #define TDS_STR_EMUL_LE "emulate little endian"
822 #define TDS_STR_CHARSET "charset"
823 #define TDS_STR_CLCHARSET "client charset"
824 #define TDS_STR_LANGUAGE "language"
825 #define TDS_STR_APPENDMODE "dump file append"
826 #define TDS_STR_DATEFMT "date format"
827 #define TDS_STR_INSTANCE "instance"
828 #define TDS_STR_ASA_DATABASE "asa database"
829 #define TDS_STR_ENCRYPTION "encryption"
830 #define TDS_STR_USENTLMV2 "use ntlmv2"
831 /* conf values */
832 #define TDS_STR_ENCRYPTION_OFF "off"
833 #define TDS_STR_ENCRYPTION_REQUEST "request"
834 #define TDS_STR_ENCRYPTION_REQUIRE "require"
835 /* Defines to enable optional GSSAPI delegation */
836 #define TDS_GSSAPI_DELEGATION "enable gssapi delegation"
837 /* Kerberos realm name */
838 #define TDS_STR_REALM "realm"
839 
840 
841 /* TODO do a better check for alignment than this */
842 typedef union
843 {
844  void *p;
845  int i;
847 
848 #define TDS_ALIGN_SIZE sizeof(tds_align_struct)
849 
850 #define TDS_MAX_LOGIN_STR_SZ 30
851 typedef struct tds_login
852 {
853  DSTR server_name;
854  int port;
855  TDS_USMALLINT tds_version; /* TDS version */
856  int block_size;
857  DSTR language; /* e.g. us-english */
858  DSTR server_charset; /* e.g. iso_1 */
859  TDS_INT connect_timeout;
860  DSTR client_host_name;
861  DSTR app_name;
862  DSTR user_name;
863  DSTR password;
864 
865  DSTR library; /* Ct-Library, DB-Library, TDS-Library or ODBC */
866  TDS_TINYINT encryption_level;
867 
868  TDS_INT query_timeout;
869  unsigned char capabilities[TDS_MAX_CAPABILITY];
870  DSTR client_charset;
871  DSTR database;
872  unsigned int bulk_copy:1;
873  unsigned int suppress_language:1;
874 } TDSLOGIN;
875 
876 typedef struct tds_connection
877 {
878  /* first part of structure is the same of login one */
880  int port;
881  TDS_USMALLINT tds_version;
882  int block_size;
883  DSTR language;
885  TDS_INT connect_timeout;
886  DSTR client_host_name;
887  DSTR server_host_name;
889  DSTR app_name;
892  DSTR library;
893  TDS_TINYINT encryption_level;
894 
895  TDS_INT query_timeout;
896  unsigned char capabilities[TDS_MAX_CAPABILITY];
897  unsigned char option_flag2;
898  DSTR client_charset;
899 
901  DSTR instance_name;
902  DSTR database;
903  DSTR dump_file;
904  int debug_flags;
905  int text_size;
906  unsigned int broken_dates:1;
907  unsigned int emul_little_endian:1;
908  unsigned int bulk_copy:1;
909  unsigned int suppress_language:1;
910  unsigned int gssapi_use_delegation:1;
911  unsigned int use_ntlmv2:1;
912 } TDSCONNECTION;
913 
914 typedef struct tds_locale
915 {
916  char *language;
917  char *server_charset;
918  char *date_fmt;
919 } TDSLOCALE;
920 
925 typedef struct tds_blob
926 {
927  TDS_CHAR *textvalue;
928  TDS_CHAR textptr[16];
929  TDS_CHAR timestamp[8];
930 } TDSBLOB;
931 
935 typedef struct tds_variant
936 {
937  /* this MUST have same position and place of textvalue in tds_blob */
938  TDS_CHAR *data;
939  TDS_INT size;
940  TDS_INT data_len;
941  TDS_UCHAR type;
942  TDS_UCHAR collation[5];
943 } TDSVARIANT;
944 
948 typedef struct
949 {
950  TDS_USMALLINT locale_id; /* master..syslanguages.lcid */
951  TDS_USMALLINT flags;
952  TDS_UCHAR charset_id; /* or zero */
954 
955 /* SF stands for "sort flag" */
956 #define TDS_SF_BIN (TDS_USMALLINT) 0x100
957 #define TDS_SF_WIDTH_INSENSITIVE (TDS_USMALLINT) 0x080
958 #define TDS_SF_KATATYPE_INSENSITIVE (TDS_USMALLINT) 0x040
959 #define TDS_SF_ACCENT_SENSITIVE (TDS_USMALLINT) 0x020
960 #define TDS_SF_CASE_INSENSITIVE (TDS_USMALLINT) 0x010
961 
962 /* UT stands for user type */
963 #define TDS_UT_TIMESTAMP 80
964 
965 
970 typedef struct tds_encoding
971 {
972  const char *name;
973  unsigned char min_bytes_per_char;
974  unsigned char max_bytes_per_char;
975  unsigned char canonic;
976 } TDS_ENCODING;
977 
978 typedef struct tds_bcpcoldata
979 {
980  TDS_UCHAR *data;
981  TDS_INT datalen;
982  TDS_INT is_null;
983 } BCPCOLDATA;
984 
985 
986 enum
987 { TDS_SYSNAME_SIZE = 512 };
988 
992 typedef struct tds_column
993 {
994  TDS_SMALLINT column_type;
999  TDS_INT column_usertype;
1000  TDS_INT column_flags;
1001 
1002  TDS_INT column_size;
1004  TDS_TINYINT column_varint_size;
1006  TDS_TINYINT column_prec;
1007  TDS_TINYINT column_scale;
1009  TDS_SMALLINT column_namelen;
1010  TDS_SMALLINT table_namelen;
1011  struct
1012  {
1013  TDS_SMALLINT column_type;
1014  TDS_INT column_size;
1015  } on_server;
1016 
1019  TDS_CHAR table_name[TDS_SYSNAME_SIZE];
1020  TDS_CHAR column_name[TDS_SYSNAME_SIZE];
1021  char * table_column_name;
1022 
1023  unsigned char *column_data;
1024  void (*column_data_free)(struct tds_column *column);
1025  unsigned int column_nullable:1;
1026  unsigned int column_writeable:1;
1027  unsigned int column_identity:1;
1028  unsigned int column_key:1;
1029  unsigned int column_hidden:1;
1030  unsigned int column_output:1;
1031  unsigned int column_timestamp:1;
1032  TDS_UCHAR column_collation[5];
1033 
1034  /* additional fields flags for compute results */
1035  TDS_TINYINT column_operator;
1036  TDS_SMALLINT column_operand;
1037 
1038  /* FIXME this is data related, not column */
1041 
1042  /* related to binding or info stored by client libraries */
1043  /* FIXME find a best place to store these data, some are unused */
1044  TDS_SMALLINT column_bindtype;
1045  TDS_SMALLINT column_bindfmt;
1046  TDS_UINT column_bindlen;
1047  TDS_SMALLINT *column_nullbind;
1048  TDS_CHAR *column_varaddr;
1049  TDS_INT *column_lenbind;
1050  TDS_INT column_textpos;
1051  TDS_INT column_text_sqlgetdatapos;
1052  TDS_CHAR column_text_sqlputdatainfo;
1053 
1054  BCPCOLDATA *bcp_column_data;
1064  TDS_INT bcp_term_len;
1065  TDS_CHAR *bcp_terminator;
1066 } TDSCOLUMN;
1067 
1068 
1070 typedef struct tds_result_info
1071 {
1072  /* TODO those fields can became a struct */
1073  TDS_SMALLINT num_cols;
1074  TDSCOLUMN **columns;
1075  TDS_INT row_size;
1076  TDS_INT ref_count;
1077  unsigned char *current_row;
1078  void (*row_free)(struct tds_result_info* result, unsigned char *row);
1079 
1080  TDS_SMALLINT rows_exist;
1081  /* TODO remove ?? used only in dblib */
1082  TDS_INT row_count;
1083  /* TODO remove ?? used only in dblib */
1084  TDS_TINYINT more_results;
1085  TDS_SMALLINT computeid;
1086  TDS_SMALLINT *bycolumns;
1087  TDS_SMALLINT by_cols;
1088 } TDSRESULTINFO;
1089 
1091 typedef enum _TDS_STATE
1092 {
1098 } TDS_STATE;
1099 
1100 #define TDS_DBG_LOGIN __FILE__, ((__LINE__ << 4) | 11)
1101 #define TDS_DBG_HEADER __FILE__, ((__LINE__ << 4) | 10)
1102 #define TDS_DBG_FUNC __FILE__, ((__LINE__ << 4) | 7)
1103 #define TDS_DBG_INFO2 __FILE__, ((__LINE__ << 4) | 6)
1104 #define TDS_DBG_INFO1 __FILE__, ((__LINE__ << 4) | 5)
1105 #define TDS_DBG_NETWORK __FILE__, ((__LINE__ << 4) | 4)
1106 #define TDS_DBG_WARN __FILE__, ((__LINE__ << 4) | 3)
1107 #define TDS_DBG_ERROR __FILE__, ((__LINE__ << 4) | 2)
1108 #define TDS_DBG_SEVERE __FILE__, ((__LINE__ << 4) | 1)
1109 
1110 #define TDS_DBGFLAG_FUNC 0x80
1111 #define TDS_DBGFLAG_INFO2 0x40
1112 #define TDS_DBGFLAG_INFO1 0x20
1113 #define TDS_DBGFLAG_NETWORK 0x10
1114 #define TDS_DBGFLAG_WARN 0x08
1115 #define TDS_DBGFLAG_ERROR 0x04
1116 #define TDS_DBGFLAG_SEVERE 0x02
1117 #define TDS_DBGFLAG_ALL 0xfff
1118 #define TDS_DBGFLAG_LOGIN 0x0800
1119 #define TDS_DBGFLAG_HEADER 0x0400
1120 #define TDS_DBGFLAG_PID 0x1000
1121 #define TDS_DBGFLAG_TIME 0x2000
1122 #define TDS_DBGFLAG_SOURCE 0x4000
1123 #define TDS_DBGFLAG_THREAD 0x8000
1124 
1125 #if 0
1126 
1131 enum TDS_DBG_LOG_STATE
1132 {
1133  TDS_DBG_LOGIN = (1 << 0)
1135  , TDS_DBG_API = (1 << 1)
1136  , TDS_DBG_ASYNC = (1 << 2)
1137  , TDS_DBG_DIAG = (1 << 3)
1138  , TDS_DBG_error = (1 << 4)
1139  /* TODO: ^^^^^ make upper case when old #defines (above) are removed */
1140  /* Log FreeTDS runtime/logic error occurs. */
1141  , TDS_DBG_PACKET = (1 << 5)
1142  , TDS_DBG_LIBTDS = (1 << 6)
1143  , TDS_DBG_CONFIG = (1 << 7)
1144  , TDS_DBG_DEFAULT = 0xFE
1145 };
1146 #endif
1147 
1148 typedef struct tds_result_info TDSCOMPUTEINFO;
1149 
1150 typedef TDSRESULTINFO TDSPARAMINFO;
1151 
1152 typedef struct tds_message
1153 {
1154  TDS_CHAR *server;
1155  TDS_CHAR *message;
1156  TDS_CHAR *proc_name;
1157  TDS_CHAR *sql_state;
1158  TDS_UINT msgno;
1159  TDS_INT line_number;
1160  /* -1 .. 255 */
1161  TDS_SMALLINT state;
1162  TDS_TINYINT priv_msg_type;
1163  TDS_TINYINT severity;
1164  /* for library-generated errors */
1165  int oserr;
1166 } TDSMESSAGE;
1167 
1168 typedef struct tds_upd_col
1169 {
1170  struct tds_upd_col *next;
1171  TDS_INT colnamelength;
1172  char * columnname;
1173 } TDSUPDCOL;
1174 
1175 typedef enum {
1176  TDS_CURSOR_STATE_UNACTIONED = 0 /* initial value */
1177  , TDS_CURSOR_STATE_REQUESTED = 1 /* called by ct_cursor */
1178  , TDS_CURSOR_STATE_SENT = 2 /* sent to server */
1179  , TDS_CURSOR_STATE_ACTIONED = 3 /* acknowledged by server */
1180 } TDS_CURSOR_STATE;
1181 
1182 typedef struct tds_cursor_status
1183 {
1184  TDS_CURSOR_STATE declare;
1185  TDS_CURSOR_STATE cursor_row;
1186  TDS_CURSOR_STATE open;
1187  TDS_CURSOR_STATE fetch;
1188  TDS_CURSOR_STATE close;
1189  TDS_CURSOR_STATE dealloc;
1191 
1192 typedef enum tds_cursor_operation
1193 {
1194  TDS_CURSOR_POSITION = 0,
1195  TDS_CURSOR_UPDATE = 1,
1196  TDS_CURSOR_DELETE = 2,
1197  TDS_CURSOR_INSERT = 4
1198 } TDS_CURSOR_OPERATION;
1199 
1200 typedef enum tds_cursor_fetch
1201 {
1202  TDS_CURSOR_FETCH_NEXT = 1,
1203  TDS_CURSOR_FETCH_PREV,
1204  TDS_CURSOR_FETCH_FIRST,
1205  TDS_CURSOR_FETCH_LAST,
1206  TDS_CURSOR_FETCH_ABSOLUTE,
1207  TDS_CURSOR_FETCH_RELATIVE
1208 } TDS_CURSOR_FETCH;
1209 
1213 typedef struct tds_cursor
1214 {
1215  struct tds_cursor *next;
1216  TDS_INT ref_count;
1217  TDS_TINYINT cursor_name_len;
1218  char *cursor_name;
1219  TDS_INT cursor_id;
1220  TDS_TINYINT options;
1221  TDS_TINYINT hasargs;
1222  TDS_USMALLINT query_len;
1223  char *query;
1224  /* TODO for updatable columns */
1225  /* TDS_TINYINT number_upd_cols; */
1226  /* TDSUPDCOL *cur_col_list; */
1227  TDS_INT cursor_rows;
1228  /* TDSPARAMINFO *params; */
1230  TDS_SMALLINT srv_status;
1231  TDSRESULTINFO *res_info;
1232  TDS_INT type, concurrency;
1233 } TDSCURSOR;
1234 
1238 typedef struct tds_env
1239 {
1240  int block_size;
1241  char *language;
1242  char *charset;
1243  char *database;
1244 } TDSENV;
1245 
1249 typedef struct tds_dynamic
1250 {
1251  struct tds_dynamic *next;
1257  char id[30];
1258  /* int dyn_state; */ /* TODO use it */
1260  TDS_INT num_id;
1277  char *query;
1278 } TDSDYNAMIC;
1279 
1280 typedef enum {
1281  TDS_MULTIPLE_QUERY,
1282  TDS_MULTIPLE_EXECUTE,
1283  TDS_MULTIPLE_RPC
1284 } TDS_MULTIPLE_TYPE;
1285 
1286 typedef struct tds_multiple
1287 {
1288  TDS_MULTIPLE_TYPE type;
1289  unsigned int flags;
1290 } TDSMULTIPLE;
1291 
1292 /* forward declaration */
1293 typedef struct tds_context TDSCONTEXT;
1294 typedef int (*err_handler_t) (const TDSCONTEXT *, TDSSOCKET *, TDSMESSAGE *);
1295 
1297 {
1298  TDSLOCALE *locale;
1299  void *parent;
1300  /* handlers */
1301  int (*msg_handler) (const TDSCONTEXT *, TDSSOCKET *, TDSMESSAGE *);
1302  int (*err_handler) (const TDSCONTEXT *, TDSSOCKET *, TDSMESSAGE *);
1303  int (*int_handler) (void *);
1304 };
1305 
1306 enum TDS_ICONV_ENTRY
1307 {
1308  client2ucs2
1309  , client2server_chardata
1310  , iso2server_metadata
1311  , initial_char_conv_count /* keep last */
1312 };
1313 
1314 typedef struct tds_authentication
1315 {
1316  TDS_UCHAR *packet;
1317  int packet_len;
1318  int (*free)(TDSSOCKET * tds, struct tds_authentication * auth);
1319  int (*handle_next)(TDSSOCKET * tds, struct tds_authentication * auth, size_t len);
1321 
1326 {
1327  TDS_SYS_SOCKET s;
1329  TDS_USMALLINT tds_version;
1330  TDS_UINT product_version;
1331  char *product_name;
1332 
1333  unsigned char capabilities[TDS_MAX_CAPABILITY];
1334  unsigned int broken_dates:1;
1335  unsigned int emul_little_endian:1;
1336  unsigned int use_iconv:1;
1337  unsigned int tds71rev1:1;
1338 
1339  unsigned char *in_buf;
1340  unsigned char *out_buf;
1341  unsigned int in_buf_max;
1342  unsigned in_pos;
1343  unsigned out_pos;
1344  unsigned in_len;
1346  unsigned char in_flag;
1347  unsigned char out_flag;
1348  void *parent;
1349 
1356  TDSRESULTINFO *res_info;
1357  TDS_INT num_comp_info;
1358  TDSCOMPUTEINFO **comp_info;
1359  TDSPARAMINFO *param_info;
1362  TDS_TINYINT has_status;
1363  TDS_INT ret_status;
1364  TDS_STATE state;
1365 
1366  volatile
1367  unsigned char in_cancel;
1369  TDS_INT8 rows_affected;
1370  TDS_INT query_timeout;
1371  TDSENV env;
1372 
1376  const TDSCONTEXT *tds_ctx;
1377  int char_conv_count;
1378  TDSICONV **char_convs;
1379 
1382  int spid;
1383  TDS_UCHAR collation[5];
1384  TDS_UCHAR tds9_transaction[8];
1385  void (*env_chg_func) (TDSSOCKET * tds, int type, char *oldval, char *newval);
1386  int internal_sp_called;
1387 
1388  void *tls_session;
1389  void *tls_credentials;
1390  TDSAUTHENTICATION *authentication;
1391  int option_value;
1392 };
1393 
1394 int tds_init_write_buf(TDSSOCKET * tds);
1395 void tds_free_result_info(TDSRESULTINFO * info);
1396 void tds_free_socket(TDSSOCKET * tds);
1397 void tds_free_connection(TDSCONNECTION * connection);
1398 void tds_free_all_results(TDSSOCKET * tds);
1399 void tds_free_results(TDSRESULTINFO * res_info);
1400 void tds_free_param_results(TDSPARAMINFO * param_info);
1401 void tds_free_param_result(TDSPARAMINFO * param_info);
1402 void tds_free_msg(TDSMESSAGE * message);
1403 void tds_cursor_deallocated(TDSSOCKET *tds, TDSCURSOR *cursor);
1404 void tds_release_cursor(TDSSOCKET *tds, TDSCURSOR *cursor);
1405 void tds_free_bcp_column_data(BCPCOLDATA * coldata);
1406 
1407 int tds_put_n(TDSSOCKET * tds, const void *buf, size_t n);
1408 int tds_put_string(TDSSOCKET * tds, const char *buf, int len);
1409 int tds_put_int(TDSSOCKET * tds, TDS_INT i);
1410 int tds_put_int8(TDSSOCKET * tds, TDS_INT8 i);
1411 int tds_put_smallint(TDSSOCKET * tds, TDS_SMALLINT si);
1413 #define tds_put_tinyint(tds, ti) tds_put_byte(tds,ti)
1414 int tds_put_byte(TDSSOCKET * tds, unsigned char c);
1415 TDSRESULTINFO *tds_alloc_results(int num_cols);
1416 TDSCOMPUTEINFO **tds_alloc_compute_results(TDSSOCKET * tds, int num_cols, int by_cols);
1417 TDSCONTEXT *tds_alloc_context(void * parent);
1418 void tds_free_context(TDSCONTEXT * locale);
1419 TDSSOCKET *tds_alloc_socket(TDSCONTEXT * context, int bufsize);
1420 
1421 /* config.c */
1422 int tds_default_port(int major, int minor);
1424 typedef void (*TDSCONFPARSE) (const char *option, const char *value, void *param);
1425 int tds_read_conf_section(FILE * in, const char *section, TDSCONFPARSE tds_conf_parse, void *parse_param);
1426 int tds_read_conf_file(TDSCONNECTION * connection, const char *server);
1427 void tds_parse_conf_section(const char *option, const char *value, void *param);
1429 void tds_fix_connection(TDSCONNECTION * connection);
1430 TDS_USMALLINT tds_config_verstr(const char *tdsver, TDSCONNECTION * connection);
1431 int tds_lookup_host(const char *servername, char *ip);
1432 int tds_set_interfaces_file_loc(const char *interfloc);
1433 extern const char STD_DATETIME_FMT[];
1434 int tds_config_boolean(const char *value);
1435 
1436 TDSLOCALE *tds_get_locale(void);
1437 int tds_alloc_row(TDSRESULTINFO * res_info);
1438 int tds_alloc_compute_row(TDSCOMPUTEINFO * res_info);
1439 BCPCOLDATA * tds_alloc_bcp_column_data(int column_size);
1440 unsigned char *tds7_crypt_pass(const unsigned char *clear_pass, size_t len, unsigned char *crypt_pass);
1441 TDSDYNAMIC *tds_lookup_dynamic(TDSSOCKET * tds, const char *id);
1442 /*@observer@*/ const char *tds_prtype(int token);
1443 int tds_get_varint_size(TDSSOCKET * tds, int datatype);
1444 int tds_get_cardinal_type(int datatype, int usertype);
1445 
1446 
1447 
1448 /* iconv.c */
1449 void tds_iconv_open(TDSSOCKET * tds, const char *charset);
1450 void tds_iconv_close(TDSSOCKET * tds);
1451 void tds_srv_charset_changed(TDSSOCKET * tds, const char *charset);
1452 void tds7_srv_charset_changed(TDSSOCKET * tds, int sql_collate, int lcid);
1453 int tds_iconv_alloc(TDSSOCKET * tds);
1454 void tds_iconv_free(TDSSOCKET * tds);
1455 TDSICONV *tds_iconv_from_collate(TDSSOCKET * tds, TDS_UCHAR collate[5]);
1456 
1457 /* threadsafe.c */
1458 char *tds_timestamp_str(char *str, int maxlen);
1459 struct tm *tds_localtime_r(const time_t *timep, struct tm *result);
1460 struct hostent *tds_gethostbyname_r(const char *servername, struct hostent *result, char *buffer, int buflen, int *h_errnop);
1461 struct hostent *tds_gethostbyaddr_r(const char *addr, int len, int type, struct hostent *result, char *buffer, int buflen,
1462  int *h_errnop);
1463 struct servent *tds_getservbyname_r(const char *name, const char *proto, struct servent *result, char *buffer, int buflen);
1464 #ifdef INADDR_NONE
1465 const char *tds_inet_ntoa_r(struct in_addr iaddr, char *ip, size_t len);
1466 #endif
1467 char *tds_get_homedir(void);
1468 
1469 /* mem.c */
1471 void tds_free_input_params(TDSDYNAMIC * dyn);
1472 void tds_free_dynamic(TDSSOCKET * tds, TDSDYNAMIC * dyn);
1473 TDSSOCKET *tds_realloc_socket(TDSSOCKET * tds, size_t bufsize);
1474 char *tds_alloc_client_sqlstate(int msgno);
1475 char *tds_alloc_lookup_sqlstate(TDSSOCKET * tds, int msgno);
1476 TDSLOGIN *tds_alloc_login(void);
1477 TDSDYNAMIC *tds_alloc_dynamic(TDSSOCKET * tds, const char *id);
1478 void tds_free_login(TDSLOGIN * login);
1480 TDSLOCALE *tds_alloc_locale(void);
1481 void *tds_alloc_param_data(TDSCOLUMN * curparam);
1482 void tds_free_locale(TDSLOCALE * locale);
1483 TDSCURSOR * tds_alloc_cursor(TDSSOCKET * tds, const char *name, TDS_INT namelen, const char *query, TDS_INT querylen);
1484 void tds_free_row(TDSRESULTINFO * res_info, unsigned char *row);
1485 
1486 /* login.c */
1487 void tds_set_packet(TDSLOGIN * tds_login, int packet_size);
1488 void tds_set_port(TDSLOGIN * tds_login, int port);
1489 void tds_set_passwd(TDSLOGIN * tds_login, const char *password);
1490 void tds_set_bulk(TDSLOGIN * tds_login, TDS_TINYINT enabled);
1491 void tds_set_user(TDSLOGIN * tds_login, const char *username);
1492 void tds_set_app(TDSLOGIN * tds_login, const char *application);
1493 void tds_set_host(TDSLOGIN * tds_login, const char *hostname);
1494 void tds_set_library(TDSLOGIN * tds_login, const char *library);
1495 void tds_set_server(TDSLOGIN * tds_login, const char *server);
1496 void tds_set_client_charset(TDSLOGIN * tds_login, const char *charset);
1497 void tds_set_language(TDSLOGIN * tds_login, const char *language);
1498 void tds_set_database_name(TDSLOGIN * tds_login, const char *dbname);
1499 void tds_set_version(TDSLOGIN * tds_login, TDS_TINYINT major_ver, TDS_TINYINT minor_ver);
1500 void tds_set_capabilities(TDSLOGIN * tds_login, unsigned char *capabilities, int size);
1501 int tds_connect_and_login(TDSSOCKET * tds, TDSCONNECTION * connection);
1502 
1503 /* query.c */
1504 int tds_submit_query(TDSSOCKET * tds, const char *query);
1505 int tds_submit_query_params(TDSSOCKET * tds, const char *query, TDSPARAMINFO * params);
1506 int tds_submit_queryf(TDSSOCKET * tds, const char *queryf, ...);
1507 int tds_submit_prepare(TDSSOCKET * tds, const char *query, const char *id, TDSDYNAMIC ** dyn_out, TDSPARAMINFO * params);
1508 int tds_submit_execdirect(TDSSOCKET * tds, const char *query, TDSPARAMINFO * params);
1509 int tds8_submit_prepexec(TDSSOCKET * tds, const char *query, const char *id, TDSDYNAMIC ** dyn_out, TDSPARAMINFO * params);
1510 int tds_submit_execute(TDSSOCKET * tds, TDSDYNAMIC * dyn);
1511 int tds_send_cancel(TDSSOCKET * tds);
1512 const char *tds_next_placeholder(const char *start);
1513 int tds_count_placeholders(const char *query);
1514 int tds_needs_unprepare(TDSSOCKET * tds, TDSDYNAMIC * dyn);
1515 int tds_submit_unprepare(TDSSOCKET * tds, TDSDYNAMIC * dyn);
1516 int tds_submit_rpc(TDSSOCKET * tds, const char *rpc_name, TDSPARAMINFO * params);
1517 int tds_submit_optioncmd(TDSSOCKET * tds, TDS_OPTION_CMD command, TDS_OPTION option, TDS_OPTION_ARG *param, TDS_INT param_size);
1518 int tds_quote_id(TDSSOCKET * tds, char *buffer, const char *id, int idlen);
1519 int tds_quote_string(TDSSOCKET * tds, char *buffer, const char *str, int len);
1520 const char *tds_skip_quoted(const char *s);
1521 
1522 int tds_cursor_declare(TDSSOCKET * tds, TDSCURSOR * cursor, TDSPARAMINFO *params, int *send);
1523 int tds_cursor_setrows(TDSSOCKET * tds, TDSCURSOR * cursor, int *send);
1524 int tds_cursor_open(TDSSOCKET * tds, TDSCURSOR * cursor, TDSPARAMINFO *params, int *send);
1525 int tds_cursor_fetch(TDSSOCKET * tds, TDSCURSOR * cursor, TDS_CURSOR_FETCH fetch_type, TDS_INT i_row);
1526 int tds_cursor_get_cursor_info(TDSSOCKET * tds, TDSCURSOR * cursor, TDS_UINT * row_number, TDS_UINT * row_count);
1527 int tds_cursor_close(TDSSOCKET * tds, TDSCURSOR * cursor);
1528 int tds_cursor_dealloc(TDSSOCKET * tds, TDSCURSOR * cursor);
1529 int tds_cursor_update(TDSSOCKET * tds, TDSCURSOR * cursor, TDS_CURSOR_OPERATION op, TDS_INT i_row, TDSPARAMINFO * params);
1530 int tds_cursor_setname(TDSSOCKET * tds, TDSCURSOR * cursor);
1531 
1532 int tds_multiple_init(TDSSOCKET *tds, TDSMULTIPLE *multiple, TDS_MULTIPLE_TYPE type);
1533 int tds_multiple_done(TDSSOCKET *tds, TDSMULTIPLE *multiple);
1534 int tds_multiple_query(TDSSOCKET *tds, TDSMULTIPLE *multiple, const char *query, TDSPARAMINFO * params);
1535 int tds_multiple_execute(TDSSOCKET *tds, TDSMULTIPLE *multiple, TDSDYNAMIC * dyn);
1536 
1537 /* token.c */
1538 int tds_process_cancel(TDSSOCKET * tds);
1539 #ifdef WORDS_BIGENDIAN
1540 void tds_swap_datatype(int coltype, unsigned char *buf);
1541 #endif
1542 void tds_swap_numeric(TDS_NUMERIC *num);
1543 int tds_get_token_size(int marker);
1546 int tds5_send_optioncmd(TDSSOCKET * tds, TDS_OPTION_CMD tds_command, TDS_OPTION tds_option, TDS_OPTION_ARG * tds_argument,
1547  TDS_INT * tds_argsize);
1548 int tds_process_tokens(TDSSOCKET * tds, /*@out@*/ TDS_INT * result_type, /*@out@*/ int *done_flags, unsigned flag);
1549 
1550 /* data.c */
1551 void tds_set_param_type(TDSSOCKET * tds, TDSCOLUMN * curcol, TDS_SERVER_TYPE type);
1552 void tds_set_column_type(TDSSOCKET * tds, TDSCOLUMN * curcol, int type);
1553 TDS_INT tds_data_get_info(TDSSOCKET *tds, TDSCOLUMN *col);
1554 
1555 
1556 /* tds_convert.c */
1557 TDS_INT tds_datecrack(TDS_INT datetype, const void *di, TDSDATEREC * dr);
1558 int tds_get_conversion_type(int srctype, int colsize);
1559 extern const char tds_hex_digits[];
1560 
1561 /* write.c */
1562 int tds_flush_packet(TDSSOCKET * tds);
1563 int tds_put_buf(TDSSOCKET * tds, const unsigned char *buf, int dsize, int ssize);
1564 
1565 /* read.c */
1566 unsigned char tds_get_byte(TDSSOCKET * tds);
1567 void tds_unget_byte(TDSSOCKET * tds);
1568 unsigned char tds_peek(TDSSOCKET * tds);
1569 TDS_SMALLINT tds_get_smallint(TDSSOCKET * tds);
1570 TDS_INT tds_get_int(TDSSOCKET * tds);
1571 TDS_INT8 tds_get_int8(TDSSOCKET * tds);
1572 int tds_get_string(TDSSOCKET * tds, int string_len, char *dest, size_t dest_size);
1573 int tds_get_char_data(TDSSOCKET * tds, char *dest, size_t wire_size, TDSCOLUMN * curcol);
1574 void *tds_get_n(TDSSOCKET * tds, /*@out@*/ /*@null@*/ void *dest, int n);
1575 int tds_get_size_by_type(int servertype);
1576 
1577 
1578 /* util.c */
1579 int tdserror (const TDSCONTEXT * tds_ctx, TDSSOCKET * tds, int msgno, int errnum);
1580 TDS_STATE tds_set_state(TDSSOCKET * tds, TDS_STATE state);
1581 void tds_set_parent(TDSSOCKET * tds, void *the_parent);
1582 int tds_swap_bytes(unsigned char *buf, int bytes);
1583 int tds_version(TDSSOCKET * tds_socket, char *pversion_string);
1584 unsigned int tds_gettime_ms(void);
1585 int tds_get_req_capability(TDSSOCKET * tds, int cap);
1586 
1587 /* log.c */
1588 void tdsdump_off(void);
1589 void tdsdump_on(void);
1590 int tdsdump_isopen(void);
1591 #if defined(__GNUC__) && __GNUC__ >= 4 && !defined(__MINGW32__)
1592 #pragma GCC visibility pop
1593 #endif
1594 int tdsdump_open(const char *filename);
1595 #if defined(__GNUC__) && __GNUC__ >= 4 && !defined(__MINGW32__)
1596 #pragma GCC visibility push(hidden)
1597 #endif
1598 void tdsdump_close(void);
1599 void tdsdump_dump_buf(const char* file, unsigned int level_line, const char *msg, const void *buf, size_t length);
1600 void tdsdump_col(const TDSCOLUMN *col);
1601 #undef tdsdump_log
1602 void tdsdump_log(const char* file, unsigned int level_line, const char *fmt, ...)
1603 #if defined(__GNUC__) && __GNUC__ >= 2
1604  __attribute__ ((__format__ (__printf__, 3, 4)))
1605 #endif
1606 ;
1607 #define tdsdump_log if (TDS_UNLIKELY(tds_write_dump)) tdsdump_log
1608 
1609 extern int tds_write_dump;
1610 extern int tds_debug_flags;
1611 extern int tds_g_append_mode;
1612 
1613 /* net.c */
1614 int tds_lastpacket(TDSSOCKET * tds);
1615 TDSERRNO tds_open_socket(TDSSOCKET * tds, const char *ip_addr, unsigned int port, int timeout, int *p_oserr);
1616 int tds_close_socket(TDSSOCKET * tds);
1617 int tds_read_packet(TDSSOCKET * tds);
1618 int tds_write_packet(TDSSOCKET * tds, unsigned char final);
1619 int tds7_get_instance_ports(FILE *output, const char *ip_addr);
1620 int tds7_get_instance_port(const char *ip_addr, const char *instance);
1621 int tds_ssl_init(TDSSOCKET *tds);
1622 void tds_ssl_deinit(TDSSOCKET *tds);
1623 const char *tds_prwsaerror(int erc);
1624 
1625 
1626 
1627 /* vstrbuild.c */
1628 int tds_vstrbuild(char *buffer, int buflen, int *resultlen, char *text, int textlen, const char *formats, int formatlen,
1629  va_list ap);
1630 
1631 /* numeric.c */
1632 char *tds_money_to_string(const TDS_MONEY * money, char *s);
1633 TDS_INT tds_numeric_to_string(const TDS_NUMERIC * numeric, char *s);
1634 TDS_INT tds_numeric_change_prec_scale(TDS_NUMERIC * numeric, unsigned char new_prec, unsigned char new_scale);
1635 
1636 /* getmac.c */
1637 void tds_getmac(TDS_SYS_SOCKET s, unsigned char mac[6]);
1638 
1639 #ifndef HAVE_SSPI
1641 TDSAUTHENTICATION * tds_gss_get_auth(TDSSOCKET * tds);
1642 #else
1643 TDSAUTHENTICATION * tds_sspi_get_auth(TDSSOCKET * tds);
1644 #endif
1645 
1646 /* bulk.c */
1647 
1650 {
1651  TDS_BCP_IN = 1,
1652  TDS_BCP_OUT = 2,
1653  TDS_BCP_QUERYOUT = 3
1654 };
1655 
1656 typedef struct tds_bcpinfo
1657 {
1658  const char *hint;
1659  void *parent;
1660  TDS_CHAR *tablename;
1661  TDS_CHAR *insert_stmt;
1662  TDS_INT direction;
1663  TDS_INT identity_insert_on;
1664  TDS_INT xfer_init;
1665  TDS_INT var_cols;
1666  TDS_INT bind_count;
1667  TDSRESULTINFO *bindinfo;
1668 } TDSBCPINFO;
1669 
1670 int tds_bcp_init(TDSSOCKET *tds, TDSBCPINFO *bcpinfo);
1671 typedef int (*tds_bcp_get_col_data) (TDSBCPINFO *bulk, TDSCOLUMN *bcpcol, int offset);
1672 typedef void (*tds_bcp_null_error) (TDSBCPINFO *bulk, int index, int offset);
1673 int tds_bcp_send_record(TDSSOCKET *tds, TDSBCPINFO *bcpinfo, tds_bcp_get_col_data get_col_data, tds_bcp_null_error null_error, int offset);
1674 int tds_bcp_done(TDSSOCKET *tds, int *rows_copied);
1675 int tds_bcp_start(TDSSOCKET *tds, TDSBCPINFO *bcpinfo);
1676 int tds_bcp_start_copy_in(TDSSOCKET *tds, TDSBCPINFO *bcpinfo);
1677 
1678 int tds_writetext_start(TDSSOCKET *tds, const char *objname, const char *textptr, const char *timestamp, int with_log, TDS_UINT size);
1679 int tds_writetext_continue(TDSSOCKET *tds, const TDS_UCHAR *text, TDS_UINT size);
1680 int tds_writetext_end(TDSSOCKET *tds);
1681 
1682 
1683 #define IS_TDS42(x) (x->tds_version==0x402)
1684 #define IS_TDS46(x) (x->tds_version==0x406)
1685 #define IS_TDS50(x) (x->tds_version==0x500)
1686 #define IS_TDS70(x) (x->tds_version==0x700)
1687 #define IS_TDS71(x) (x->tds_version==0x701)
1688 #define IS_TDS72(x) (x->tds_version==0x702)
1689 
1690 #define IS_TDS7_PLUS(x) ((x)->tds_version>=0x700)
1691 #define IS_TDS71_PLUS(x) ((x)->tds_version>=0x701)
1692 #define IS_TDS72_PLUS(x) ((x)->tds_version>=0x702)
1693 
1694 #define TDS_MAJOR(x) ((x)->tds_version >> 8)
1695 #define TDS_MINOR(x) ((x)->tds_version & 0xff)
1696 
1697 #define IS_TDSDEAD(x) (((x) == NULL) || TDS_IS_SOCKET_INVALID((x)->s))
1698 
1700 #define TDS_IS_SYBASE(x) (!(x->product_version & 0x80000000u))
1701 
1702 #define TDS_IS_MSSQL(x) ((x->product_version & 0x80000000u)!=0)
1703 
1707 #define TDS_MS_VER(maj,min,x) (0x80000000u|((maj)<<24)|((min)<<16)|(x))
1708 
1709 /* TODO test if not similar to ms one*/
1711 #define TDS_SYB_VER(maj,min,x) (((maj)<<24)|((min)<<16)|(x)<<8)
1712 
1713 #ifdef __cplusplus
1714 #if 0
1715 {
1716 #endif
1717 }
1718 #endif
1719 
1720 #if defined(__GNUC__) && __GNUC__ >= 4 && !defined(__MINGW32__)
1721 #pragma GCC visibility pop
1722 #endif
1723 
1724 #define TDS_PUT_INT(tds,v) tds_put_int((tds), ((TDS_INT)(v)))
1725 #define TDS_PUT_SMALLINT(tds,v) tds_put_smallint((tds), ((TDS_SMALLINT)(v)))
1726 #define TDS_PUT_BYTE(tds,v) tds_put_byte((tds), ((unsigned char)(v)))
1727 
1728 #endif /* _tds_h_ */