2000-10-05 13:47:22 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2005-09-08 04:59:50 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2000-10-05 13:47:22 +00:00
|
|
|
*
|
2005-09-08 04:59:50 +00:00
|
|
|
* $RCSfile: EConnection.cxx,v $
|
2000-10-05 13:47:22 +00:00
|
|
|
*
|
2006-03-29 11:16:30 +00:00
|
|
|
* $Revision: 1.12 $
|
2000-10-05 13:47:22 +00:00
|
|
|
*
|
2006-03-29 11:16:30 +00:00
|
|
|
* last change: $Author: obo $ $Date: 2006-03-29 12:16:30 $
|
2000-10-05 13:47:22 +00:00
|
|
|
*
|
2005-09-08 04:59:50 +00:00
|
|
|
* The Contents of this file are made available subject to
|
|
|
|
* the terms of GNU Lesser General Public License Version 2.1.
|
2000-10-05 13:47:22 +00:00
|
|
|
*
|
|
|
|
*
|
2005-09-08 04:59:50 +00:00
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
* =============================================
|
|
|
|
* Copyright 2005 by Sun Microsystems, Inc.
|
|
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
2000-10-05 13:47:22 +00:00
|
|
|
*
|
2005-09-08 04:59:50 +00:00
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License version 2.1, as published by the Free Software Foundation.
|
2000-10-05 13:47:22 +00:00
|
|
|
*
|
2005-09-08 04:59:50 +00:00
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
2000-10-05 13:47:22 +00:00
|
|
|
*
|
2005-09-08 04:59:50 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
|
|
* MA 02111-1307 USA
|
2000-10-05 13:47:22 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _CONNECTIVITY_FLAT_ECONNECTION_HXX_
|
|
|
|
#include "flat/EConnection.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _CONNECTIVITY_FLAT_EDATABASEMETADATA_HXX_
|
|
|
|
#include "flat/EDatabaseMetaData.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _CONNECTIVITY_FLAT_CATALOG_HXX_
|
|
|
|
#include "flat/ECatalog.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _CONNECTIVITY_RESOURCE_HRC_
|
|
|
|
#include "Resource.hrc"
|
|
|
|
#endif
|
|
|
|
#ifndef _CONNECTIVITY_FLAT_ODRIVER_HXX_
|
|
|
|
#include "flat/EDriver.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_LANG_DISPOSEDEXCEPTION_HPP_
|
|
|
|
#include <com/sun/star/lang/DisposedException.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _URLOBJ_HXX //autogen wg. INetURLObject
|
|
|
|
#include <tools/urlobj.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _CONNECTIVITY_FLAT_DPREPAREDSTATEMENT_HXX_
|
|
|
|
#include "flat/EPreparedStatement.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _CONNECTIVITY_FLAT_DSTATEMENT_HXX_
|
|
|
|
#include "flat/EStatement.hxx"
|
|
|
|
#endif
|
2001-03-15 08:02:28 +00:00
|
|
|
#ifndef _COMPHELPER_EXTRACT_HXX_
|
|
|
|
#include <comphelper/extract.hxx>
|
2000-10-05 13:47:22 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
using namespace connectivity::flat;
|
|
|
|
using namespace connectivity::file;
|
|
|
|
|
|
|
|
typedef connectivity::file::OConnection OConnection_B;
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
using namespace ::com::sun::star::uno;
|
|
|
|
using namespace ::com::sun::star::beans;
|
|
|
|
using namespace ::com::sun::star::sdbcx;
|
|
|
|
using namespace ::com::sun::star::sdbc;
|
|
|
|
using namespace ::com::sun::star::lang;
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------------
|
|
|
|
OFlatConnection::OFlatConnection(ODriver* _pDriver) : OConnection(_pDriver)
|
|
|
|
,m_bHeaderLine(sal_True)
|
|
|
|
,m_cFieldDelimiter(';')
|
|
|
|
,m_cStringDelimiter('"')
|
|
|
|
,m_cDecimalDelimiter(',')
|
|
|
|
,m_cThousandDelimiter('.')
|
|
|
|
{
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
OFlatConnection::~OFlatConnection()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
// XServiceInfo
|
|
|
|
// --------------------------------------------------------------------------------
|
|
|
|
IMPLEMENT_SERVICE_INFO(OFlatConnection, "com.sun.star.sdbc.drivers.flat.Connection", "com.sun.star.sdbc.Connection")
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
void OFlatConnection::construct(const ::rtl::OUString& url,const Sequence< PropertyValue >& info) throw(SQLException)
|
|
|
|
{
|
|
|
|
osl_incrementInterlockedCount( &m_refCount );
|
|
|
|
|
|
|
|
::rtl::OUString aExt;
|
|
|
|
const PropertyValue *pBegin = info.getConstArray();
|
|
|
|
const PropertyValue *pEnd = pBegin + info.getLength();
|
|
|
|
for(;pBegin != pEnd;++pBegin)
|
|
|
|
{
|
2005-03-10 14:28:38 +00:00
|
|
|
if(!pBegin->Name.compareToAscii("HeaderLine"))
|
2000-10-05 13:47:22 +00:00
|
|
|
m_bHeaderLine = cppu::any2bool(pBegin->Value);
|
|
|
|
else if(!pBegin->Name.compareToAscii("FieldDelimiter"))
|
2000-10-19 10:56:36 +00:00
|
|
|
{
|
|
|
|
::rtl::OUString aVal;
|
|
|
|
pBegin->Value >>= aVal; m_cFieldDelimiter = aVal.toChar();
|
|
|
|
}
|
2000-10-05 13:47:22 +00:00
|
|
|
else if(!pBegin->Name.compareToAscii("StringDelimiter"))
|
2000-10-19 10:56:36 +00:00
|
|
|
{
|
|
|
|
::rtl::OUString aVal;
|
|
|
|
pBegin->Value >>= aVal; m_cStringDelimiter = aVal.toChar();
|
|
|
|
}
|
2000-10-05 13:47:22 +00:00
|
|
|
else if(!pBegin->Name.compareToAscii("DecimalDelimiter"))
|
2000-10-19 10:56:36 +00:00
|
|
|
{
|
|
|
|
::rtl::OUString aVal;
|
|
|
|
pBegin->Value >>= aVal; m_cDecimalDelimiter = aVal.toChar();
|
|
|
|
}
|
2000-10-05 13:47:22 +00:00
|
|
|
else if(!pBegin->Name.compareToAscii("ThousandDelimiter"))
|
2000-10-19 10:56:36 +00:00
|
|
|
{
|
|
|
|
::rtl::OUString aVal;
|
|
|
|
pBegin->Value >>= aVal; m_cThousandDelimiter = aVal.toChar();
|
|
|
|
}
|
2000-10-05 13:47:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
osl_decrementInterlockedCount( &m_refCount );
|
|
|
|
OConnection::construct(url,info);
|
|
|
|
}
|
|
|
|
// --------------------------------------------------------------------------------
|
|
|
|
Reference< XDatabaseMetaData > SAL_CALL OFlatConnection::getMetaData( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aMutex );
|
2001-05-17 05:46:55 +00:00
|
|
|
checkDisposed(OConnection_B::rBHelper.bDisposed);
|
|
|
|
|
2000-10-05 13:47:22 +00:00
|
|
|
|
2000-11-03 13:21:22 +00:00
|
|
|
Reference< XDatabaseMetaData > xMetaData = m_xMetaData;
|
|
|
|
if(!xMetaData.is())
|
|
|
|
{
|
|
|
|
xMetaData = new OFlatDatabaseMetaData(this);
|
|
|
|
m_xMetaData = xMetaData;
|
|
|
|
}
|
2000-10-05 13:47:22 +00:00
|
|
|
|
2000-11-03 13:21:22 +00:00
|
|
|
return xMetaData;
|
2000-10-05 13:47:22 +00:00
|
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
::com::sun::star::uno::Reference< XTablesSupplier > OFlatConnection::createCatalog()
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aMutex );
|
|
|
|
Reference< XTablesSupplier > xTab = m_xCatalog;
|
2001-10-05 05:15:40 +00:00
|
|
|
if(!xTab.is())
|
2000-10-05 13:47:22 +00:00
|
|
|
{
|
|
|
|
OFlatCatalog *pCat = new OFlatCatalog(this);
|
|
|
|
xTab = pCat;
|
|
|
|
m_xCatalog = xTab;
|
|
|
|
}
|
|
|
|
return xTab;
|
|
|
|
}
|
|
|
|
// --------------------------------------------------------------------------------
|
|
|
|
Reference< XStatement > SAL_CALL OFlatConnection::createStatement( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aMutex );
|
2001-05-17 05:46:55 +00:00
|
|
|
checkDisposed(OConnection_B::rBHelper.bDisposed);
|
|
|
|
|
2000-10-05 13:47:22 +00:00
|
|
|
OFlatStatement* pStmt = new OFlatStatement(this);
|
|
|
|
|
2000-10-17 08:15:19 +00:00
|
|
|
Reference< XStatement > xStmt = pStmt;
|
2000-10-05 13:47:22 +00:00
|
|
|
m_aStatements.push_back(WeakReferenceHelper(*pStmt));
|
2000-10-17 08:15:19 +00:00
|
|
|
return xStmt;
|
2000-10-05 13:47:22 +00:00
|
|
|
}
|
|
|
|
// --------------------------------------------------------------------------------
|
|
|
|
Reference< XPreparedStatement > SAL_CALL OFlatConnection::prepareStatement( const ::rtl::OUString& sql ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aMutex );
|
2001-05-17 05:46:55 +00:00
|
|
|
checkDisposed(OConnection_B::rBHelper.bDisposed);
|
2000-10-05 13:47:22 +00:00
|
|
|
|
2001-05-17 05:46:55 +00:00
|
|
|
|
|
|
|
OFlatPreparedStatement* pStmt = new OFlatPreparedStatement(this);
|
2000-10-17 08:15:19 +00:00
|
|
|
Reference< XPreparedStatement > xStmt = pStmt;
|
2000-10-05 13:47:22 +00:00
|
|
|
pStmt->construct(sql);
|
2000-10-17 08:15:19 +00:00
|
|
|
|
2000-10-05 13:47:22 +00:00
|
|
|
m_aStatements.push_back(WeakReferenceHelper(*pStmt));
|
2000-10-17 08:15:19 +00:00
|
|
|
return xStmt;
|
2000-10-05 13:47:22 +00:00
|
|
|
}
|
|
|
|
// --------------------------------------------------------------------------------
|
|
|
|
Reference< XPreparedStatement > SAL_CALL OFlatConnection::prepareCall( const ::rtl::OUString& sql ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aMutex );
|
2001-05-17 05:46:55 +00:00
|
|
|
checkDisposed(OConnection_B::rBHelper.bDisposed);
|
|
|
|
|
2000-10-05 13:47:22 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|