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