Main Page | Modules | Class List | Directories | File List | Class Members | File Members | Related Pages

sybdb.h

Go to the documentation of this file.
00001 /* FreeTDS - Library of routines accessing Sybase and Microsoft databases
00002  * Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004  Brian Bruns
00003  *
00004  * This library is free software; you can redistribute it and/or
00005  * modify it under the terms of the GNU Library General Public
00006  * License as published by the Free Software Foundation; either
00007  * version 2 of the License, or (at your option) any later version.
00008  *
00009  * This library is distributed in the hope that it will be useful,
00010  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00011  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00012  * Library General Public License for more details.
00013  *
00014  * You should have received a copy of the GNU Library General Public
00015  * License along with this library; if not, write to the
00016  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
00017  * Boston, MA 02111-1307, USA.
00018  */
00019 
00027 #ifndef _sybdb_h_
00028 #define _sybdb_h_
00029 
00030 #include "tds_sysdep_public.h"
00031 
00032 #undef TDS_STATIC_CAST
00033 #ifdef __cplusplus
00034 #define TDS_STATIC_CAST(type, a) static_cast<type>(a)
00035 extern "C"
00036 {
00037 #if 0
00038 }
00039 #endif
00040 #else
00041 #define TDS_STATIC_CAST(type, a) ((type)(a))
00042 #endif
00043 
00044 static const char rcsid_sybdb_h[] = "$Id: sybdb.h,v 1.85 2007/12/02 23:01:37 jklowden Exp $";
00045 static const void *const no_unused_sybdb_h_warn[] = { rcsid_sybdb_h, no_unused_sybdb_h_warn };
00046 
00047 #ifdef FALSE
00048 #undef FALSE
00049 #endif
00050 #ifdef TRUE
00051 #undef TRUE
00052 #endif
00053 #define FALSE 0
00054 #define TRUE  1
00055 
00056 #define DBSAVE   1
00057 #define DBNOSAVE 0
00058 #define DBNOERR  -1
00059 
00060 #define INT_EXIT        0
00061 #define INT_CONTINUE    1
00062 #define INT_CANCEL      2
00063 #define INT_TIMEOUT     3
00064 
00065 #define DBMAXNUMLEN 33
00066 #define DBMAXNAME   30
00067 
00071 #define DBVERSION_UNKNOWN 0
00072 #define DBVERSION_46      1
00073 #define DBVERSION_100     2
00074 #define DBVERSION_42      3
00075 #define DBVERSION_70      4
00076 #define DBVERSION_80      5
00077 
00078 /* these two are defined by Microsoft for dbsetlversion() */
00079 #define DBVER42           DBVERSION_42
00080 #define DBVER60           DBVERSION_70  /* our best approximation */
00081 
00086 #define DBTDS_UNKNOWN           0
00087 #define DBTDS_2_0               1       /* pre 4.0 SQL Server */
00088 #define DBTDS_3_4               2       /* Microsoft SQL Server (3.0) */
00089 #define DBTDS_4_0               3       /* 4.0 SQL Server */
00090 #define DBTDS_4_2               4       /* 4.2 SQL Server */
00091 #define DBTDS_4_6               5       /* 2.0 OpenServer and 4.6 SQL Server. */
00092 #define DBTDS_4_9_5             6       /* 4.9.5 (NCR) SQL Server */
00093 #define DBTDS_5_0               7       /* 5.0 SQL Server */
00094 #define DBTDS_7_0               8       /* Microsoft SQL Server 7.0 */
00095 #define DBTDS_8_0               9       /* Microsoft SQL Server 2000 */
00096 #define DBTDS_9_0               10      /* Microsoft SQL Server 2005 */
00097 
00098 #define DBTXPLEN 16
00099 
00100 #define BCPMAXERRS 1
00101 #define BCPFIRST 2
00102 #define BCPLAST 3
00103 #define BCPBATCH 4
00104 #define BCPKEEPIDENTITY 8
00105 
00106 #define BCPLABELED 5
00107 #define BCPHINTS 6
00108 
00109 #define DBCMDNONE 0
00110 #define DBCMDPEND 1
00111 #define DBCMDSENT 2
00112 
00113 typedef int RETCODE;
00114 
00115 typedef void DBCURSOR;
00116 typedef void DBXLATE;
00117 typedef void DBSORTORDER;
00118 typedef void DBLOGINFO;
00119 typedef void *DBVOIDPTR;
00120 typedef short SHORT;
00121 typedef unsigned short USHORT;
00122 typedef int (*INTFUNCPTR) (void *, ...);
00123 typedef int (*DBWAITFUNC) (void);
00124 typedef DBWAITFUNC(*DB_DBBUSY_FUNC) (void *dbproc);
00125 typedef void (*DB_DBIDLE_FUNC) (DBWAITFUNC dfunc, void *dbproc);
00126 typedef int (*DB_DBCHKINTR_FUNC) (void *dbproc);
00127 typedef int (*DB_DBHNDLINTR_FUNC) (void *dbproc);
00128 
00129 #ifndef __INCvxWorksh
00130 /* VxWorks already defines STATUS and BOOL. Compiler gets mad if you 
00131 ** redefine them. */
00132 /* __INCvxWorksh will get #defined by std. include files included from tds.h
00133 */
00134 #ifdef STATUS
00135 /* On DU4.0d we get a conflicting STATUS definition from arpa/nameser.h
00136    when _REENTRANT is defined.
00137 */
00138 #undef STATUS
00139 #endif
00140 typedef int STATUS;
00141 #if !defined(_WINDEF_) && !defined(_WINDEF_H) && !defined(DOS32X)
00142 typedef int BOOL;
00143 #endif
00144 #endif
00145 
00146 #if !defined(_FREETDS_LIBRARY_SOURCE) || !defined(_tds_h_)
00147 /* copied from tds.h */
00148 /* TODO find a best way... */
00149 enum
00150 {
00151         SYBCHAR = 47,           /* 0x2F */
00152 #define SYBCHAR SYBCHAR
00153         SYBVARCHAR = 39,        /* 0x27 */
00154 #define SYBVARCHAR      SYBVARCHAR
00155         SYBINTN = 38,           /* 0x26 */
00156 #define SYBINTN SYBINTN
00157         SYBINT1 = 48,           /* 0x30 */
00158 #define SYBINT1 SYBINT1
00159         SYBINT2 = 52,           /* 0x34 */
00160 #define SYBINT2 SYBINT2
00161         SYBINT4 = 56,           /* 0x38 */
00162 #define SYBINT4 SYBINT4
00163         SYBINT8 = 127,          /* 0x7F */
00164 #define SYBINT8 SYBINT8
00165         SYBFLT8 = 62,           /* 0x3E */
00166 #define SYBFLT8 SYBFLT8
00167         SYBDATETIME = 61,       /* 0x3D */
00168 #define SYBDATETIME     SYBDATETIME
00169         SYBBIT = 50,            /* 0x32 */
00170 #define SYBBIT  SYBBIT
00171         SYBTEXT = 35,           /* 0x23 */
00172 #define SYBTEXT SYBTEXT
00173         SYBIMAGE = 34,          /* 0x22 */
00174 #define SYBIMAGE        SYBIMAGE
00175         SYBMONEY4 = 122,        /* 0x7A */
00176 #define SYBMONEY4       SYBMONEY4
00177         SYBMONEY = 60,          /* 0x3C */
00178 #define SYBMONEY        SYBMONEY
00179         SYBDATETIME4 = 58,      /* 0x3A */
00180 #define SYBDATETIME4    SYBDATETIME4
00181         SYBREAL = 59,           /* 0x3B */
00182 #define SYBREAL SYBREAL
00183         SYBBINARY = 45,         /* 0x2D */
00184 #define SYBBINARY       SYBBINARY
00185         SYBVARBINARY = 37,      /* 0x25 */
00186 #define SYBVARBINARY    SYBVARBINARY
00187         SYBNUMERIC = 108,       /* 0x6C */
00188 #define SYBNUMERIC      SYBNUMERIC
00189         SYBDECIMAL = 106,       /* 0x6A */
00190 #define SYBDECIMAL      SYBDECIMAL
00191         SYBFLTN = 109,          /* 0x6D */
00192 #define SYBFLTN SYBFLTN
00193         SYBMONEYN = 110,        /* 0x6E */
00194 #define SYBMONEYN       SYBMONEYN
00195         SYBDATETIMN = 111       /* 0x6F */
00196 #define SYBDATETIMN     SYBDATETIMN
00197 };
00198 
00199 #define SYBAOPCNT  0x4b
00200 #define SYBAOPCNTU 0x4c
00201 #define SYBAOPSUM  0x4d
00202 #define SYBAOPSUMU 0x4e
00203 #define SYBAOPAVG  0x4f
00204 #define SYBAOPAVGU 0x50
00205 #define SYBAOPMIN  0x51
00206 #define SYBAOPMAX  0x52
00207 
00208 /* mssql2k compute operator */
00209 #define SYBAOPCNT_BIG           0x09
00210 #define SYBAOPSTDEV             0x30
00211 #define SYBAOPSTDEVP            0x31
00212 #define SYBAOPVAR               0x32
00213 #define SYBAOPVARP              0x33
00214 #define SYBAOPCHECKSUM_AGG      0x72
00215 
00216 #endif
00217 
00218 typedef unsigned char DBBOOL;
00219 typedef char DBCHAR;
00220 typedef unsigned char DBBIT;
00221 typedef unsigned char DBTINYINT;
00222 typedef tds_sysdep_int16_type DBSMALLINT;
00223 typedef tds_sysdep_int32_type DBINT;
00224 typedef unsigned char DBBINARY;
00225 typedef tds_sysdep_real32_type DBREAL;
00226 typedef tds_sysdep_real64_type DBFLT8;
00227 typedef unsigned tds_sysdep_int16_type DBUSMALLINT;
00228 
00229 typedef struct 
00230 {
00231         DBINT len;
00232     char  str[256];
00233 } DBVARYCHAR;
00234    
00235 typedef struct
00236 {
00237         unsigned char precision;
00238         unsigned char scale;
00239         unsigned char array[33];
00240 } DBNUMERIC;
00241 
00242 typedef DBNUMERIC DBDECIMAL;
00243 
00244 typedef struct
00245 {
00246         DBINT mnyhigh;
00247         unsigned tds_sysdep_int32_type mnylow;
00248 } DBMONEY;
00249 
00250 typedef struct
00251 {
00252         DBINT mny4;
00253 } DBMONEY4;
00254 
00255 typedef struct
00256 {
00257         DBINT dtdays;
00258         DBINT dttime;
00259 } DBDATETIME;
00260 
00261 typedef struct
00262 {
00263         DBUSMALLINT days;
00264         DBUSMALLINT minutes;
00265 } DBDATETIME4;
00266 
00267 #ifdef MSDBLIB
00268 #define SQLCHAR SYBCHAR
00269 #endif
00270 
00271 typedef struct tds_dblib_loginrec LOGINREC;
00272 
00273 #ifndef DOS32X
00274 typedef unsigned char BYTE;
00275 #endif
00276 
00277 typedef struct dbtypeinfo
00278 {
00279         DBINT precision;
00280         DBINT scale;
00281 } DBTYPEINFO;
00282 
00283 struct dbstring
00284 {
00285         BYTE *strtext;
00286         DBINT strtotlen;
00287         struct dbstring *strnext;
00288 };
00289 typedef struct dbstring DBSTRING;
00290 
00291 /* Used by dbcolinfo */
00292 enum
00293 { MAXCOLNAMELEN = 512 }; /* duplicates TDS_SYSNAME_SIZE */
00294 typedef enum { CI_REGULAR=1, CI_ALTERNATE=2, CI_CURSOR=3 } CI_TYPE;
00295 
00296 typedef struct 
00297 { 
00298     DBINT SizeOfStruct; 
00299     DBCHAR  Name[MAXCOLNAMELEN+2]; 
00300     DBCHAR  ActualName[MAXCOLNAMELEN+2]; 
00301     DBCHAR  TableName[MAXCOLNAMELEN+2]; 
00302     SHORT Type; 
00303     DBINT UserType; 
00304     DBINT MaxLength; 
00305     BYTE  Precision; 
00306     BYTE  Scale; 
00307     BOOL  VarLength; 
00308     BYTE  Null; 
00309     BYTE  CaseSensitive; 
00310     BYTE  Updatable; 
00311     BOOL  Identity; 
00312 
00313 } DBCOL; 
00314 /* end dbcolinfo stuff */
00315 
00316 
00317 
00318 /* a large list of options, DBTEXTSIZE is needed by sybtcl */
00319 #define DBPARSEONLY      0
00320 #define DBESTIMATE       1
00321 #define DBSHOWPLAN       2
00322 #define DBNOEXEC         3
00323 #define DBARITHIGNORE    4
00324 #define DBNOCOUNT        5
00325 #define DBARITHABORT     6
00326 #define DBTEXTLIMIT      7
00327 #define DBBROWSE         8
00328 #define DBOFFSET         9
00329 #define DBSTAT          10
00330 #define DBERRLVL        11
00331 #define DBCONFIRM       12
00332 #define DBSTORPROCID    13
00333 #define DBBUFFER        14
00334 #define DBNOAUTOFREE    15
00335 #define DBROWCOUNT      16
00336 #define DBTEXTSIZE      17
00337 #define DBNATLANG       18
00338 #define DBDATEFORMAT    19
00339 #define DBPRPAD         20
00340 #define DBPRCOLSEP      21
00341 #define DBPRLINELEN     22
00342 #define DBPRLINESEP     23
00343 #define DBLFCONVERT     24
00344 #define DBDATEFIRST     25
00345 #define DBCHAINXACTS    26
00346 #define DBFIPSFLAG      27
00347 #define DBISOLATION     28
00348 #define DBAUTH          29
00349 #define DBIDENTITY      30
00350 #define DBNOIDCOL       31
00351 #define DBDATESHORT     32
00352 #define DBCLIENTCURSORS 33
00353 #define DBSETTIME       34
00354 #define DBQUOTEDIDENT   35
00355 
00356 #define DBNUMOPTIONS  36
00357 
00358 #define DBPADOFF       0
00359 #define DBPADON        1
00360 
00361 #define OFF            0
00362 #define ON             1
00363 
00364 #define NOSUCHOPTION   2
00365 
00366 #define MAXOPTTEXT    32
00367 
00368 typedef struct tds_dblib_dbprocess DBPROCESS;
00369 
00370 typedef struct dbdaterec
00371 {
00372 #ifdef MSDBLIB
00373         DBINT year;
00374         DBINT month;
00375         DBINT day;
00376         DBINT dayofyear;
00377         DBINT weekday;
00378         DBINT hour;
00379         DBINT minute;
00380         DBINT second;
00381         DBINT millisecond;
00382         DBINT tzone;
00383 #else
00384         DBINT dateyear;
00385         DBINT datemonth;
00386         DBINT datedmonth;
00387         DBINT datedyear;
00388         DBINT datedweek;
00389         DBINT datehour;
00390         DBINT dateminute;
00391         DBINT datesecond;
00392         DBINT datemsecond;
00393         DBINT datetzone;
00394 #endif
00395 } DBDATEREC;
00396 
00397 typedef int (*EHANDLEFUNC) (DBPROCESS * dbproc, int severity, int dberr, int oserr, char *dberrstr, char *oserrstr);
00398 
00399 typedef int (*MHANDLEFUNC) (DBPROCESS * dbproc, DBINT msgno, int msgstate, int severity, char *msgtext, char *srvname,
00400                             char *proc, int line);
00401 
00402 /* dbpoll() result codes, sybtcl needs DBRESULT */
00403 #define DBRESULT       1
00404 #define DBNOTIFICATION 2
00405 #define DBTIMEOUT      3
00406 #define DBINTERRUPT    4
00407 
00408 /* more sybtcl needs: */
00409 #define DBTXTSLEN    8
00410 
00411 /* bind types */
00412 #define CHARBIND          0
00413 #define STRINGBIND        1
00414 #define NTBSTRINGBIND     2
00415 #define VARYCHARBIND      3
00416 #define VARYBINBIND       4
00417 #define TINYBIND          6
00418 #define SMALLBIND         7
00419 #define INTBIND           8
00420 #define FLT8BIND          9
00421 #define REALBIND          10
00422 #define DATETIMEBIND      11
00423 #define SMALLDATETIMEBIND 12
00424 #define MONEYBIND         13
00425 #define SMALLMONEYBIND    14
00426 #define BINARYBIND        15
00427 #define BITBIND           16
00428 #define NUMERICBIND       17
00429 #define DECIMALBIND       18
00430 #define MAXBINDTYPES      19    /* keep last */
00431 
00432 #define DBPRCOLSEP  21
00433 #define DBPRLINELEN 22
00434 #define DBRPCRETURN 1
00435 #define DBRPCDEFAULT 2
00436 
00437 #define REG_ROW         -1
00438 #define MORE_ROWS       -1
00439 #define NO_MORE_ROWS    -2
00440 #define BUF_FULL        -3
00441 #define NO_MORE_RESULTS 2
00442 #define SUCCEED         1
00443 #define FAIL            0
00444 
00445 #define DB_IN  1
00446 #define DB_OUT 2
00447 #define DB_QUERYOUT 3
00448 
00449 #define DBSINGLE 0
00450 #define DBDOUBLE 1
00451 #define DBBOTH   2
00452 
00453 /* remote procedure call (rpc) options */
00454 #define DBRPCRECOMPILE  TDS_STATIC_CAST(DBSMALLINT, 0x0001)
00455 #define DBRPCRESET      TDS_STATIC_CAST(DBSMALLINT, 0x0002)
00456 #define DBRPCCURSOR     TDS_STATIC_CAST(DBSMALLINT, 0x0008)
00457 
00458 DBBOOL db12hour(DBPROCESS * dbprocess, char *language);
00459 BYTE *dbadata(DBPROCESS * dbproc, int computeid, int column);
00460 DBINT dbadlen(DBPROCESS * dbproc, int computeid, int column);
00461 RETCODE dbaltbind(DBPROCESS * dbprocess, int computeid, int column, int vartype, DBINT varlen, BYTE * varaddr);
00462 RETCODE dbaltbind_ps(DBPROCESS * dbprocess, int computeid, int column, int vartype, DBINT varlen, BYTE * varaddr,
00463                      DBTYPEINFO * typeinfo);
00464 int dbaltcolid(DBPROCESS * dbproc, int computeid, int column);
00465 RETCODE dbaltlen(DBPROCESS * dbproc, int computeid, int column);
00466 int dbaltop(DBPROCESS * dbproc, int computeid, int column);
00467 int dbalttype(DBPROCESS * dbproc, int computeid, int column);
00468 RETCODE dbaltutype(DBPROCESS * dbproc, int computeid, int column);
00469 RETCODE dbanullbind(DBPROCESS * dbprocess, int computeid, int column, DBINT * indicator);
00470 RETCODE dbbind(DBPROCESS * dbproc, int column, int vartype, DBINT varlen, BYTE * varaddr);
00471 RETCODE dbbind_ps(DBPROCESS * dbprocess, int column, int vartype, DBINT varlen, BYTE * varaddr, DBTYPEINFO * typeinfo);
00472 int dbbufsize(DBPROCESS * dbprocess);
00473 BYTE *dbbylist(DBPROCESS * dbproc, int computeid, int *size);
00474 RETCODE dbcancel(DBPROCESS * dbproc);
00475 RETCODE dbcanquery(DBPROCESS * dbproc);
00476 char *dbchange(DBPROCESS * dbprocess);
00477 DBBOOL dbcharsetconv(DBPROCESS * dbprocess);
00478 void dbclose(DBPROCESS * dbproc);
00479 void dbclrbuf(DBPROCESS * dbproc, DBINT n);
00480 RETCODE dbclropt(DBPROCESS * dbproc, int option, char *param);
00481 RETCODE dbcmd(DBPROCESS * dbproc, const char *cmdstring);
00482 RETCODE dbcmdrow(DBPROCESS * dbproc);
00483 
00484 #define DBCMDROW(x) dbcmdrow((x))
00485 DBBOOL dbcolbrowse(DBPROCESS * dbprocess, int colnum);
00486 RETCODE dbcolinfo (DBPROCESS *dbproc, CI_TYPE type, DBINT column, DBINT computeid, DBCOL *pdbcol);
00487 RETCODE dbtablecolinfo (DBPROCESS *dbproc, DBINT column, DBCOL *pdbcol );
00488 DBINT dbcollen(DBPROCESS * dbproc, int column);
00489 char *dbcolname(DBPROCESS * dbproc, int column);
00490 char *dbcolsource(DBPROCESS * dbproc, int colnum);
00491 int dbcoltype(DBPROCESS * dbproc, int column);
00492 DBTYPEINFO *dbcoltypeinfo(DBPROCESS * dbproc, int column);
00493 DBINT dbcolutype(DBPROCESS * dbprocess, int column);
00494 DBINT dbconvert(DBPROCESS * dbproc, int srctype, const BYTE * src, DBINT srclen, int desttype, BYTE * dest, DBINT destlen);
00495 DBINT dbconvert_ps(DBPROCESS * dbprocess, int srctype, BYTE * src, DBINT srclen, int desttype, BYTE * dest, DBINT destlen,
00496                    DBTYPEINFO * typeinfo);
00497 DBINT dbcount(DBPROCESS * dbproc);
00498 
00499 #define DBCOUNT(x) dbcount((x))
00500 int dbcurcmd(DBPROCESS * dbproc);
00501 
00502 #define DBCURCMD(x) dbcurcmd((x))
00503 DBINT dbcurrow(DBPROCESS * dbproc);
00504 
00505 #define DBCURROW(x) dbcurrow((x))
00506 RETCODE dbcursor(DBCURSOR * hc, DBINT optype, DBINT bufno, BYTE * table, BYTE * values);
00507 RETCODE dbcursorbind(DBCURSOR * hc, int col, int vartype, DBINT varlen, DBINT * poutlen, BYTE * pvaraddr, DBTYPEINFO * typeinfo);
00508 void dbcursorclose(DBCURSOR * hc);
00509 RETCODE dbcursorcolinfo(DBCURSOR * hc, DBINT column, DBCHAR * colname, DBINT * coltype, DBINT * collen, DBINT * usertype);
00510 RETCODE dbcursorfetch(DBCURSOR * hc, DBINT fetchtype, DBINT rownum);
00511 RETCODE dbcursorinfo(DBCURSOR * hc, DBINT * ncols, DBINT * nrows);
00512 DBCURSOR *dbcursoropen(DBPROCESS * dbprocess, BYTE * stmt, SHORT scollopt, SHORT concuropt, USHORT nrows, DBINT * pstatus);
00513 BYTE *dbdata(DBPROCESS * dbproc, int column);
00514 int dbdate4cmp(DBPROCESS * dbprocess, DBDATETIME4 * d1, DBDATETIME4 * d2);
00515 RETCODE dbdate4zero(DBPROCESS * dbprocess, DBDATETIME4 * d1);
00516 RETCODE dbdatechar(DBPROCESS * dbprocess, char *buf, int datepart, int value);
00517 RETCODE dbdatecmp(DBPROCESS * dbproc, DBDATETIME * d1, DBDATETIME * d2);
00518 RETCODE dbdatecrack(DBPROCESS * dbproc, DBDATEREC * di, DBDATETIME * dt);
00519 int dbdatename(DBPROCESS * dbprocess, char *buf, int date, DBDATETIME * datetime);
00520 char *dateorder(DBPROCESS * dbprocess, char *language);
00521 DBINT dbdatepart(DBPROCESS * dbprocess, int datepart, DBDATETIME * datetime);
00522 RETCODE dbdatezero(DBPROCESS * dbprocess, DBDATETIME * d1);
00523 DBINT dbdatlen(DBPROCESS * dbproc, int column);
00524 char *dbdayname(DBPROCESS * dbprocess, char *language, int daynum);
00525 DBBOOL dbdead(DBPROCESS * dbproc);
00526 
00527 #define DBDEAD(x) dbdead((x))
00528 EHANDLEFUNC dberrhandle(EHANDLEFUNC handler);
00529 void dbexit(void);
00530 RETCODE dbfcmd(DBPROCESS * dbproc, const char *fmt, ...);
00531 DBINT dbfirstrow(DBPROCESS * dbproc);
00532 
00533 #define DBFIRSTROW(x) dbfirstrow((x))
00534 RETCODE dbfree_xlate(DBPROCESS * dbprocess, DBXLATE * xlt_tosrv, DBXLATE * clt_todisp);
00535 void dbfreebuf(DBPROCESS * dbproc);
00536 void dbfreequal(char *qualptr);
00537 RETCODE dbfreesort(DBPROCESS * dbprocess, DBSORTORDER * sortorder);
00538 char *dbgetchar(DBPROCESS * dbprocess, int n);
00539 char *dbgetcharset(DBPROCESS * dbprocess);
00540 RETCODE dbgetloginfo(DBPROCESS * dbprocess, DBLOGINFO ** loginfo);
00541 int dbgetlusername(LOGINREC * login, BYTE * name_buffer, int buffer_len);
00542 int dbgetmaxprocs(void);
00543 char *dbgetnatlanf(DBPROCESS * dbprocess);
00544 int dbgetoff(DBPROCESS * dbprocess, DBUSMALLINT offtype, int startfrom);
00545 int dbgetpacket(DBPROCESS * dbproc);
00546 RETCODE dbgetrow(DBPROCESS * dbproc, DBINT row);
00547 int dbgettime(void);
00548 #define DBGETTIME dbgettime
00549 BYTE *dbgetuserdata(DBPROCESS * dbproc);
00550 DBBOOL dbhasretstat(DBPROCESS * dbproc);
00551 RETCODE dbinit(void);
00552 int dbiordesc(DBPROCESS * dbproc);
00553 
00554 #define DBIORDESC(x) dbiordesc((x))
00555 int dbiowdesc(DBPROCESS * dbproc);
00556 
00557 #define DBIOWDESC(x) dbiowdesc((x))
00558 DBBOOL dbisavail(DBPROCESS * dbprocess);
00559 
00560 #define DBISAVAIL(x) dbisavail((x))
00561 DBBOOL dbisopt(DBPROCESS * dbproc, int option, char *param);
00562 DBINT dblastrow(DBPROCESS * dbproc);
00563 
00564 #define DBLASTROW(x) dblastrow((x))
00565 RETCODE dbload_xlate(DBPROCESS * dbprocess, char *srv_charset, char *clt_name, DBXLATE ** xlt_tosrv, DBXLATE ** xlt_todisp);
00566 DBSORTORDER *dbloadsort(DBPROCESS * dbprocess);
00567 LOGINREC *dblogin(void);
00568 void dbloginfree(LOGINREC * login);
00569 RETCODE dbmny4add(DBPROCESS * dbproc, DBMONEY4 * m1, DBMONEY4 * m2, DBMONEY4 * sum);
00570 int dbmny4cmp(DBPROCESS * dbproc, DBMONEY4 * m1, DBMONEY4 * m2);
00571 RETCODE dbmny4copy(DBPROCESS * dbprocess, DBMONEY4 * m1, DBMONEY4 * m2);
00572 RETCODE dbmny4divide(DBPROCESS * dbproc, DBMONEY4 * m1, DBMONEY4 * m2, DBMONEY4 * quotient);
00573 RETCODE dbmny4minus(DBPROCESS * dbproc, DBMONEY4 * src, DBMONEY4 * dest);
00574 RETCODE dbmny4mul(DBPROCESS * dbproc, DBMONEY4 * m1, DBMONEY4 * m2, DBMONEY4 * prod);
00575 RETCODE dbmny4sub(DBPROCESS * dbproc, DBMONEY4 * m1, DBMONEY4 * m2, DBMONEY4 * diff);
00576 RETCODE dbmny4zero(DBPROCESS * dbproc, DBMONEY4 * dest);
00577 RETCODE dbmnyadd(DBPROCESS * dbproc, DBMONEY * m1, DBMONEY * m2, DBMONEY * sum);
00578 int dbmnycmp(DBPROCESS * dbproc, DBMONEY * m1, DBMONEY * m2);
00579 RETCODE dbmnycopy(DBPROCESS * dbproc, DBMONEY * src, DBMONEY * dest);
00580 RETCODE dbmnydec(DBPROCESS * dbproc, DBMONEY * mnyptr);
00581 RETCODE dbmnydivide(DBPROCESS * dbproc, DBMONEY * m1, DBMONEY * m2, DBMONEY * quotient);
00582 RETCODE dbmnydown(DBPROCESS * dbproc, DBMONEY * mnyptr, int divisor, int *remainder);
00583 RETCODE dbmnyinc(DBPROCESS * dbproc, DBMONEY * mnyptr);
00584 RETCODE dbmnyinit(DBPROCESS * dbproc, DBMONEY * mnyptr, int trim, DBBOOL * negative);
00585 RETCODE dbmnymaxneg(DBPROCESS * dbproc, DBMONEY * dest);
00586 RETCODE dbmnyndigit(DBPROCESS * dbproc, DBMONEY * mnyptr, DBCHAR * value, DBBOOL * zero);
00587 RETCODE dbmnymaxpos(DBPROCESS * dbproc, DBMONEY * dest);
00588 RETCODE dbmnyminus(DBPROCESS * dbproc, DBMONEY * src, DBMONEY * dest);
00589 RETCODE dbmnymul(DBPROCESS * dbproc, DBMONEY * m1, DBMONEY * m2, DBMONEY * prod);
00590 RETCODE dbmnydigit(DBPROCESS * dbprocess, DBMONEY * m1, DBCHAR * value, DBBOOL * zero);
00591 RETCODE dbmnyscale(DBPROCESS * dbproc, DBMONEY * dest, int multiplier, int addend);
00592 RETCODE dbmnysub(DBPROCESS * dbproc, DBMONEY * m1, DBMONEY * m2, DBMONEY * diff);
00593 RETCODE dbmnyzero(DBPROCESS * dbproc, DBMONEY * dest);
00594 const char *dbmonthname(DBPROCESS * dbproc, char *language, int monthnum, DBBOOL shortform);
00595 RETCODE dbmorecmds(DBPROCESS * dbproc);
00596 
00597 #define DBMORECMDS(x) dbmorecmds((x))
00598 RETCODE dbmoretext(DBPROCESS * dbproc, DBINT size, BYTE * text);
00599 MHANDLEFUNC dbmsghandle(MHANDLEFUNC handler);
00600 char *dbname(DBPROCESS * dbproc);
00601 RETCODE dbnextrow(DBPROCESS * dbproc);
00602 RETCODE dbnpcreate(DBPROCESS * dbprocess);
00603 RETCODE dbnpdefine(DBPROCESS * dbprocess, DBCHAR * procedure_name, DBSMALLINT namelen);
00604 RETCODE dbnullbind(DBPROCESS * dbproc, int column, DBINT * indicator);
00605 int dbnumalts(DBPROCESS * dbproc, int computeid);
00606 int dbnumcols(DBPROCESS * dbproc);
00607 int dbnumcompute(DBPROCESS * dbprocess);
00608 int DBNUMORDERS(DBPROCESS * dbprocess);
00609 int dbnumrets(DBPROCESS * dbproc);
00610 DBPROCESS *tdsdbopen(LOGINREC * login, const char *server, int msdblib);
00611 DBPROCESS *dbopen(LOGINREC * login, const char *server);
00612 
00613 #ifdef MSDBLIB
00614 #define   dbopen(x,y) tdsdbopen((x),(y), 1)
00615 #else
00616 #define   dbopen(x,y) tdsdbopen((x),(y), 0)
00617 #endif
00618 
00619 /* fix PHP problem */
00620 #ifdef PHP_SYBASE_DBOPEN
00621 #undef PHP_SYBASE_DBOPEN
00622 #define PHP_SYBASE_DBOPEN dbopen
00623 #endif
00624 
00625 int dbordercol(DBPROCESS * dbprocess, int order);
00626 RETCODE dbpoll(DBPROCESS * dbproc, long milliseconds, DBPROCESS ** ready_dbproc, int *return_reason);
00627 void dbprhead(DBPROCESS * dbproc);
00628 RETCODE dbprrow(DBPROCESS * dbproc);
00629 const char *dbprtype(int token);
00630 char *dbqual(DBPROCESS * dbprocess, int tabnum, char *tabname);
00631 DBBOOL DRBUF(DBPROCESS * dbprocess);
00632 DBINT dbreadpage(DBPROCESS * dbprocess, char *p_dbname, DBINT pageno, BYTE * buf);
00633 STATUS dbreadtext(DBPROCESS * dbproc, void *buf, DBINT bufsize);
00634 void dbrecftos(char *filename);
00635 RETCODE dbrecvpassthru(DBPROCESS * dbprocess, DBVOIDPTR * bufp);
00636 RETCODE dbregdrop(DBPROCESS * dbprocess, DBCHAR * procnm, DBSMALLINT namelen);
00637 RETCODE dbregexec(DBPROCESS * dbproc, DBUSMALLINT options);
00638 RETCODE dbreghandle(DBPROCESS * dbprocess, DBCHAR * procnm, DBSMALLINT namelen, INTFUNCPTR handler);
00639 RETCODE dbreginit(DBPROCESS * dbproc, DBCHAR * procedure_name, DBSMALLINT namelen);
00640 RETCODE dbreglist(DBPROCESS * dbproc);
00641 RETCODE dbregnowatch(DBPROCESS * dbprocess, DBCHAR * procnm, DBSMALLINT namelen);
00642 RETCODE dbregparam(DBPROCESS * dbproc, char *param_name, int type, DBINT datalen, BYTE * data);
00643 RETCODE dbregwatch(DBPROCESS * dbprocess, DBCHAR * procnm, DBSMALLINT namelen, DBUSMALLINT options);
00644 RETCODE dbregwatchlist(DBPROCESS * dbprocess);
00645 RETCODE dbresults(DBPROCESS * dbproc);
00646 RETCODE dbresults_r(DBPROCESS * dbproc, int recursive);
00647 BYTE *dbretdata(DBPROCESS * dbproc, int retnum);
00648 int dbretlen(DBPROCESS * dbproc, int retnum);
00649 char *dbretname(DBPROCESS * dbproc, int retnum);
00650 DBINT dbretstatus(DBPROCESS * dbproc);
00651 int dbrettype(DBPROCESS * dbproc, int retnum);
00652 RETCODE dbrows(DBPROCESS * dbproc);
00653 
00654 #define DBROWS(x) dbrows((x))
00655 STATUS dbrowtype(DBPROCESS * dbprocess);
00656 
00657 #define DBROWTYPE(x) dbrowtype((x))
00658 RETCODE dbrpcinit(DBPROCESS * dbproc, char *rpcname, DBSMALLINT options);
00659 RETCODE dbrpcparam(DBPROCESS * dbproc, char *paramname, BYTE status, int type, DBINT maxlen, DBINT datalen, BYTE * value);
00660 RETCODE dbrpcsend(DBPROCESS * dbproc);
00661 void dbrpwclr(LOGINREC * login);
00662 RETCODE dbrpwset(LOGINREC * login, char *srvname, char *password, int pwlen);
00663 RETCODE dbsafestr(DBPROCESS * dbproc, const char *src, DBINT srclen, char *dest, DBINT destlen, int quotetype);
00664 RETCODE *dbsechandle(DBINT type, INTFUNCPTR handler);
00665 RETCODE dbsendpassthru(DBPROCESS * dbprocess, DBVOIDPTR bufp);
00666 char *dbservcharset(DBPROCESS * dbprocess);
00667 void dbsetavail(DBPROCESS * dbprocess);
00668 void dbsetbusy(DBPROCESS * dbprocess, DB_DBBUSY_FUNC busyfunc);
00669 RETCODE dbsetdefcharset(char *charset);
00670 RETCODE dbsetdeflang(char *language);
00671 void dbsetidle(DBPROCESS * dbprocess, DB_DBIDLE_FUNC idlefunc);
00672 void dbsetifile(char *filename);
00673 void dbsetinterrupt(DBPROCESS * dbproc, DB_DBCHKINTR_FUNC chkintr, DB_DBHNDLINTR_FUNC hndlintr);
00674 RETCODE dbsetloginfo(LOGINREC * loginrec, DBLOGINFO * loginfo);
00675 RETCODE dbsetlogintime(int seconds);
00676 RETCODE dbsetmaxprocs(int maxprocs);
00677 RETCODE dbsetnull(DBPROCESS * dbprocess, int bindtype, int bindlen, BYTE * bindval);
00678 RETCODE dbsetopt(DBPROCESS * dbproc, int option, const char *char_param, int int_param);
00679 STATUS dbsetrow(DBPROCESS * dbprocess, DBINT row);
00680 RETCODE dbsettime(int seconds);
00681 void dbsetuserdata(DBPROCESS * dbproc, BYTE * ptr);
00682 RETCODE dbsetversion(DBINT version);
00683 
00684 int dbspid(DBPROCESS * dbproc);
00685 RETCODE dbspr1row(DBPROCESS * dbproc, char *buffer, DBINT buf_len);
00686 DBINT dbspr1rowlen(DBPROCESS * dbproc);
00687 RETCODE dbsprhead(DBPROCESS * dbproc, char *buffer, DBINT buf_len);
00688 RETCODE dbsprline(DBPROCESS * dbproc, char *buffer, DBINT buf_len, DBCHAR line_char);
00689 RETCODE dbsqlexec(DBPROCESS * dbproc);
00690 RETCODE dbsqlok(DBPROCESS * dbproc);
00691 RETCODE dbsqlsend(DBPROCESS * dbproc);
00692 int dbstrbuild(DBPROCESS * dbproc, char *charbuf, int bufsize, char *text, char *formats, ...);
00693 int dbstrcmp(DBPROCESS * dbprocess, char *s1, int l1, char *s2, int l2, DBSORTORDER * sort);
00694 RETCODE dbstrcpy(DBPROCESS * dbproc, int start, int numbytes, char *dest);
00695 int dbstrlen(DBPROCESS * dbproc);
00696 int dbstrsort(DBPROCESS * dbprocess, char *s1, int l1, char *s2, int l2, DBSORTORDER * sort);
00697 DBBOOL dbtabbrowse(DBPROCESS * dbprocess, int tabnum);
00698 int dbtabcount(DBPROCESS * dbprocess);
00699 char *dbtabname(DBPROCESS * dbprocess, int tabnum);
00700 char *dbtabsoruce(DBPROCESS * dbprocess, int colnum, int *tabnum);
00701 DBINT dbvarylen(DBPROCESS * dbproc, int column);
00702 
00703 #define SYBEICONVIU      2400   /* Some character(s) could not be converted into client's character set. */
00704 #define SYBEICONVAVAIL   2401   /* Character set conversion is not available between client character set '%.*s' and server character set '%.*s'.*/
00705 #define SYBEICONVO       2402   /* Error converting characters into server's character set. Some character(s) could not be converted.*/
00706 #define SYBEICONVI       2403   /* Some character(s) could not be converted into client's character set.  Unconverted bytes were changed to question marks ('?').*/
00707 #define SYBEICONV2BIG    2404   /* Buffer overflow converting characters from client into server's character set.*/
00708                                 /* cf. doc/dblib_errors.txt for more iconv error values. */
00709                                 /* Reserve a few slots for other iconv-related issues. */
00710 #define SYBETDSVER       2410   /* Cannot bcp with TDSVER < 5.0 */
00711 #define SYBESYNC        20001   /* Read attempted while out of synchronization with SQL Server. */
00712 #define SYBEFCON        20002   /* SQL Server connection failed. */
00713 #define SYBETIME        20003   /* SQL Server connection timed out. */
00714 #define SYBEREAD        20004   /* Read from SQL Server failed. */
00715 #define SYBEBUFL        20005   /* DB-LIBRARY internal error - send buffer length corrupted. */
00716 #define SYBEWRIT        20006   /* Write to SQL Server failed. */
00717 #define SYBEVMS         20007   /* Sendflush: VMS I/O error. */
00718 #define SYBESOCK        20008   /* Unable to open socket */
00719 #define SYBECONN        20009   /* Unable to connect socket -- SQL Server is unavailable or does not exist. */
00720 #define SYBEMEM         20010   /* Unable to allocate sufficient memory */
00721 #define SYBEDBPS        20011   /* Maximum number of DBPROCESSes already allocated. */
00722 #define SYBEINTF        20012   /* Server name not found in interface file */
00723 #define SYBEUHST        20013   /* Unknown host machine name */
00724 #define SYBEPWD         20014   /* Incorrect password. */
00725 #define SYBEOPIN        20015   /* Could not open interface file. */
00726 #define SYBEINLN        20016   /* Interface file: unexpected end-of-line. */
00727 #define SYBESEOF        20017   /* Unexpected EOF from SQL Server. */
00728 #define SYBESMSG        20018   /* General SQL Server error: Check messages from the SQL Server. */
00729 #define SYBERPND        20019   /* Attempt to initiate a new SQL Server operation with results pending. */
00730 #define SYBEBTOK        20020   /* Bad token from SQL Server: Data-stream processing out of sync. */
00731 #define SYBEITIM        20021   /* Illegal timeout value specified. */
00732 #define SYBEOOB         20022   /* Error in sending out-of-band data to SQL Server. */
00733 #define SYBEBTYP        20023   /* Unknown bind type passed to DB-LIBRARY function. */
00734 #define SYBEBNCR        20024   /* Attempt to bind user variable to a non-existent compute row. */
00735 #define SYBEIICL        20025   /* Illegal integer column length returned by SQL Server. Legal integer lengths are 1, 2, and 4 bytes. */
00736 #define SYBECNOR        20026   /* Column number out of range. */
00737 #define SYBENPRM        20027   /* NULL parameter not allowed for this dboption. */
00738 #define SYBEUVDT        20028   /* Unknown variable-length datatype encountered. */
00739 #define SYBEUFDT        20029   /* Unknown fixed-length datatype encountered. */
00740 #define SYBEWAID        20030   /* DB-LIBRARY internal error: ALTFMT following ALTNAME has wrong id. */
00741 #define SYBECDNS        20031   /* Datastream indicates that a compute column is derived from a non-existent select-list member. */
00742 #define SYBEABNC        20032   /* Attempt to bind to a non-existent column. */
00743 #define SYBEABMT        20033   /* User attempted a dbbind() with mismatched column and variable types. */
00744 #define SYBEABNP        20034   /* Attempt to bind using NULL pointers. */
00745 #define SYBEAAMT        20035   /* User attempted a dbaltbind() with mismatched column and variable types. */
00746 #define SYBENXID        20036   /* The Server did not grant us a distributed-transaction ID. */
00747 #define SYBERXID        20037   /* The Server did not recognize our distributed-transaction ID. */
00748 #define SYBEICN         20038   /* Invalid computeid or compute column number. */
00749 #define SYBENMOB        20039   /* No such member of 'order by' clause. */
00750 #define SYBEAPUT        20040   /* Attempt to print unknown token. */
00751 #define SYBEASNL        20041   /* Attempt to set fields in a null loginrec. */
00752 #define SYBENTLL        20042   /* Name too long for loginrec field. */
00753 #define SYBEASUL        20043   /* Attempt to set unknown loginrec field. */
00754 #define SYBERDNR        20044   /* Attempt to retrieve data from a non-existent row. */
00755 #define SYBENSIP        20045   /* Negative starting index passed to dbstrcpy(). */
00756 #define SYBEABNV        20046   /* Attempt to bind to a NULL program variable. */
00757 #define SYBEDDNE        20047   /* DBPROCESS is dead or not enabled. */
00758 #define SYBECUFL        20048   /* Data-conversion resulted in underflow. */
00759 #define SYBECOFL        20049   /* Data-conversion resulted in overflow. */
00760 #define SYBECSYN        20050   /* Attempt to convert data stopped by syntax error in source field. */
00761 #define SYBECLPR        20051   /* Data-conversion resulted in loss of precision. */
00762 #define SYBECNOV        20052   /* Attempt to set variable to NULL resulted in overflow. */
00763 #define SYBERDCN        20053   /* Requested data-conversion does not exist. */
00764 #define SYBESFOV        20054   /* dbsafestr() overflowed its destination buffer. */
00765 #define SYBEUNT         20055   /* Unknown network type found in interface file. */
00766 #define SYBECLOS        20056   /* Error in closing network connection. */
00767 #define SYBEUAVE        20057   /* Unable to allocate VMS event flag. */
00768 #define SYBEUSCT        20058   /* Unable to set communications timer. */
00769 #define SYBEEQVA        20059   /* Error in queueing VMS AST routine. */
00770 #define SYBEUDTY        20060   /* Unknown datatype encountered. */
00771 #define SYBETSIT        20061   /* Attempt to call dbtsput() with an invalid timestamp. */
00772 #define SYBEAUTN        20062   /* Attempt to update the timestamp of a table which has no timestamp column. */
00773 #define SYBEBDIO        20063   /* Bad bulk-copy direction.  Must be either IN or OUT. */
00774 #define SYBEBCNT        20064   /* Attempt to use Bulk Copy with a non-existent Server table. */
00775 #define SYBEIFNB        20065   /* Illegal field number passed to bcp_control(). */
00776 #define SYBETTS         20066   /* The table which bulk-copy is attempting to copy to a host-file is shorter than the number of rows which bulk-copy was instructed to skip. */
00777 #define SYBEKBCO        20067   /* 1000 rows successfully bulk-copied to host-file. */
00778 #define SYBEBBCI        20068   /* Batch successfully bulk-copied to SQL Server. */
00779 #define SYBEKBCI        20069   /* Bcp: 1000 rows sent to SQL Server. */
00780 #define SYBEBCRE        20070   /* I/O error while reading bcp data-file. */
00781 #define SYBETPTN        20071   /* Syntax error: only two periods are permitted in table names. */
00782 #define SYBEBCWE        20072   /* I/O error while writing bcp data-file. */
00783 #define SYBEBCNN        20073   /* Attempt to bulk-copy a NULL value into Server column %d,  which does not accept NULL values. */
00784 #define SYBEBCOR        20074   /* Attempt to bulk-copy an oversized row to the SQL Server. */
00785 #define SYBEBCIS        20075   /* Attempt to bulk-copy an illegally-sized column value to the SQL Server. */
00786 #define SYBEBCPI        20076   /* bcp_init() must be called before any other bcp routines. */
00787 #define SYBEBCPN        20077   /* bcp_bind(), bcp_collen(), bcp_colptr(), bcp_moretext() and bcp_sendrow() may be used only after bcp_init() has been called with the copy direction set to DB_IN. */
00788 #define SYBEBCPB        20078   /* bcp_bind(), bcp_moretext() and bcp_sendrow() may NOT be used after bcp_init() has been passed a non-NULL input file name. */
00789 #define SYBEVDPT        20079   /* For bulk copy, all variable-length data must have either a length-prefix or a terminator specified. */
00790 #define SYBEBIVI        20080   /* bcp_columns(), bcp_colfmt() and bcp_colfmt_ps() may be used only after bcp_init() has been passed a valid input file. */
00791 #define SYBEBCBC        20081   /* bcp_columns() must be called before bcp_colfmt() and bcp_colfmt_ps(). */
00792 #define SYBEBCFO        20082   /* Bcp host-files must contain at least one column. */
00793 #define SYBEBCVH        20083   /* bcp_exec() may be called only after bcp_init() has been passed a valid host file. */
00794 #define SYBEBCUO        20084   /* Bcp: Unable to open host data-file. */
00795 #define SYBEBCUC        20085   /* Bcp: Unable to close host data-file. */
00796 #define SYBEBUOE        20086   /* Bcp: Unable to open error-file. */
00797 #define SYBEBUCE        20087   /* Bcp: Unable to close error-file. */
00798 #define SYBEBWEF        20088   /* I/O error while writing bcp error-file. */
00799 #define SYBEASTF        20089   /* VMS: Unable to setmode for control_c ast. */
00800 #define SYBEUACS        20090   /* VMS: Unable to assign channel to sys$command. */
00801 #define SYBEASEC        20091   /* Attempt to send an empty command buffer to the SQL Server. */
00802 #define SYBETMTD        20092   /* Attempt to send too much TEXT data via the dbmoretext() call. */
00803 #define SYBENTTN        20093   /* Attempt to use dbtxtsput() to put a new text-timestamp into a non-existent data row. */
00804 #define SYBEDNTI        20094   /* Attempt to use dbtxtsput() to put a new text-timestamp into a column whose datatype is neither SYBTEXT nor SYBIMAGE. */
00805 #define SYBEBTMT        20095   /* Attempt to send too much TEXT data via the bcp_moretext() call. */
00806 #define SYBEORPF        20096   /* Attempt to set remote password would overflow the login-record's remote-password field. */
00807 #define SYBEUVBF        20097   /* Attempt to read an unknown version of BCP format-file. */
00808 #define SYBEBUOF        20098   /* Bcp: Unable to open format-file. */
00809 #define SYBEBUCF        20099   /* Bcp: Unable to close format-file. */
00810 #define SYBEBRFF        20100   /* I/O error while reading bcp format-file. */
00811 #define SYBEBWFF        20101   /* I/O error while writing bcp format-file. */
00812 #define SYBEBUDF        20102   /* Bcp: Unrecognized datatype found in format-file. */
00813 #define SYBEBIHC        20103   /* Incorrect host-column number found in bcp format-file. */
00814 #define SYBEBEOF        20104   /* Unexpected EOF encountered in BCP data-file. */
00815 #define SYBEBCNL        20105   /* Negative length-prefix found in BCP data-file. */
00816 #define SYBEBCSI        20106   /* Host-file columns may be skipped only when copying INto the Server. */
00817 #define SYBEBCIT        20107   /* It's illegal to use BCP terminators with program variables other than SYBCHAR, SYBBINARY, SYBTEXT, or SYBIMAGE. */
00818 #define SYBEBCSA        20108   /* The BCP hostfile '%s' contains only %ld rows. Skipping all of these rows is not allowed. */
00819 #define SYBENULL        20109   /* NULL DBPROCESS pointer passed to DB-Library. */
00820 #define SYBEUNAM        20110   /* Unable to get current username from operating system. */
00821 #define SYBEBCRO        20111   /* The BCP hostfile '%s' contains only %ld rows. It was impossible to read the requested %ld rows. */
00822 #define SYBEMPLL        20112   /* Attempt to set maximum number of DBPROCESSes lower than 1. */
00823 #define SYBERPIL        20113   /* It is illegal to pass -1 to dbrpcparam() for the datalen of parameters which are of type SYBCHAR, SYBVARCHAR, SYBBINARY, or SYBVARBINARY. */
00824 #define SYBERPUL        20114   /* When passing a SYBINTN, SYBDATETIMN, SYBMONEYN, or SYBFLTN parameter via dbrpcparam(), it's necessary to specify the parameter's maximum or actual length, so that DB-Library can recognize it as a SYBINT1, SYBINT2, SYBINT4, SYBMONEY, or SYBMONEY4, etc. */
00825 #define SYBEUNOP        20115   /* Unknown option passed to dbsetopt(). */
00826 #define SYBECRNC        20116   /* The current row is not a result of compute clause %d, so it is illegal to attempt to extract that data from this row. */
00827 #define SYBERTCC        20117   /* dbreadtext() may not be used to receive the results of a query which contains a COMPUTE clause. */
00828 #define SYBERTSC        20118   /* dbreadtext() may only be used to receive the results of a query which contains a single result column. */
00829 #define SYBEUCRR        20119   /* Internal software error: Unknown connection result reported by                                                 * dbpasswd(). */
00830 #define SYBERPNA        20120   /* The RPC facility is available only when using a SQL Server whose version number is 4.0 or greater. */
00831 #define SYBEOPNA        20121   /* The text/image facility is available only when using a SQL Server whose version number is 4.0 or greater. */
00832 #define SYBEFGTL        20122   /* Bcp: Row number of the first row to be copied cannot be greater than the row number for the last row to be copied.  */
00833 #define SYBECWLL        20123   /* Attempt to set column width less than 1.  */
00834 #define SYBEUFDS        20124   /* Unrecognized format encountered in dbstrbuild(). */
00835 #define SYBEUCPT        20125   /* Unrecognized custom-format parameter-type encountered in dbstrbuild(). */
00836 #define SYBETMCF        20126   /* Attempt to install too many custom formats via dbfmtinstall(). */
00837 #define SYBEAICF        20127   /* Error in attempting to install custom format. */
00838 #define SYBEADST        20128   /* Error in attempting to determine the size of a pair of translation tables. */
00839 #define SYBEALTT        20129   /* Error in attempting to load a pair of translation tables. */
00840 #define SYBEAPCT        20130   /* Error in attempting to perform a character-set translation. */
00841 #define SYBEXOCI        20131   /* A character-set translation overflowed its destination buffer while using bcp to copy data from a host-file to the SQL Server. */
00842 #define SYBEFSHD        20132   /* Error in attempting to find the Sybase home directory. */
00843 #define SYBEAOLF        20133   /* Error in attempting to open a localization file. */
00844 #define SYBEARDI        20134   /* Error in attempting to read datetime information from a localization file. */
00845 #define SYBEURCI        20135   /* Unable to read copyright information from the dblib localization file. */
00846 #define SYBEARDL        20136   /* Error in attempting to read the dblib.loc localization file. */
00847 #define SYBEURMI        20137   /* Unable to read money-format information from the dblib localization file. */
00848 #define SYBEUREM        20138   /* Unable to read error mnemonic from the dblib localization file. */
00849 #define SYBEURES        20139   /* Unable to read error string from the dblib localization file. */
00850 #define SYBEUREI        20140   /* Unable to read error information from the dblib localization file. */
00851 #define SYBEOREN        20141   /* Warning: an out-of-range error-number was encountered in dblib.loc. The maximum permissible error-number is defined as DBERRCOUNT in sybdb.h. */
00852 #define SYBEISOI        20142   /* Invalid sort-order information found. */
00853 #define SYBEIDCL        20143   /* Illegal datetime column length returned by DataServer. Legal datetime lengths are 4 and 8 bytes. */
00854 #define SYBEIMCL        20144   /* Illegal money column length returned by DataServer. Legal money lengths are 4 and 8 bytes. */
00855 #define SYBEIFCL        20145   /* Illegal floating-point column length returned by DataServer. Legal floating-point lengths are 4 and 8 bytes. */
00856 #define SYBEUTDS        20146   /* Unrecognized TDS version received from SQL Server. */
00857 #define SYBEBUFF        20147   /* Bcp: Unable to create format-file. */
00858 #define SYBEACNV        20148   /* Attemp to do conversion with NULL destination variable. */
00859 #define SYBEDPOR        20149   /* Out-of-range datepart constant. */
00860 #define SYBENDC         20150   /* Cannot have negative component in date in numeric form. */
00861 #define SYBEMVOR        20151   /* Month values must be between 1 and 12. */
00862 #define SYBEDVOR        20152   /* Day values must be between 1 and 7. */
00863 #define SYBENBVP        20153   /* Cannot pass dbsetnull() a NULL bindval pointer. */
00864 #define SYBESPID        20154   /* Called dbspid() with a NULL dbproc. */
00865 #define SYBENDTP        20155   /* Called dbdatecrack() with a NULL datetime  parameter. */
00866 #define SYBEXTN         20156   /* The xlt_todisp and xlt_tosrv parameters to dbfree_xlate() were NULL. */
00867 #define SYBEXTDN        20157   /* Warning:  the xlt_todisp parameter to dbfree_xlate() was NULL.  The space associated with the xlt_tosrv parameter has been freed. */
00868 #define SYBEXTSN        20158   /* Warning:  the xlt_tosrv parameter to dbfree_xlate() was NULL.  The space associated with the xlt_todisp parameter has been freed. */
00869 #define SYBENUM         20159   /* Incorrect number of arguments given  to DB-Library.  */
00870 #define SYBETYPE        20160   /* Invalid argument type given to DB-Library. */
00871 #define SYBEGENOS       20161   /* General Operating System Error. */
00872 #define SYBEPAGE        20162   /* wrong resource type or length given for  dbpage() operation.  */
00873 #define SYBEOPTNO       20163   /* Option is not allowed or is unreconized */
00874 #define SYBEETD         20164   /* Failure to send the expected amount of  TEXT or IMAGE data via dbmoretext(). */
00875 #define SYBERTYPE       20165   /* Invalid resource type given to DB-Library. */
00876 #define SYBERFILE       20166   /* "Can not open resource file." */
00877 #define SYBEFMODE       20167   /* Read/Write/Append mode denied on file. */
00878 #define SYBESLCT        20168   /* Could not select or copy field specified */
00879 #define SYBEZTXT        20169   /* Attempt to send zero length TEXT or  IMAGE to dataserver via dbwritetext(). */
00880 #define SYBENTST        20170   /* The file being opened must be a stream_lf. */
00881 #define SYBEOSSL        20171   /* Operating system login level not in range of Secure SQL Server */
00882 #define SYBEESSL        20172   /* Login security level entered does not agree with operating system level */
00883 #define SYBENLNL        20173   /* Program not linked with specified network library. */
00884 #define SYBENHAN        20174   /* called dbrecvpassthru() with a NULL handler parameter. */
00885 #define SYBENBUF        20175   /* called dbsendpassthru() with a NULL buf pointer. */
00886 #define SYBENULP        20176   /* Called %s with a NULL %s parameter. */
00887 #define SYBENOTI        20177   /* No event handler installed. */
00888 #define SYBEEVOP        20178   /* Called dbregwatch() with a bad options parameter. */
00889 #define SYBENEHA        20179   /* Called dbreghandle() with a NULL handler parameter. */
00890 #define SYBETRAN        20180   /* DBPROCESS is being used for another transaction. */
00891 #define SYBEEVST        20181   /* Must initiate a transaction before calling dbregparam(). */
00892 #define SYBEEINI        20182   /* Must call dbreginit() before dbregraise(). */
00893 #define SYBEECRT        20183   /* Must call dbregdefine() before dbregcreate(). */
00894 #define SYBEECAN        20184   /* Attempted to cancel unrequested event notification. */
00895 #define SYBEEUNR        20185   /* Unsolicited event notification received. */
00896 #define SYBERPCS        20186   /* Must call dbrpcinit() before dbrpcparam(). */
00897 #define SYBETPAR        20187   /* No SYBTEXT or SYBIMAGE parameters were defined. */
00898 #define SYBETEXS        20188   /* Called dbmoretext() with a bad size parameter. */
00899 #define SYBETRAC        20189   /* Attempted to turn off a trace flag that was not on. */
00900 #define SYBETRAS        20190   /* DB-Library internal error - trace structure not found. */
00901 #define SYBEPRTF        20191   /* dbtracestring() may only be called from a printfunc(). */
00902 #define SYBETRSN        20192   /* Bad numbytes parameter passed to dbtracestring(). */
00903 #define SYBEBPKS        20193   /* In DBSETLPACKET(), the packet size parameter must be between 0 and 999999. */
00904 #define SYBEIPV         20194   /* %1! is an illegal value for the %2! parameter of %3!. */
00905 #define SYBEMOV         20195   /* Money arithmetic resulted in overflow in function %1!. */
00906 #define SYBEDIVZ        20196   /* Attempt to divide by $0.00 in function %1!. */
00907 #define SYBEASTL        20197   /* Synchronous I/O attempted at AST level. */
00908 #define SYBESEFA        20198   /* DBSETNOTIFS cannot be called if connections are present. */
00909 #define SYBEPOLL        20199   /* Only one dbpoll() can be active at a time. */
00910 #define SYBENOEV        20200   /* dbpoll() cannot be called if registered procedure notifications have been disabled. */
00911 #define SYBEBADPK       20201   /* Packet size of %1! not supported. -- size of %2! used instead. */
00912 #define SYBESECURE      20202   /* Secure Server function not supported in this version. */
00913 #define SYBECAP         20203   /* DB-Library capabilities not accepted by the Server. */
00914 #define SYBEFUNC        20204   /* Functionality not supported at the specified version level. */
00915 #define SYBERESP        20205   /* Response function address passed to dbresponse() must be non-NULL. */
00916 #define SYBEIVERS       20206   /* Illegal version level specified. */
00917 #define SYBEONCE        20207   /* Function can be called only once. */
00918 #define SYBERPNULL      20208   /* value parameter for dbprcparam() can be NULL, only if the datalen parameter is 0 */
00919 #define SYBERPTXTIM     20209   /* RPC parameters cannot be of type Text/Image. */
00920 #define SYBENEG         20210   /* Negotiated login attempt failed. */
00921 #define SYBELBLEN       20211   /* Security labels should be less than 256 characters long. */
00922 #define SYBEUMSG        20212   /* Unknown message-id in MSG datastream. */
00923 #define SYBECAPTYP      20213   /* Unexpected capability type in CAPABILITY datastream. */
00924 #define SYBEBNUM        20214   /* Bad numbytes parameter passed to dbstrcpy() */
00925 #define SYBEBBL         20215   /* Bad bindlen parameter passed to dbsetnull() */
00926 #define SYBEBPREC       20216   /* Illegal precision specified */
00927 #define SYBEBSCALE      20217   /* Illegal scale specified */
00928 #define SYBECDOMAIN     20218   /* Source field value is not within the domain of legal values. */
00929 #define SYBECINTERNAL   20219   /* Internal Conversion error. */
00930 #define SYBEBTYPSRV     20220   /* Datatype is not supported by the server. */
00931 #define SYBEBCSET       20221   /* Unknown character-set encountered." */
00932 #define SYBEFENC        20222   /* Password Encryption failed." */
00933 #define SYBEFRES        20223   /* Challenge-Response function failed.", */
00934 #define SYBEISRVPREC    20224   /* Illegal precision value returned by the server. */
00935 #define SYBEISRVSCL     20225   /* Illegal scale value returned by the server. */
00936 #define SYBEINUMCL      20226   /* Invalid numeric column length returned by the server. */
00937 #define SYBEIDECCL      20227   /* Invalid decimal column length returned by the server. */
00938 #define SYBEBCMTXT      20228   /* bcp_moretext() may be used only when there is at least one text or image column in the server table. */
00939 #define SYBEBCPREC      20229   /* Column %1!: Illegal precision value encountered. */
00940 #define SYBEBCBNPR      20230   /* bcp_bind(): if varaddr is NULL, prefixlen must be 0 and no terminator should be specified. */
00941 #define SYBEBCBNTYP     20231   /* bcp_bind(): if varaddr is NULL and varlen greater than 0, the table column type must be SYBTEXT or SYBIMAGE and the program variable type must be SYBTEXT, SYBCHAR, SYBIMAGE or SYBBINARY. */
00942 #define SYBEBCSNTYP     20232   /* column number %1!: if varaddr is NULL and varlen greater than 0, the table column type must be SYBTEXT or SYBIMAGE and the program variable type must be SYBTEXT, SYBCHAR, SYBIMAGE or SYBBINARY. */
00943 #define SYBEBCPCTYP     20233   /* bcp_colfmt(): If table_colnum is 0, host_type cannot be 0. */
00944 #define SYBEBCVLEN      20234   /* varlen should be greater than or equal to -1. */
00945 #define SYBEBCHLEN      20235   /* host_collen should be greater than or equal to -1. */
00946 #define SYBEBCBPREF     20236   /* Illegal prefix length. Legal values are 0, 1, 2 or 4. */
00947 #define SYBEBCPREF      20237   /* Illegal prefix length. Legal values are -1, 0, 1, 2 or 4. */
00948 #define SYBEBCITBNM     20238   /* bcp_init(): tblname parameter cannot be NULL. */
00949 #define SYBEBCITBLEN    20239   /* bcp_init(): tblname parameter is too long. */
00950 #define SYBEBCSNDROW    20240   /* bcp_sendrow() may NOT be called unless all text data for the previous row has been sent using bcp_moretext(). */
00951 #define SYBEBPROCOL     20241   /* bcp protocol error: returned column count differs from the actual number of columns received. */
00952 #define SYBEBPRODEF     20242   /* bcp protocol error: expected default information and got none. */
00953 #define SYBEBPRONUMDEF  20243   /* bcp protocol error: expected number of defaults differs from the actual number of defaults received. */
00954 #define SYBEBPRODEFID   20244   /* bcp protocol error: default column id and actual column id are not same */
00955 #define SYBEBPRONODEF   20245   /* bcp protocol error:  default value received for column that does not have default. */
00956 #define SYBEBPRODEFTYP  20246   /* bcp protocol error:  default value datatype differs from column datatype. */
00957 #define SYBEBPROEXTDEF  20247   /* bcp protocol error: more than one row of default information received. */
00958 #define SYBEBPROEXTRES  20248   /* bcp protocol error: unexpected set of results received. */
00959 #define SYBEBPROBADDEF  20249   /* bcp protocol error: illegal default column id received. */
00960 #define SYBEBPROBADTYP  20250   /* bcp protocol error: unknown column datatype. */
00961 #define SYBEBPROBADLEN  20251   /* bcp protocol error: illegal datatype length received. */
00962 #define SYBEBPROBADPREC 20252   /* bcp protocol error: illegal precision value received. */
00963 #define SYBEBPROBADSCL  20253   /* bcp protocol error: illegal scale value received. */
00964 #define SYBEBADTYPE     20254   /* Illegal value for type parameter  given to %1!. */
00965 #define SYBECRSNORES    20255   /* Cursor statement generated no results. */
00966 #define SYBECRSNOIND    20256   /* One of the tables involved in the cursor  statement does not have a unique index. */
00967 #define SYBECRSVIEW     20257   /* A view cannot be joined with another table  or a view in a cursor statement. */
00968 #define SYBECRSVIIND    20258   /* The view used in the cursor statement does  not include all the unique index columns of  the underlying tables. */
00969 #define SYBECRSORD      20259   /* Only fully keyset driven cursors can have 'order by', ' group by', or 'having' phrases. */
00970 #define SYBECRSBUFR     20260   /* Row buffering should not be turned on when  using cursor APIs. */
00971 #define SYBECRSNOFREE   20261   /* The DBNOAUTOFREE option should not be  turned on when using cursor APIs. */
00972 #define SYBECRSDIS      20262   /* Cursor statement contains one of the  disallowed phrases 'compute', 'union', 'for browse', or 'select into'. */
00973 #define SYBECRSAGR      20263   /* Aggregate functions are not allowed in a  cursor statement. */
00974 #define SYBECRSFRAND    20264   /* Fetch types RANDOM and RELATIVE can only be  used within the keyset of keyset driven  cursors. */
00975 #define SYBECRSFLAST    20265   /* Fetch type LAST requires fully keyset  driven cursors. */
00976 #define SYBECRSBROL     20266   /* Backward scrolling cannot be used in a  forward scrolling cursor. */
00977 #define SYBECRSFROWN    20267   /* Row number to be fetched is outside valid  range. */
00978 #define SYBECRSBSKEY    20268   /* Keyset cannot be scrolled backward in mixed  cursors with a previous fetch type. */
00979 #define SYBECRSRO       20269   /* Data locking or modifications cannot be  made in a READONLY cursor. */
00980 #define SYBECRSNOCOUNT  20270   /* The DBNOCOUNT option should not be  turned on when doing updates or deletes with  dbcursor(). */
00981 #define SYBECRSTAB      20271   /* Table name must be determined in operations  involving data locking or modifications. */
00982 #define SYBECRSUPDNB    20272   /* Update or insert operations cannot use bind  variables when binding type is NOBIND. */
00983 #define SYBECRSNOWHERE  20273   /* A WHERE clause is not allowed in a cursor  update or insert. */
00984 #define SYBECRSSET      20274   /* A SET clause is required for a cursor  update or insert.  */
00985 #define SYBECRSUPDTAB   20275   /* Update or insert operations using bind  variables require single table cursors. */
00986 #define SYBECRSNOUPD    20276   /* Update or delete operation did not affect  any rows. */
00987 #define SYBECRSINV      20277   /* Invalid cursor statement. */
00988 #define SYBECRSNOKEYS   20278   /* The entire keyset must be defined for KEYSET cursors. */
00989 #define SYBECRSNOBIND   20279   /* Cursor bind must be called prior to updating cursor */
00990 #define SYBECRSFTYPE    20280   /* Unknown fetch type. */
00991 #define SYBECRSINVALID  20281   /* The cursor handle is invalid. */
00992 #define SYBECRSMROWS    20282   /* Multiple rows are returned, only one is expected. */
00993 #define SYBECRSNROWS    20283   /* No rows returned, at least one is expected. */
00994 #define SYBECRSNOLEN    20284   /* No unique index found. */
00995 #define SYBECRSNOPTCC   20285   /* No OPTCC was found. */
00996 #define SYBECRSNORDER   20286   /* The order of clauses must be from, where, and order by. */
00997 #define SYBECRSNOTABLE  20287   /* Table name is NULL. */
00998 #define SYBECRSNUNIQUE  20288   /* No unique keys associated with this view. */
00999 #define SYBECRSVAR      20289   /* There is no valid address associated with this bind. */
01000 #define SYBENOVALUE     20290   /* Security labels require both a name and a value */
01001 #define SYBEVOIDRET     20291   /* Parameter of type SYBVOID cannot  be a return parameter. */
01002 #define SYBECLOSEIN     20292   /* Unable to close interface file. */
01003 #define SYBEBOOL        20293   /* Boolean parameters must be TRUE or FALSE. */
01004 #define SYBEBCPOPT      20294   /* The  option cannot be called while a bulk copy operation is progress. */
01005 #define SYBEERRLABEL    20295   /* An illegal value was returned from the security label handler. */
01006 #define SYBEATTNACK     20296   /* Timed out waiting for server to acknowledge attention." */
01007 #define SYBEBBFL        20297   /* -001- Batch failed in bulk-copy to SQL Server */
01008 #define SYBEDCL         20298   /* -004- DCL Error */
01009 #define SYBECS          20299   /* -004- cs context Error */
01010 #define SYBEBULKINSERT  20599   /* cannot build bulk insert statement */
01011 
01012 int dbtds(DBPROCESS * dbprocess);
01013 
01014 #define DBTDS(a)                dbtds(a)
01015 DBINT dbtextsize(DBPROCESS * dbprocess);
01016 int dbtsnewlen(DBPROCESS * dbprocess);
01017 DBBINARY *dbtsnewval(DBPROCESS * dbprocess);
01018 RETCODE dbtsput(DBPROCESS * dbprocess, DBBINARY * newts, int newtslen, int tabnum, char *tabname);
01019 DBBINARY *dbtxptr(DBPROCESS * dbproc, int column);
01020 DBBINARY *dbtxtimestamp(DBPROCESS * dbproc, int column);
01021 DBBINARY *dbtxtsnewval(DBPROCESS * dbprocess);
01022 RETCODE dbtxtsput(DBPROCESS * dbprocess, DBBINARY newtxts, int colnum);
01023 RETCODE dbuse(DBPROCESS * dbproc, const char *name);
01024 const char *dbversion(void);
01025 DBBOOL dbwillconvert(int srctype, int desttype);
01026 RETCODE dbwritepage(DBPROCESS * dbprocess, char *p_dbname, DBINT pageno, DBINT size, BYTE * buf);
01027 RETCODE dbwritetext(DBPROCESS * dbproc, char *objname, DBBINARY * textptr, DBTINYINT textptrlen, DBBINARY * timestamp,
01028                     DBBOOL log, DBINT size, BYTE * text);
01029 int dbxlate(DBPROCESS * dbprocess, char *src, int srclen, char *dest, int destlen, DBXLATE * xlt, int *srcbytes_used,
01030             DBBOOL srcend, int status);
01031 
01032 /* LOGINREC manipulation */
01033 RETCODE dbsetlname(LOGINREC * login, const char *value, int which);
01034 RETCODE dbsetlbool(LOGINREC * login, int value, int which);
01035 RETCODE dbsetlshort(LOGINREC * login, int value, int which);
01036 RETCODE dbsetllong(LOGINREC * login, long value, int which);
01037 RETCODE dbsetlversion (LOGINREC * login, BYTE version);
01038 
01039 #define DBSETHOST               1
01040 #define DBSETLHOST(x,y)         dbsetlname((x), (y), DBSETHOST)
01041 #define dbsetlhost(x,y)         dbsetlname((x), (y), DBSETHOST)
01042 #define DBSETUSER               2
01043 #define DBSETLUSER(x,y)         dbsetlname((x), (y), DBSETUSER)
01044 #define dbsetluser(x,y)         dbsetlname((x), (y), DBSETUSER)
01045 #define DBSETPWD                3
01046 #define DBSETLPWD(x,y)          dbsetlname((x), (y), DBSETPWD)
01047 #define dbsetlpwd(x,y)          dbsetlname((x), (y), DBSETPWD)
01048 #define DBSETHID                4       /* not implemented */
01049 #define DBSETLHID(x,y)          dbsetlname((x), (y), DBSETHID)
01050 #define DBSETAPP                5
01051 #define DBSETLAPP(x,y)          dbsetlname((x), (y), DBSETAPP)
01052 #define dbsetlapp(x,y)          dbsetlname((x), (y), DBSETAPP)
01053 #define DBSETBCP                6
01054 #define BCP_SETL(x,y)           dbsetlbool((x), (y), DBSETBCP)
01055 #define DBSETNATLANG            7
01056 #define DBSETLNATLANG(x,y)      dbsetlname((x), (y), DBSETNATLANG)
01057 #define dbsetlnatlang(x,y)      dbsetlname((x), (y), DBSETNATLANG)
01058 #define DBSETNOSHORT            8       /* not implemented */
01059 #define DBSETLNOSHORT(x,y)      dbsetlbool((x), (y), DBSETNOSHORT)
01060 #define DBSETHIER               9       /* not implemented */
01061 #define DBSETLHIER(x,y)         dbsetlshort((x), (y), DBSETHIER)
01062 #define DBSETCHARSET            10
01063 #define DBSETLCHARSET(x,y)      dbsetlname((x), (y), DBSETCHARSET)
01064 #define DBSETPACKET             11
01065 #define DBSETLPACKET(x,y)       dbsetllong((x), (y), DBSETPACKET)
01066 #define dbsetlpacket(x,y)       dbsetllong((x), (y), DBSETPACKET)
01067 #define DBSETENCRYPT            12
01068 #define DBSETLENCRYPT(x,y)      dbsetlbool((x), (y), DBSETENCRYPT)
01069 #define DBSETLABELED            13
01070 #define DBSETLLABELED(x,y)      dbsetlbool((x), (y), DBSETLABELED)
01071 #define BCP_SETLABELED(x,y)     dbsetlbool((x), (y), DBSETLABELED)
01072 #define DBSETLVERSION(login, version) dbsetlversion((login), (version))
01073 
01074 RETCODE bcp_init(DBPROCESS * dbproc, const char *tblname, const char *hfile, const char *errfile, int direction);
01075 RETCODE bcp_done(DBPROCESS * dbproc);
01076 
01077 RETCODE bcp_batch(DBPROCESS * dbproc);
01078 RETCODE bcp_bind(DBPROCESS * dbproc, BYTE * varaddr, int prefixlen, DBINT varlen, BYTE * terminator, int termlen, int type,
01079                  int table_column);
01080 RETCODE bcp_collen(DBPROCESS * dbproc, DBINT varlen, int table_column);
01081 RETCODE bcp_columns(DBPROCESS * dbproc, int host_colcount);
01082 RETCODE bcp_colfmt(DBPROCESS * dbproc, int host_column, int host_type, int host_prefixlen, DBINT host_collen,
01083                    const BYTE * host_term, int host_termlen, int colnum);
01084 RETCODE bcp_colfmt_ps(DBPROCESS * dbproc, int host_column, int host_type, int host_prefixlen, DBINT host_collen,
01085                       BYTE * host_term, int host_termlen, int colnum, DBTYPEINFO * typeinfo);
01086 RETCODE bcp_colptr(DBPROCESS * dbproc, BYTE * colptr, int table_column);
01087 RETCODE bcp_control(DBPROCESS * dbproc, int field, DBINT value);
01088 int bcp_getbatchsize(DBPROCESS * dbproc); /* FreeTDS only */
01089 RETCODE bcp_exec(DBPROCESS * dbproc, DBINT * rows_copied);
01090 DBBOOL bcp_getl(LOGINREC * login);
01091 RETCODE bcp_moretext(DBPROCESS * dbproc, DBINT size, BYTE * text);
01092 RETCODE bcp_options(DBPROCESS * dbproc, int option, BYTE * value, int valuelen);
01093 RETCODE bcp_readfmt(DBPROCESS * dbproc, char *filename);
01094 RETCODE bcp_sendrow(DBPROCESS * dbproc);
01095 RETCODE bcp_writefmt(DBPROCESS * dbproc, char *filename);
01096 
01097 void build_xact_string(char *xact_name, char *service_name, DBINT commid, char *result);
01098 RETCODE remove_xact(DBPROCESS * connect, DBINT commid, int n);
01099 RETCODE abort_xact(DBPROCESS * connect, DBINT commid);
01100 void close_commit(DBPROCESS * connect);
01101 RETCODE commit_xact(DBPROCESS * connect, DBINT commid);
01102 DBPROCESS *open_commit(LOGINREC * login, char *servername);
01103 RETCODE scan_xact(DBPROCESS * connect, DBINT commid);
01104 DBINT start_xact(DBPROCESS * connect, char *application_name, char *xact_name, int site_count);
01105 DBINT stat_xact(DBPROCESS * connect, DBINT commid);
01106 
01107 #ifdef __cplusplus
01108 #if 0
01109 {
01110 #endif
01111 }
01112 #endif
01113 
01114 #endif

Generated on Wed May 7 19:22:09 2008 for FreeTDS API by  doxygen 1.4.1