1/*
2 *  GetConnectAttr.c
3 *
4 *  $Id: GetConnectAttr.c,v 1.4 2006/01/20 15:58:35 source Exp $
5 *
6 *  SQLGetConnectAttr trace functions
7 *
8 *  The iODBC driver manager.
9 *
10 *  Copyright (C) 1996-2006 by OpenLink Software <iodbc@openlinksw.com>
11 *  All Rights Reserved.
12 *
13 *  This software is released under the terms of either of the following
14 *  licenses:
15 *
16 *      - GNU Library General Public License (see LICENSE.LGPL)
17 *      - The BSD License (see LICENSE.BSD).
18 *
19 *  Note that the only valid version of the LGPL license as far as this
20 *  project is concerned is the original GNU Library General Public License
21 *  Version 2, dated June 1991.
22 *
23 *  While not mandated by the BSD license, any patches you make to the
24 *  iODBC source code may be contributed back into the iODBC project
25 *  at your discretion. Contributions will benefit the Open Source and
26 *  Data Access community as a whole. Submissions may be made at:
27 *
28 *      http://www.iodbc.org
29 *
30 *
31 *  GNU Library Generic Public License Version 2
32 *  ============================================
33 *  This library is free software; you can redistribute it and/or
34 *  modify it under the terms of the GNU Library General Public
35 *  License as published by the Free Software Foundation; only
36 *  Version 2 of the License dated June 1991.
37 *
38 *  This library is distributed in the hope that it will be useful,
39 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
40 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
41 *  Library General Public License for more details.
42 *
43 *  You should have received a copy of the GNU Library General Public
44 *  License along with this library; if not, write to the Free
45 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
46 *
47 *
48 *  The BSD License
49 *  ===============
50 *  Redistribution and use in source and binary forms, with or without
51 *  modification, are permitted provided that the following conditions
52 *  are met:
53 *
54 *  1. Redistributions of source code must retain the above copyright
55 *     notice, this list of conditions and the following disclaimer.
56 *  2. Redistributions in binary form must reproduce the above copyright
57 *     notice, this list of conditions and the following disclaimer in
58 *     the documentation and/or other materials provided with the
59 *     distribution.
60 *  3. Neither the name of OpenLink Software Inc. nor the names of its
61 *     contributors may be used to endorse or promote products derived
62 *     from this software without specific prior written permission.
63 *
64 *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
65 *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
66 *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
67 *  A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL OPENLINK OR
68 *  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
69 *  EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
70 *  PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
71 *  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
72 *  LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
73 *  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
74 *  SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
75 */
76
77#include "trace.h"
78
79
80#if ODBCVER >= 0x0300
81void
82_trace_connattr_type (SQLINTEGER type)
83{
84  char *ptr = "unknown connection attribute";
85
86  switch (type)
87    {
88      _S (SQL_ATTR_ACCESS_MODE);
89      _S (SQL_ATTR_AUTOCOMMIT);
90      _S (SQL_ATTR_AUTO_IPD);
91      _S (SQL_ATTR_CONNECTION_DEAD);
92      _S (SQL_ATTR_CONNECTION_TIMEOUT);
93      _S (SQL_ATTR_CURRENT_CATALOG);
94      _S (SQL_ATTR_DISCONNECT_BEHAVIOR);
95      _S (SQL_ATTR_ENLIST_IN_DTC);
96      _S (SQL_ATTR_ENLIST_IN_XA);
97      _S (SQL_ATTR_LOGIN_TIMEOUT);
98      _S (SQL_ATTR_METADATA_ID);
99      _S (SQL_ATTR_ODBC_CURSORS);
100      _S (SQL_ATTR_PACKET_SIZE);
101      _S (SQL_ATTR_QUIET_MODE);
102      _S (SQL_ATTR_TRACE);
103      _S (SQL_ATTR_TRACEFILE);
104      _S (SQL_ATTR_TRANSLATE_LIB);
105      _S (SQL_ATTR_TRANSLATE_OPTION);
106      _S (SQL_ATTR_TXN_ISOLATION);
107    }
108
109  trace_emit ("\t\t%-15.15s   %d (%s)\n", "SQLINTEGER ", (int) type, ptr);
110}
111
112
113void
114trace_SQLGetConnectAttr (int trace_leave, int retcode,
115  SQLHDBC		  ConnectionHandle,
116  SQLINTEGER		  Attribute,
117  SQLPOINTER		  ValuePtr,
118  SQLINTEGER		  BufferLength,
119  SQLINTEGER		* StringLengthPtr)
120{
121  /* Trace function */
122  _trace_print_function (en_GetConnectAttr, trace_leave, retcode);
123
124  /* Trace Arguments */
125  _trace_handle (SQL_HANDLE_DBC, ConnectionHandle);
126  _trace_connattr_type (Attribute);
127  _trace_pointer (ValuePtr);
128  _trace_bufferlen (BufferLength);
129  _trace_integer_p (StringLengthPtr, TRACE_OUTPUT_SUCCESS);
130}
131
132
133void
134trace_SQLGetConnectAttrW (int trace_leave, int retcode,
135  SQLHDBC		  ConnectionHandle,
136  SQLINTEGER		  Attribute,
137  SQLPOINTER		  ValuePtr,
138  SQLINTEGER		  BufferLength,
139  SQLINTEGER		* StringLengthPtr)
140{
141  /* Trace function */
142  _trace_print_function (en_GetConnectAttrW, trace_leave, retcode);
143
144  /* Trace Arguments */
145  _trace_handle (SQL_HANDLE_DBC, ConnectionHandle);
146  _trace_connattr_type (Attribute);
147  _trace_pointer (ValuePtr);
148  _trace_bufferlen (BufferLength);
149  _trace_integer_p (StringLengthPtr, TRACE_OUTPUT_SUCCESS);
150}
151#endif
152