1 /*************************************************************************
2  *
3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4  *
5  * Copyright 2000, 2010 Oracle and/or its affiliates.
6  *
7  * OpenOffice.org - a multi-platform office productivity suite
8  *
9  * This file is part of OpenOffice.org.
10  *
11  * OpenOffice.org is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * OpenOffice.org is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Lesser General Public License version 3 for more details
19  * (a copy is included in the LICENSE file that accompanied this code).
20  *
21  * You should have received a copy of the GNU Lesser General Public License
22  * version 3 along with OpenOffice.org.  If not, see
23  * <http://www.openoffice.org/license.html>
24  * for a copy of the LGPLv3 License.
25  *
26  ************************************************************************/
27 
28 // MARKER(update_precomp.py): autogen include statement, do not remove
29 #include "precompiled_connectivity.hxx"
30 
31 #ifndef _CONNECTIVITY_ADABAS_BRESULTSETMETADATA_HXX_
32 #include "adabas/BResultSetMetaData.hxx"
33 #endif
34 #include "adabas/BCatalog.hxx"
35 #include <com/sun/star/sdbc/DataType.hpp>
36 #include <com/sun/star/sdbc/XRow.hpp>
37 
38 using namespace com::sun::star::sdbc;
39 using namespace com::sun::star::uno;
40 using namespace connectivity::adabas;
41 using namespace connectivity;
42 
43 OAdabasResultSetMetaData::OAdabasResultSetMetaData(odbc::OConnection*	_pConnection, SQLHANDLE _pStmt,const ::vos::ORef<OSQLColumns>& _rSelectColumns )
44 : OAdabasResultSetMetaData_BASE(_pConnection,_pStmt)
45 ,m_aSelectColumns(_rSelectColumns)
46 {
47 }
48 // -------------------------------------------------------------------------
49 OAdabasResultSetMetaData::~OAdabasResultSetMetaData()
50 {
51 }
52 // -----------------------------------------------------------------------------
53 sal_Int32 SAL_CALL OAdabasResultSetMetaData::getColumnType( sal_Int32 column ) throw(SQLException, RuntimeException)
54 {
55 	sal_Int32 nType = OAdabasResultSetMetaData_BASE::getColumnType( column);
56 	// special handling for float values which could be doubles
57 	::rtl::OUString sTypeName;
58 	OAdabasCatalog::correctColumnProperties(getPrecision(column),nType,sTypeName);
59 
60 	return nType;
61 }
62 // -----------------------------------------------------------------------------
63 sal_Int32 SAL_CALL OAdabasResultSetMetaData::isNullable( sal_Int32 column ) throw(SQLException, RuntimeException)
64 {
65 	sal_Int32 nValue = 0;
66 	sal_Bool bFound = sal_False;
67 	if ( m_aSelectColumns.isValid() && column > 0 && column <= (sal_Int32)m_aSelectColumns->get().size() )
68 		bFound = (m_aSelectColumns->get())[column-1]->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISNULLABLE)) >>= nValue;
69 
70 	if ( !bFound )
71 		nValue = getNumColAttrib(column,SQL_DESC_NULLABLE);
72 	return nValue;
73 }
74 // -------------------------------------------------------------------------
75 sal_Bool SAL_CALL OAdabasResultSetMetaData::isAutoIncrement( sal_Int32 column ) throw(SQLException, RuntimeException)
76 {
77 	if ( m_aSelectColumns.isValid() && column > 0 && column <= (sal_Int32)m_aSelectColumns->get().size() )
78     {
79         sal_Bool bAutoIncrement = sal_False;
80         (m_aSelectColumns->get())[column-1]->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISAUTOINCREMENT)) >>= bAutoIncrement;
81 		return bAutoIncrement;
82     }
83 
84 	return getNumColAttrib(column,SQL_DESC_AUTO_UNIQUE_VALUE) == SQL_TRUE;
85 }
86 // -------------------------------------------------------------------------
87 
88