1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_connectivity.hxx"
26*b1cdbd2cSJim Jagielski #include "ado/AResultSetMetaData.hxx"
27*b1cdbd2cSJim Jagielski #include <com/sun/star/sdbc/DataType.hpp>
28*b1cdbd2cSJim Jagielski #include <com/sun/star/sdbc/ColumnValue.hpp>
29*b1cdbd2cSJim Jagielski #include "ado/Awrapado.hxx"
30*b1cdbd2cSJim Jagielski #include "connectivity/dbexception.hxx"
31*b1cdbd2cSJim Jagielski 
32*b1cdbd2cSJim Jagielski using namespace connectivity;
33*b1cdbd2cSJim Jagielski using namespace connectivity::ado;
34*b1cdbd2cSJim Jagielski using namespace com::sun::star::uno;
35*b1cdbd2cSJim Jagielski using namespace com::sun::star::lang;
36*b1cdbd2cSJim Jagielski using namespace com::sun::star::beans;
37*b1cdbd2cSJim Jagielski using namespace com::sun::star::sdbc;
38*b1cdbd2cSJim Jagielski 
OResultSetMetaData(ADORecordset * _pRecordSet)39*b1cdbd2cSJim Jagielski OResultSetMetaData::OResultSetMetaData( ADORecordset* _pRecordSet)
40*b1cdbd2cSJim Jagielski 					:	m_pRecordSet(_pRecordSet),
41*b1cdbd2cSJim Jagielski 						m_nColCount(-1)
42*b1cdbd2cSJim Jagielski {
43*b1cdbd2cSJim Jagielski 	if ( m_pRecordSet )
44*b1cdbd2cSJim Jagielski 		m_pRecordSet->AddRef();
45*b1cdbd2cSJim Jagielski }
46*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
~OResultSetMetaData()47*b1cdbd2cSJim Jagielski OResultSetMetaData::~OResultSetMetaData()
48*b1cdbd2cSJim Jagielski {
49*b1cdbd2cSJim Jagielski 	if ( m_pRecordSet )
50*b1cdbd2cSJim Jagielski 		m_pRecordSet->Release();
51*b1cdbd2cSJim Jagielski }
52*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getColumnDisplaySize(sal_Int32 column)53*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL OResultSetMetaData::getColumnDisplaySize( sal_Int32 column ) throw(SQLException, RuntimeException)
54*b1cdbd2cSJim Jagielski {
55*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
56*b1cdbd2cSJim Jagielski 	if(aField.IsValid() && aField.GetActualSize() != -1)
57*b1cdbd2cSJim Jagielski 		return aField.GetActualSize();
58*b1cdbd2cSJim Jagielski 	return 0;
59*b1cdbd2cSJim Jagielski }
60*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
61*b1cdbd2cSJim Jagielski 
getColumnType(sal_Int32 column)62*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL OResultSetMetaData::getColumnType( sal_Int32 column ) throw(SQLException, RuntimeException)
63*b1cdbd2cSJim Jagielski {
64*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
65*b1cdbd2cSJim Jagielski 	return ADOS::MapADOType2Jdbc(aField.GetADOType());
66*b1cdbd2cSJim Jagielski }
67*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
68*b1cdbd2cSJim Jagielski 
getColumnCount()69*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL OResultSetMetaData::getColumnCount(  ) throw(SQLException, RuntimeException)
70*b1cdbd2cSJim Jagielski {
71*b1cdbd2cSJim Jagielski 	if(m_nColCount != -1 )
72*b1cdbd2cSJim Jagielski 		return m_nColCount;
73*b1cdbd2cSJim Jagielski 
74*b1cdbd2cSJim Jagielski 	if ( !m_pRecordSet )
75*b1cdbd2cSJim Jagielski 		return 0;
76*b1cdbd2cSJim Jagielski 
77*b1cdbd2cSJim Jagielski 	ADOFields* pFields	= NULL;
78*b1cdbd2cSJim Jagielski 	m_pRecordSet->get_Fields(&pFields);
79*b1cdbd2cSJim Jagielski 	WpOLEAppendCollection<ADOFields, ADOField, WpADOField>	aFields(pFields);
80*b1cdbd2cSJim Jagielski 	m_nColCount = aFields.GetItemCount();
81*b1cdbd2cSJim Jagielski 	return m_nColCount;
82*b1cdbd2cSJim Jagielski }
83*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
84*b1cdbd2cSJim Jagielski 
isCaseSensitive(sal_Int32 column)85*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL OResultSetMetaData::isCaseSensitive( sal_Int32 column ) throw(SQLException, RuntimeException)
86*b1cdbd2cSJim Jagielski {
87*b1cdbd2cSJim Jagielski 	sal_Bool bRet = sal_False;
88*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
89*b1cdbd2cSJim Jagielski 	if ( aField.IsValid() )
90*b1cdbd2cSJim Jagielski 	{
91*b1cdbd2cSJim Jagielski 		WpADOProperties aProps( aField.get_Properties() );
92*b1cdbd2cSJim Jagielski 		if ( aProps.IsValid() )
93*b1cdbd2cSJim Jagielski 			bRet = OTools::getValue( aProps, ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("ISCASESENSITIVE")) );
94*b1cdbd2cSJim Jagielski 	}
95*b1cdbd2cSJim Jagielski 	return bRet;
96*b1cdbd2cSJim Jagielski }
97*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
98*b1cdbd2cSJim Jagielski 
getSchemaName(sal_Int32)99*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL OResultSetMetaData::getSchemaName( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
100*b1cdbd2cSJim Jagielski {
101*b1cdbd2cSJim Jagielski 	return ::rtl::OUString();
102*b1cdbd2cSJim Jagielski }
103*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
104*b1cdbd2cSJim Jagielski 
getColumnName(sal_Int32 column)105*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL OResultSetMetaData::getColumnName( sal_Int32 column ) throw(SQLException, RuntimeException)
106*b1cdbd2cSJim Jagielski {
107*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
108*b1cdbd2cSJim Jagielski 	if(aField.IsValid())
109*b1cdbd2cSJim Jagielski 		return aField.GetName();
110*b1cdbd2cSJim Jagielski 
111*b1cdbd2cSJim Jagielski 	return ::rtl::OUString();
112*b1cdbd2cSJim Jagielski }
113*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getTableName(sal_Int32 column)114*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL OResultSetMetaData::getTableName( sal_Int32 column ) throw(SQLException, RuntimeException)
115*b1cdbd2cSJim Jagielski {
116*b1cdbd2cSJim Jagielski 	::rtl::OUString sTableName;
117*b1cdbd2cSJim Jagielski 
118*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
119*b1cdbd2cSJim Jagielski 	if ( aField.IsValid() )
120*b1cdbd2cSJim Jagielski 	{
121*b1cdbd2cSJim Jagielski 		WpADOProperties aProps( aField.get_Properties() );
122*b1cdbd2cSJim Jagielski 		if ( aProps.IsValid() )
123*b1cdbd2cSJim Jagielski 			sTableName = OTools::getValue( aProps, ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BASETABLENAME")) );
124*b1cdbd2cSJim Jagielski 	}
125*b1cdbd2cSJim Jagielski 	return sTableName;
126*b1cdbd2cSJim Jagielski }
127*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getCatalogName(sal_Int32)128*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL OResultSetMetaData::getCatalogName( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
129*b1cdbd2cSJim Jagielski {
130*b1cdbd2cSJim Jagielski 	return ::rtl::OUString();
131*b1cdbd2cSJim Jagielski }
132*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getColumnTypeName(sal_Int32)133*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL OResultSetMetaData::getColumnTypeName( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
134*b1cdbd2cSJim Jagielski {
135*b1cdbd2cSJim Jagielski 	return ::rtl::OUString();
136*b1cdbd2cSJim Jagielski }
137*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getColumnLabel(sal_Int32 column)138*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL OResultSetMetaData::getColumnLabel( sal_Int32 column ) throw(SQLException, RuntimeException)
139*b1cdbd2cSJim Jagielski {
140*b1cdbd2cSJim Jagielski 	return getColumnName(column);
141*b1cdbd2cSJim Jagielski }
142*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getColumnServiceName(sal_Int32)143*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL OResultSetMetaData::getColumnServiceName( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
144*b1cdbd2cSJim Jagielski {
145*b1cdbd2cSJim Jagielski 	return ::rtl::OUString();
146*b1cdbd2cSJim Jagielski }
147*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
148*b1cdbd2cSJim Jagielski 
isCurrency(sal_Int32 column)149*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL OResultSetMetaData::isCurrency( sal_Int32 column ) throw(SQLException, RuntimeException)
150*b1cdbd2cSJim Jagielski {
151*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
152*b1cdbd2cSJim Jagielski 	if(aField.IsValid())
153*b1cdbd2cSJim Jagielski 	{
154*b1cdbd2cSJim Jagielski 		return ((aField.GetAttributes() & adFldFixed) == adFldFixed) && (aField.GetADOType() == adCurrency);
155*b1cdbd2cSJim Jagielski 	}
156*b1cdbd2cSJim Jagielski 	return sal_False;
157*b1cdbd2cSJim Jagielski }
158*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
159*b1cdbd2cSJim Jagielski 
isAutoIncrement(sal_Int32 column)160*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL OResultSetMetaData::isAutoIncrement( sal_Int32 column ) throw(SQLException, RuntimeException)
161*b1cdbd2cSJim Jagielski {
162*b1cdbd2cSJim Jagielski 	sal_Bool bRet = sal_False;
163*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
164*b1cdbd2cSJim Jagielski 	if ( aField.IsValid() )
165*b1cdbd2cSJim Jagielski 	{
166*b1cdbd2cSJim Jagielski 		WpADOProperties aProps( aField.get_Properties() );
167*b1cdbd2cSJim Jagielski 		if ( aProps.IsValid() )
168*b1cdbd2cSJim Jagielski 		{
169*b1cdbd2cSJim Jagielski 			bRet = OTools::getValue( aProps, ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("ISAUTOINCREMENT")) );
170*b1cdbd2cSJim Jagielski #if OSL_DEBUG_LEVEL > 0
171*b1cdbd2cSJim Jagielski 			sal_Int32 nCount = aProps.GetItemCount();
172*b1cdbd2cSJim Jagielski 			for (sal_Int32 i = 0; i<nCount; ++i)
173*b1cdbd2cSJim Jagielski 			{
174*b1cdbd2cSJim Jagielski 				WpADOProperty aProp = aProps.GetItem(i);
175*b1cdbd2cSJim Jagielski 				::rtl::OUString sName = aProp.GetName();
176*b1cdbd2cSJim Jagielski 				::rtl::OUString sVal = aProp.GetValue();
177*b1cdbd2cSJim Jagielski 			}
178*b1cdbd2cSJim Jagielski #endif
179*b1cdbd2cSJim Jagielski 		}
180*b1cdbd2cSJim Jagielski 	}
181*b1cdbd2cSJim Jagielski 	return bRet;
182*b1cdbd2cSJim Jagielski }
183*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
184*b1cdbd2cSJim Jagielski 
185*b1cdbd2cSJim Jagielski 
isSigned(sal_Int32 column)186*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL OResultSetMetaData::isSigned( sal_Int32 column ) throw(SQLException, RuntimeException)
187*b1cdbd2cSJim Jagielski {
188*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
189*b1cdbd2cSJim Jagielski 	if(aField.IsValid())
190*b1cdbd2cSJim Jagielski 	{
191*b1cdbd2cSJim Jagielski 		DataTypeEnum eType = aField.GetADOType();
192*b1cdbd2cSJim Jagielski 		return !(eType == adUnsignedBigInt || eType == adUnsignedInt || eType == adUnsignedSmallInt || eType == adUnsignedTinyInt);
193*b1cdbd2cSJim Jagielski 	}
194*b1cdbd2cSJim Jagielski 	return sal_False;
195*b1cdbd2cSJim Jagielski }
196*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getPrecision(sal_Int32 column)197*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL OResultSetMetaData::getPrecision( sal_Int32 column ) throw(SQLException, RuntimeException)
198*b1cdbd2cSJim Jagielski {
199*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
200*b1cdbd2cSJim Jagielski 	if(aField.IsValid())
201*b1cdbd2cSJim Jagielski 		return aField.GetPrecision();
202*b1cdbd2cSJim Jagielski 	return 0;
203*b1cdbd2cSJim Jagielski }
204*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getScale(sal_Int32 column)205*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL OResultSetMetaData::getScale( sal_Int32 column ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException)
206*b1cdbd2cSJim Jagielski {
207*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
208*b1cdbd2cSJim Jagielski 	if(aField.IsValid())
209*b1cdbd2cSJim Jagielski 		return aField.GetNumericScale();
210*b1cdbd2cSJim Jagielski 	return 0;
211*b1cdbd2cSJim Jagielski }
212*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
213*b1cdbd2cSJim Jagielski 
isNullable(sal_Int32 column)214*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL OResultSetMetaData::isNullable( sal_Int32 column ) throw(SQLException, RuntimeException)
215*b1cdbd2cSJim Jagielski {
216*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
217*b1cdbd2cSJim Jagielski 	if(aField.IsValid())
218*b1cdbd2cSJim Jagielski 	{
219*b1cdbd2cSJim Jagielski 		return (aField.GetAttributes() & adFldIsNullable) == adFldIsNullable;
220*b1cdbd2cSJim Jagielski 	}
221*b1cdbd2cSJim Jagielski 	return sal_False;
222*b1cdbd2cSJim Jagielski }
223*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
224*b1cdbd2cSJim Jagielski 
isSearchable(sal_Int32)225*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL OResultSetMetaData::isSearchable( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
226*b1cdbd2cSJim Jagielski {
227*b1cdbd2cSJim Jagielski 	return sal_True;
228*b1cdbd2cSJim Jagielski }
229*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
230*b1cdbd2cSJim Jagielski 
isReadOnly(sal_Int32 column)231*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL OResultSetMetaData::isReadOnly( sal_Int32 column ) throw(SQLException, RuntimeException)
232*b1cdbd2cSJim Jagielski {
233*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
234*b1cdbd2cSJim Jagielski 	if(aField.IsValid())
235*b1cdbd2cSJim Jagielski 	{
236*b1cdbd2cSJim Jagielski 		//	return (aField.GetStatus() & adFieldReadOnly) == adFieldReadOnly;
237*b1cdbd2cSJim Jagielski 	}
238*b1cdbd2cSJim Jagielski 	return sal_False;
239*b1cdbd2cSJim Jagielski }
240*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
241*b1cdbd2cSJim Jagielski 
isDefinitelyWritable(sal_Int32 column)242*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL OResultSetMetaData::isDefinitelyWritable( sal_Int32 column ) throw(SQLException, RuntimeException)
243*b1cdbd2cSJim Jagielski {
244*b1cdbd2cSJim Jagielski 	WpADOField aField = ADOS::getField(m_pRecordSet,column);
245*b1cdbd2cSJim Jagielski 	if(aField.IsValid())
246*b1cdbd2cSJim Jagielski 	{
247*b1cdbd2cSJim Jagielski 		return (aField.GetAttributes() & adFldUpdatable) == adFldUpdatable;
248*b1cdbd2cSJim Jagielski 	}
249*b1cdbd2cSJim Jagielski 	return sal_False;
250*b1cdbd2cSJim Jagielski ;
251*b1cdbd2cSJim Jagielski }
252*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
isWritable(sal_Int32 column)253*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL OResultSetMetaData::isWritable( sal_Int32 column ) throw(SQLException, RuntimeException)
254*b1cdbd2cSJim Jagielski {
255*b1cdbd2cSJim Jagielski 	return isDefinitelyWritable(column);
256*b1cdbd2cSJim Jagielski }
257*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
258*b1cdbd2cSJim Jagielski 
259