summaryrefslogtreecommitdiff
path: root/connectivity/source/drivers/ado/ATables.cxx
diff options
context:
space:
mode:
authorOcke Janssen <oj@openoffice.org>2001-11-09 06:05:38 +0000
committerOcke Janssen <oj@openoffice.org>2001-11-09 06:05:38 +0000
commit30c616da2b5d0e0ee32bc4b8e87540257b24dbd6 (patch)
tree92318a5c7ffb0f72581e28e571f7c46dbcb9415f /connectivity/source/drivers/ado/ATables.cxx
parent538702315171ec91ae6da4effccc7e2c7dbf0ce4 (diff)
#94371# primary key fixes
Diffstat (limited to 'connectivity/source/drivers/ado/ATables.cxx')
-rw-r--r--connectivity/source/drivers/ado/ATables.cxx46
1 files changed, 26 insertions, 20 deletions
diff --git a/connectivity/source/drivers/ado/ATables.cxx b/connectivity/source/drivers/ado/ATables.cxx
index f896a5ba48aa..8d7354919777 100644
--- a/connectivity/source/drivers/ado/ATables.cxx
+++ b/connectivity/source/drivers/ado/ATables.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ATables.cxx,v $
*
- * $Revision: 1.9 $
+ * $Revision: 1.10 $
*
- * last change: $Author: oj $ $Date: 2001-10-12 11:43:13 $
+ * last change: $Author: oj $ $Date: 2001-11-09 07:05:38 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -92,8 +92,12 @@
#ifndef CONNECTIVITY_CONNECTION_HXX
#include "TConnection.hxx"
#endif
+#ifndef _COMPHELPER_TYPES_HXX_
+#include <comphelper/types.hxx>
+#endif
using namespace connectivity;
+using namespace comphelper;
using namespace connectivity::ado;
using namespace com::sun::star::uno;
using namespace com::sun::star::lang;
@@ -106,14 +110,14 @@ typedef connectivity::sdbcx::OCollection OCollection_TYPE;
Reference< XNamed > OTables::createObject(const ::rtl::OUString& _rName)
{
- ADOTable* pTable = NULL;
- m_pCollection->get_Item(OLEVariant(_rName),&pTable);
- return new OAdoTable(this,isCaseSensitive(),m_pCatalog,pTable);
+ OSL_ENSURE(m_aCollection.IsValid(),"Collection isn't valid");
+ return new OAdoTable(this,isCaseSensitive(),m_pCatalog,m_aCollection.GetItem(_rName));
}
// -------------------------------------------------------------------------
void OTables::impl_refresh( ) throw(RuntimeException)
{
- m_pCollection->Refresh();
+ OSL_ENSURE(m_aCollection.IsValid(),"Collection isn't valid");
+ m_aCollection.Refresh();
}
// -------------------------------------------------------------------------
Reference< XPropertySet > OTables::createEmptyObject()
@@ -124,32 +128,34 @@ Reference< XPropertySet > OTables::createEmptyObject()
// XAppend
void OTables::appendObject( const Reference< XPropertySet >& descriptor )
{
- Reference< ::com::sun::star::lang::XUnoTunnel> xTunnel(descriptor,UNO_QUERY);
- if(xTunnel.is())
+ OAdoTable* pTable = NULL;
+ if(getImplementation(pTable,descriptor) && pTable != NULL)
{
- OAdoTable* pTable = (OAdoTable*)xTunnel->getSomething(OAdoTable:: getUnoTunnelImplementationId());
- if(pTable)
- {
- m_pCollection->Append(OLEVariant(pTable->getImpl()));
+ OSL_ENSURE(m_aCollection.IsValid(),"Collection isn't valid");
+ if(!m_aCollection.Append(pTable->getImpl()))
ADOS::ThrowException(*m_pCatalog->getConnection()->getConnection(),*this);
- }
- else
- throw SQLException(::rtl::OUString::createFromAscii("Could not append table!"),*this,OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_HY0000),1000,Any());
}
+ else
+ throw SQLException(::rtl::OUString::createFromAscii("Could not append table!"),*this,OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_HY0000),1000,Any());
}
// -------------------------------------------------------------------------
// XDrop
void OTables::dropObject(sal_Int32 _nPos,const ::rtl::OUString _sElementName)
{
- m_pCollection->Delete(OLEVariant(_sElementName));
- ADOS::ThrowException(*m_pCatalog->getConnection()->getConnection(),*this);
+ OSL_ENSURE(m_aCollection.IsValid(),"Collection isn't valid");
+ if(!m_aCollection.Delete(_sElementName))
+ ADOS::ThrowException(*m_pCatalog->getConnection()->getConnection(),*this);
}
// -------------------------------------------------------------------------
Reference< XNamed > OTables::cloneObject(const Reference< XPropertySet >& _xDescriptor)
{
- Reference< XNamed > xName(_xDescriptor,UNO_QUERY);
- OSL_ENSURE(xName.is(),"Must be a XName interface here !");
- return xName.is() ? createObject(xName->getName()) : Reference< XNamed >();
+ OAdoTable* pTable = NULL;
+ if(getImplementation(pTable,_xDescriptor) && pTable != NULL)
+ {
+ WpADOTable aTable = pTable->getImpl();
+ return new OAdoTable(this,isCaseSensitive(),m_pCatalog,aTable);
+ }
+ return Reference< XNamed >();
}
// -----------------------------------------------------------------------------