summaryrefslogtreecommitdiff
path: root/connectivity/source
diff options
context:
space:
mode:
Diffstat (limited to 'connectivity/source')
-rw-r--r--connectivity/source/drivers/mozab/MConnection.cxx130
1 files changed, 63 insertions, 67 deletions
diff --git a/connectivity/source/drivers/mozab/MConnection.cxx b/connectivity/source/drivers/mozab/MConnection.cxx
index f318ffad7193..cc7eca65dd92 100644
--- a/connectivity/source/drivers/mozab/MConnection.cxx
+++ b/connectivity/source/drivers/mozab/MConnection.cxx
@@ -4,9 +4,9 @@
*
* $RCSfile: MConnection.cxx,v $
*
- * $Revision: 1.20 $
+ * $Revision: 1.21 $
*
- * last change: $Author: obo $ $Date: 2006-03-29 12:17:15 $
+ * last change: $Author: hr $ $Date: 2006-06-20 01:41:49 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
@@ -59,6 +59,9 @@
#ifndef _DBHELPER_DBEXCEPTION_HXX_
#include <connectivity/dbexception.hxx>
#endif
+#ifndef CONNECTIVITY_DIAGNOSE_EX_H
+#include "diagnose_ex.h"
+#endif
#ifndef COMPHELPER_OFFICE_RESOURCE_BUNDLE_HXX
#include <comphelper/officeresourcebundle.hxx>
@@ -77,8 +80,6 @@ extern "C" void* SAL_CALL OMozabConnection_CreateInstance(void* _pDriver)
return (new connectivity::mozab::OConnection( reinterpret_cast<connectivity::mozab::MozabDriver*>(_pDriver) ));
}
-
-using namespace connectivity::mozab;
using namespace dbtools;
//------------------------------------------------------------------------------
@@ -89,56 +90,49 @@ using namespace com::sun::star::sdbc;
using namespace com::sun::star::sdbcx;
// --------------------------------------------------------------------------------
-namespace connectivity
-{
- namespace mozab
- {
- // =====================================================================
- // = ConnectionImplData
- // =====================================================================
- struct ConnectionImplData
- {
- ::boost::shared_ptr< ::comphelper::OfficeResourceBundle > pResourceBundle;
- };
- }
-}
-
+namespace connectivity { namespace mozab {
-// -----------------------------------------------------------------------------
-const sal_Char* OConnection::getSDBC_SCHEME_MOZILLA()
-{
- static sal_Char* SDBC_SCHEME_MOZILLA = MOZAB_MOZILLA_SCHEMA;
- return SDBC_SCHEME_MOZILLA;
-}
-// -----------------------------------------------------------------------------
-const sal_Char* OConnection::getSDBC_SCHEME_THUNDERBIRD()
+// =====================================================================
+// = ConnectionImplData
+// =====================================================================
+struct ConnectionImplData
{
- static sal_Char* SDBC_SCHEME_THUNDERBIRD = MOZAB_THUNDERBIRD_SCHEMA;
- return SDBC_SCHEME_THUNDERBIRD;
-}
-// -----------------------------------------------------------------------------
-const sal_Char* OConnection::getSDBC_SCHEME_LDAP()
-{
- static sal_Char* SDBC_SCHEME_LDAP = MOZAB_LDAP_SCHEMA;
- return SDBC_SCHEME_LDAP;
-}
+ ::boost::shared_ptr< ::comphelper::OfficeResourceBundle > pResourceBundle;
+};
+
// -----------------------------------------------------------------------------
-const sal_Char* OConnection::getSDBC_SCHEME_OUTLOOK_MAPI()
+const sal_Char* getSdbcScheme( SdbcScheme _eScheme )
{
- static sal_Char* SDBC_SCHEME_OUTLOOK_MAPI = MOZAB_OUTLOOK_SCHEMA;
- return SDBC_SCHEME_OUTLOOK_MAPI;
+ switch ( _eScheme )
+ {
+ case SDBC_MOZILLA: return "mozilla";
+ case SDBC_THUNDERBIRD: return "thunderbird";
+ case SDBC_LDAP: return "ldap";
+ case SDBC_OUTLOOK_MAPI: return "outlook";
+ case SDBC_OUTLOOK_EXPRESS: return "outlookexp";
+ }
+ return NULL;
}
// -----------------------------------------------------------------------------
-const sal_Char* OConnection::getSDBC_SCHEME_OUTLOOK_EXPRESS()
+::rtl::OUString OConnection::getDriverImplementationName()
{
- static sal_Char* SDBC_SCHEME_OUTLOOK_EXPRESS = MOZAB_OUTLOOKEXP_SCHEMA;
- return SDBC_SCHEME_OUTLOOK_EXPRESS;
+ return rtl::OUString::createFromAscii(MOZAB_DRIVER_IMPL_NAME);
}
+
// -----------------------------------------------------------------------------
-::rtl::OUString OConnection::getDriverImplementationName()
+const sal_Char* getSchemeURI( MozillaScheme _eScheme )
{
- return rtl::OUString::createFromAscii(MOZAB_DRIVER_IMPL_NAME);
+ switch ( _eScheme )
+ {
+ case SCHEME_MOZILLA : return "moz-abdirectory://";
+ case SCHEME_MOZILLA_MDB : return "moz-abmdbdirectory://";
+ case SCHEME_LDAP : return "moz-abldapdirectory://";
+ case SCHEME_OUTLOOK_MAPI : return "moz-aboutlookdirectory://op/";
+ case SCHEME_OUTLOOK_EXPRESS : return "moz-aboutlookdirectory://oe/";
+ }
+ return NULL;
}
+
// -----------------------------------------------------------------------------
OConnection::OConnection(MozabDriver* _pDriver)
@@ -242,25 +236,25 @@ void OConnection::construct(const ::rtl::OUString& url,const Sequence< PropertyV
m_sPassword = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM(""));
m_bUseSSL = sal_False;
- if ( aAddrbookScheme.compareToAscii( getSDBC_SCHEME_MOZILLA() ) == 0 ) {
- m_sMozillaURI = rtl::OUString::createFromAscii( MOZ_SCHEME_MOZILLA );
+ if ( aAddrbookScheme.compareToAscii( getSdbcScheme( SDBC_MOZILLA ) ) == 0 ) {
+ m_sMozillaURI = rtl::OUString::createFromAscii( getSchemeURI( SCHEME_MOZILLA ) );
m_eSDBCAddressType = SDBCAddress::Mozilla;
if(sAdditionalInfo.getLength())
m_sMozillaProfile = sAdditionalInfo;
}
else
- if ( aAddrbookScheme.compareToAscii( getSDBC_SCHEME_THUNDERBIRD() ) == 0 ) {
- //Yes. I am sure it is MOZ_SCHEME_MOZILLA
- m_sMozillaURI = rtl::OUString::createFromAscii( MOZ_SCHEME_MOZILLA );
+ if ( aAddrbookScheme.compareToAscii( getSdbcScheme( SDBC_THUNDERBIRD ) ) == 0 ) {
+ //Yes. I am sure it is SCHEME_MOZILLA
+ m_sMozillaURI = rtl::OUString::createFromAscii( getSchemeURI( SCHEME_MOZILLA ) );
m_eSDBCAddressType = SDBCAddress::ThunderBird;
if(sAdditionalInfo.getLength())
m_sMozillaProfile = sAdditionalInfo;
}
- else if ( aAddrbookScheme.compareToAscii( getSDBC_SCHEME_LDAP() ) == 0 ) {
+ else if ( aAddrbookScheme.compareToAscii( getSdbcScheme( SDBC_LDAP ) ) == 0 ) {
rtl::OUString sBaseDN;
sal_Int32 nPortNumber = -1;
- m_sMozillaURI = rtl::OUString::createFromAscii( MOZ_SCHEME_LDAP );
+ m_sMozillaURI = rtl::OUString::createFromAscii( getSchemeURI( SCHEME_LDAP ) );
m_eSDBCAddressType = SDBCAddress::LDAP;
if ( !m_sHostName.getLength() )
@@ -344,12 +338,12 @@ void OConnection::construct(const ::rtl::OUString& url,const Sequence< PropertyV
m_sMozillaURI += ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("?(or(DisplayName,=,DontDoThisAtHome)))"));
}
- else if ( aAddrbookScheme.compareToAscii( getSDBC_SCHEME_OUTLOOK_MAPI() ) == 0 ) {
- m_sMozillaURI = ::rtl::OUString::createFromAscii( MOZ_SCHEME_OUTLOOK_MAPI );
+ else if ( aAddrbookScheme.compareToAscii( getSdbcScheme( SDBC_OUTLOOK_MAPI ) ) == 0 ) {
+ m_sMozillaURI = ::rtl::OUString::createFromAscii( getSchemeURI( SCHEME_OUTLOOK_MAPI ) );
m_eSDBCAddressType = SDBCAddress::Outlook;
}
- else if ( aAddrbookScheme.compareToAscii( getSDBC_SCHEME_OUTLOOK_EXPRESS() ) == 0 ) {
- m_sMozillaURI = rtl::OUString::createFromAscii( MOZ_SCHEME_OUTLOOK_EXPRESS );
+ else if ( aAddrbookScheme.compareToAscii( getSdbcScheme( SDBC_OUTLOOK_EXPRESS ) ) == 0 ) {
+ m_sMozillaURI = rtl::OUString::createFromAscii( getSchemeURI( SCHEME_OUTLOOK_EXPRESS ) );
m_eSDBCAddressType = SDBCAddress::OutlookExp;
}
else
@@ -418,8 +412,9 @@ Reference< XPreparedStatement > SAL_CALL OConnection::prepareStatement( const ::
// --------------------------------------------------------------------------------
Reference< XPreparedStatement > SAL_CALL OConnection::prepareCall( const ::rtl::OUString& _sSql ) throw(SQLException, RuntimeException)
{
+ OSL_UNUSED( _sSql );
+ ::dbtools::throwFeatureNotImplementedException( "XConnection::prepareCall", *this );
OSL_TRACE("OConnection::prepareCall( %s )", OUtoCStr( _sSql ) );
- // not implemented yet :-) a task to do
return NULL;
}
// --------------------------------------------------------------------------------
@@ -432,9 +427,9 @@ Reference< XPreparedStatement > SAL_CALL OConnection::prepareCall( const ::rtl::
return _sSql;
}
// --------------------------------------------------------------------------------
-void SAL_CALL OConnection::setAutoCommit( sal_Bool autoCommit ) throw(SQLException, RuntimeException)
+void SAL_CALL OConnection::setAutoCommit( sal_Bool /*autoCommit*/ ) throw(SQLException, RuntimeException)
{
- // here you have to set your commit mode please have a look at the jdbc documentation to get a clear explanation
+ ::dbtools::throwFeatureNotImplementedException( "XConnection::setAutoCommit", *this );
}
// --------------------------------------------------------------------------------
sal_Bool SAL_CALL OConnection::getAutoCommit( ) throw(SQLException, RuntimeException)
@@ -480,9 +475,9 @@ Reference< XDatabaseMetaData > SAL_CALL OConnection::getMetaData( ) throw(SQLEx
return xMetaData;
}
// --------------------------------------------------------------------------------
-void SAL_CALL OConnection::setReadOnly( sal_Bool readOnly ) throw(SQLException, RuntimeException)
+void SAL_CALL OConnection::setReadOnly( sal_Bool /*readOnly*/ ) throw(SQLException, RuntimeException)
{
- // set you connection to readonly
+ ::dbtools::throwFeatureNotImplementedException( "XConnection::setReadOnly", *this );
}
// --------------------------------------------------------------------------------
sal_Bool SAL_CALL OConnection::isReadOnly( ) throw(SQLException, RuntimeException)
@@ -491,9 +486,9 @@ sal_Bool SAL_CALL OConnection::isReadOnly( ) throw(SQLException, RuntimeExcepti
return sal_False;
}
// --------------------------------------------------------------------------------
-void SAL_CALL OConnection::setCatalog( const ::rtl::OUString& catalog ) throw(SQLException, RuntimeException)
+void SAL_CALL OConnection::setCatalog( const ::rtl::OUString& /*catalog*/ ) throw(SQLException, RuntimeException)
{
- // if your database doesn't work with catalogs you go to next method otherwise you kjnow what to do
+ ::dbtools::throwFeatureNotImplementedException( "XConnection::setCatalog", *this );
}
// --------------------------------------------------------------------------------
::rtl::OUString SAL_CALL OConnection::getCatalog( ) throw(SQLException, RuntimeException)
@@ -502,10 +497,9 @@ void SAL_CALL OConnection::setCatalog( const ::rtl::OUString& catalog ) throw(SQ
return ::rtl::OUString();
}
// --------------------------------------------------------------------------------
-void SAL_CALL OConnection::setTransactionIsolation( sal_Int32 level ) throw(SQLException, RuntimeException)
+void SAL_CALL OConnection::setTransactionIsolation( sal_Int32 /*level*/ ) throw(SQLException, RuntimeException)
{
- // set your isolation level
- // please have a look at @see com.sun.star.sdbc.TransactionIsolation
+ ::dbtools::throwFeatureNotImplementedException( "XConnection::setTransactionIsolation", *this );
}
// --------------------------------------------------------------------------------
sal_Int32 SAL_CALL OConnection::getTransactionIsolation( ) throw(SQLException, RuntimeException)
@@ -520,9 +514,9 @@ Reference< ::com::sun::star::container::XNameAccess > SAL_CALL OConnection::getT
return NULL;
}
// --------------------------------------------------------------------------------
-void SAL_CALL OConnection::setTypeMap( const Reference< ::com::sun::star::container::XNameAccess >& typeMap ) throw(SQLException, RuntimeException)
+void SAL_CALL OConnection::setTypeMap( const Reference< ::com::sun::star::container::XNameAccess >& /*typeMap*/ ) throw(SQLException, RuntimeException)
{
- // the other way around
+ ::dbtools::throwFeatureNotImplementedException( "XConnection::setTypeMap", *this );
}
// --------------------------------------------------------------------------------
// XCloseable
@@ -613,7 +607,9 @@ void OConnection::throwGenericSQLException( sal_Int32 _nErrorResourceId )
// this means that we're disposed, and how could anybody request us to throw an exception then?
::rtl::OUString sErrorMessage;
- if ( pResourceBundle.get() )
+ if ( pResourceBundle.get() && _nErrorResourceId )
sErrorMessage = pResourceBundle->loadString( _nErrorResourceId );
::dbtools::throwGenericSQLException( sErrorMessage, *this );
}
+
+} } // namespace connectivity::mozab