Files
libreoffice/connectivity/source/drivers/ado/adoimp.cxx

376 lines
14 KiB
C++
Raw Normal View History

2000-09-18 15:18:56 +00:00
/*************************************************************************
*
* $RCSfile: adoimp.cxx,v $
*
* $Revision: 1.11 $
2000-09-18 15:18:56 +00:00
*
* last change: $Author: fs $ $Date: 2002-01-18 16:33:01 $
2000-09-18 15:18:56 +00:00
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* 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.
*
* 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.
*
* 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
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (the "License"); You may not use this file
* except in compliance with the License. You may obtain a copy of the
* License at http://www.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
2001-06-20 06:16:56 +00:00
#ifndef _COM_SUN_STAR_SDBCX_PRIVILEGE_HPP_
#include <com/sun/star/sdbcx/Privilege.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_PRIVILEGEOBJECT_HPP_
#include <com/sun/star/sdbcx/PrivilegeObject.hpp>
#endif
2001-07-30 07:53:02 +00:00
#ifndef _DBHELPER_DBEXCEPTION_HXX_
#include "connectivity/dbexception.hxx"
#endif
2000-09-18 15:18:56 +00:00
#ifndef _CONNECTIVITY_ADO_AWRAPADO_HXX_
#include "ado/Awrapado.hxx"
#endif
#ifndef _CONNECTIVITY_ADO_ADOIMP_HXX_
#include "ado/adoimp.hxx"
#endif
#ifndef _OSL_DIAGNOSE_H_
#include <osl/diagnose.h>
#endif
#ifndef _COM_SUN_STAR_SDBC_DATATYPE_HPP_
#include <com/sun/star/sdbc/DataType.hpp>
#endif
2001-06-20 06:16:56 +00:00
2000-09-18 15:18:56 +00:00
using namespace connectivity::ado;
using namespace com::sun::star::uno;
using namespace com::sun::star::sdbc;
2001-06-20 06:16:56 +00:00
using namespace com::sun::star::sdbcx;
2000-09-18 15:18:56 +00:00
#define MYADOID(l) {l, 0,0x10,0x80,0,0,0xAA,0,0x6D,0x2E,0xA4};
const CLSID ADOS::CLSID_ADOCONNECTION_21 = MYADOID(0x00000514);
const IID ADOS::IID_ADOCONNECTION_21 = MYADOID(0x00000550);
const CLSID ADOS::CLSID_ADOCOMMAND_21 = MYADOID(0x00000507);
const IID ADOS::IID_ADOCOMMAND_21 = MYADOID(0x0000054E);
const CLSID ADOS::CLSID_ADORECORDSET_21 = MYADOID(0x00000535);
const IID ADOS::IID_ADORECORDSET_21 = MYADOID(0x0000054F);
const CLSID ADOS::CLSID_ADOCATALOG_25 = MYADOID(0x00000602);
const IID ADOS::IID_ADOCATALOG_25 = MYADOID(0x00000603);
const CLSID ADOS::CLSID_ADOINDEX_25 = MYADOID(0x0000061E);
const IID ADOS::IID_ADOINDEX_25 = MYADOID(0x0000061F);
const CLSID ADOS::CLSID_ADOTABLE_25 = MYADOID(0x00000609);
const IID ADOS::IID_ADOTABLE_25 = MYADOID(0x00000610);
const CLSID ADOS::CLSID_ADOKEY_25 = MYADOID(0x00000621);
const IID ADOS::IID_ADOKEY_25 = MYADOID(0x00000622);
const CLSID ADOS::CLSID_ADOCOLUMN_25 = MYADOID(0x0000061B);
const IID ADOS::IID_ADOCOLUMN_25 = MYADOID(0x0000061C);
const CLSID ADOS::CLSID_ADOGROUP_25 = MYADOID(0x00000615);
const IID ADOS::IID_ADOGROUP_25 = MYADOID(0x00000616);
const CLSID ADOS::CLSID_ADOUSER_25 = MYADOID(0x00000618);
const IID ADOS::IID_ADOUSER_25 = MYADOID(0x00000619);
const CLSID ADOS::CLSID_ADOVIEW_25 = MYADOID(0x00000612);
const IID ADOS::IID_ADOVIEW_25 = MYADOID(0x00000613);
OLEString& ADOS::GetKeyStr()
{
static OLEString sKeyStr(::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("gxwaezucfyqpwjgqbcmtsncuhwsnyhiohwxz")));
return sKeyStr;
}
2000-09-18 15:18:56 +00:00
// -------------------------------------------------------------------------
sal_Int32 ADOS::MapADOType2Jdbc(DataTypeEnum eType)
{
sal_Int32 nType = DataType::VARCHAR;;
2000-09-18 15:18:56 +00:00
switch (eType)
{
case adUnsignedSmallInt:
2001-04-12 11:33:30 +00:00
case adSmallInt: nType = DataType::SMALLINT; break;
2000-09-18 15:18:56 +00:00
case adUnsignedInt:
2001-04-12 11:33:30 +00:00
case adInteger: nType = DataType::INTEGER; break;
2000-09-18 15:18:56 +00:00
case adUnsignedBigInt:
2001-04-12 11:33:30 +00:00
case adBigInt: nType = DataType::BIGINT; break;
case adSingle: nType = DataType::FLOAT; break;
case adDouble: nType = DataType::DOUBLE; break;
case adCurrency: nType = DataType::DOUBLE; break;
2000-09-18 15:18:56 +00:00
case adVarNumeric:
2001-04-12 11:33:30 +00:00
case adNumeric: nType = DataType::NUMERIC; break;
case adDecimal: nType = DataType::DECIMAL; break;
case adDBDate: nType = DataType::DATE; break;
case adDBTime: nType = DataType::TIME; break;
2001-08-30 12:20:59 +00:00
case adDate:
2001-04-12 11:33:30 +00:00
case adDBTimeStamp: nType = DataType::TIMESTAMP; break;
case adBoolean: nType = DataType::BIT; break;
2001-04-24 07:21:49 +00:00
// case adArray: nType = DataType::ARRAY; break;
2000-09-18 15:18:56 +00:00
case adBinary:
2001-04-12 11:33:30 +00:00
case adGUID: nType = DataType::BINARY; break;
2000-09-18 15:18:56 +00:00
case adBSTR:
case adVarWChar:
case adWChar:
2001-04-12 11:33:30 +00:00
case adVarChar: nType = DataType::VARCHAR; break;
case adLongVarWChar:
case adLongVarChar: nType = DataType::LONGVARCHAR; break;
case adVarBinary: nType = DataType::VARBINARY; break;
case adLongVarBinary: nType = DataType::LONGVARBINARY;break;
case adChar: nType = DataType::CHAR; break;
2000-09-18 15:18:56 +00:00
case adUnsignedTinyInt:
2001-04-12 11:33:30 +00:00
case adTinyInt: nType = DataType::TINYINT; break;
case adEmpty: nType = DataType::SQLNULL; break;
case adUserDefined:
case adPropVariant:
case adFileTime:
case adChapter:
case adIDispatch:
case adIUnknown:
case adError:
case adVariant:
nType = DataType::OTHER; break;
2000-09-18 15:18:56 +00:00
default:
2001-04-12 11:33:30 +00:00
OSL_ENSURE(0,"MapADOType2Jdbc: Unknown Type!");
2000-09-18 15:18:56 +00:00
;
}
2001-04-12 11:33:30 +00:00
return nType;
2000-09-18 15:18:56 +00:00
}
// -------------------------------------------------------------------------
2001-08-30 12:20:59 +00:00
DataTypeEnum ADOS::MapJdbc2ADOType(sal_Int32 _nType,sal_Int32 _nJetEngine)
2000-09-18 15:18:56 +00:00
{
switch (_nType)
{
2001-04-12 11:33:30 +00:00
case DataType::SMALLINT: return adSmallInt; break;
2000-09-18 15:18:56 +00:00
case DataType::INTEGER: return adInteger; break;
case DataType::BIGINT: return adBigInt; break;
2001-04-12 11:33:30 +00:00
case DataType::FLOAT: return adSingle; break;
2000-09-18 15:18:56 +00:00
case DataType::DOUBLE: return adDouble; break;
case DataType::NUMERIC: return adNumeric; break;
case DataType::DECIMAL: return adDecimal; break;
2001-08-30 12:20:59 +00:00
case DataType::DATE: return isJetEngine(_nJetEngine) ? adDate : adDBDate; break;
2001-04-12 11:33:30 +00:00
case DataType::TIME: return adDBTime; break;
2001-08-30 12:20:59 +00:00
case DataType::TIMESTAMP: return isJetEngine(_nJetEngine) ? adDate : adDBTimeStamp; break;
2000-09-18 15:18:56 +00:00
case DataType::BIT: return adBoolean; break;
case DataType::BINARY: return adBinary; break;
case DataType::VARCHAR: return adVarWChar; break;
case DataType::LONGVARCHAR: return adLongVarWChar; break;
2001-04-12 11:33:30 +00:00
case DataType::VARBINARY: return adVarBinary; break;
case DataType::LONGVARBINARY: return adLongVarBinary; break;
case DataType::CHAR: return adWChar; break;
2001-08-30 12:20:59 +00:00
case DataType::TINYINT: return isJetEngine(_nJetEngine) ? adUnsignedTinyInt : adTinyInt;break;
2000-09-18 15:18:56 +00:00
default:
2001-04-12 11:33:30 +00:00
OSL_ENSURE(0,"MapADOType2Jdbc: Unknown Type!");
2000-09-18 15:18:56 +00:00
;
}
return adEmpty;
}
2001-04-12 11:33:30 +00:00
// -----------------------------------------------------------------------------
const int JET_ENGINETYPE_UNKNOWN = 0;
const int JET_ENGINETYPE_JET10 = 1;
const int JET_ENGINETYPE_JET11 = 2;
const int JET_ENGINETYPE_JET20 = 3;
const int JET_ENGINETYPE_JET3X = 4;
const int JET_ENGINETYPE_JET4X = 5;
const int JET_ENGINETYPE_DBASE3 = 10;
const int JET_ENGINETYPE_DBASE4 = 11;
const int JET_ENGINETYPE_DBASE5 = 12;
const int JET_ENGINETYPE_EXCEL30 = 20;
const int JET_ENGINETYPE_EXCEL40 = 21;
const int JET_ENGINETYPE_EXCEL50 = 22;
const int JET_ENGINETYPE_EXCEL80 = 23;
const int JET_ENGINETYPE_EXCEL90 = 24;
const int JET_ENGINETYPE_EXCHANGE4 = 30;
const int JET_ENGINETYPE_LOTUSWK1 = 40;
const int JET_ENGINETYPE_LOTUSWK3 = 41;
const int JET_ENGINETYPE_LOTUSWK4 = 42;
const int JET_ENGINETYPE_PARADOX3X = 50;
const int JET_ENGINETYPE_PARADOX4X = 51;
const int JET_ENGINETYPE_PARADOX5X = 52;
const int JET_ENGINETYPE_PARADOX7X = 53;
const int JET_ENGINETYPE_TEXT1X = 60;
const int JET_ENGINETYPE_HTML1X = 70;
sal_Bool ADOS::isJetEngine(sal_Int32 _nEngineType)
{
sal_Bool bRet = sal_False;
switch(_nEngineType)
{
case JET_ENGINETYPE_UNKNOWN:
case JET_ENGINETYPE_JET10:
case JET_ENGINETYPE_JET11:
case JET_ENGINETYPE_JET20:
case JET_ENGINETYPE_JET3X:
case JET_ENGINETYPE_JET4X:
case JET_ENGINETYPE_DBASE3:
case JET_ENGINETYPE_DBASE4:
case JET_ENGINETYPE_DBASE5:
case JET_ENGINETYPE_EXCEL30:
case JET_ENGINETYPE_EXCEL40:
case JET_ENGINETYPE_EXCEL50:
case JET_ENGINETYPE_EXCEL80:
case JET_ENGINETYPE_EXCEL90:
case JET_ENGINETYPE_EXCHANGE4:
case JET_ENGINETYPE_LOTUSWK1:
case JET_ENGINETYPE_LOTUSWK3:
case JET_ENGINETYPE_LOTUSWK4:
case JET_ENGINETYPE_PARADOX3X:
case JET_ENGINETYPE_PARADOX4X:
case JET_ENGINETYPE_PARADOX5X:
case JET_ENGINETYPE_PARADOX7X:
case JET_ENGINETYPE_TEXT1X:
case JET_ENGINETYPE_HTML1X:
bRet = sal_True;
break;
}
return bRet;
}
2001-06-20 06:16:56 +00:00
// -----------------------------------------------------------------------------
ObjectTypeEnum ADOS::mapObjectType2Ado(sal_Int32 objType)
{
ObjectTypeEnum eType = adPermObjTable;
switch(objType)
{
case PrivilegeObject::TABLE:
eType = adPermObjTable;
break;
case PrivilegeObject::VIEW:
eType = adPermObjView;
break;
case PrivilegeObject::COLUMN:
eType = adPermObjColumn;
break;
}
return eType;
}
// -----------------------------------------------------------------------------
sal_Int32 ADOS::mapAdoType2Object(ObjectTypeEnum objType)
{
sal_Int32 nType = PrivilegeObject::TABLE;
switch(objType)
{
case adPermObjTable:
nType = PrivilegeObject::TABLE;
break;
case adPermObjView:
nType = PrivilegeObject::VIEW;
break;
case adPermObjColumn:
nType = PrivilegeObject::COLUMN;
break;
}
return nType;
}
#ifdef DELETE
#undef DELETE
#endif
// -----------------------------------------------------------------------------
sal_Int32 ADOS::mapAdoRights2Sdbc(RightsEnum eRights)
{
sal_Int32 nRights = 0;
if((eRights & adRightInsert) == adRightInsert)
nRights |= Privilege::INSERT;
if((eRights & adRightDelete) == adRightDelete)
nRights |= ::com::sun::star::sdbcx::Privilege::DELETE;
if((eRights & adRightUpdate) == adRightUpdate)
nRights |= Privilege::UPDATE;
if((eRights & adRightWriteDesign) == adRightWriteDesign)
nRights |= Privilege::ALTER;
if((eRights & adRightRead) == adRightRead)
nRights |= Privilege::SELECT;
if((eRights & adRightReference) == adRightReference)
nRights |= Privilege::REFERENCE;
if((eRights & adRightDrop) == adRightDrop)
nRights |= Privilege::DROP;
return nRights;
}
// -----------------------------------------------------------------------------
sal_Int32 ADOS::mapRights2Ado(sal_Int32 nRights)
{
sal_Int32 eRights = adRightNone;
if((nRights & Privilege::INSERT) == Privilege::INSERT)
eRights |= adRightInsert;
if((nRights & Privilege::DELETE) == Privilege::DELETE)
eRights |= adRightDelete;
if((nRights & Privilege::UPDATE) == Privilege::UPDATE)
eRights |= adRightUpdate;
if((nRights & Privilege::ALTER) == Privilege::ALTER)
eRights |= adRightWriteDesign;
if((nRights & Privilege::SELECT) == Privilege::SELECT)
eRights |= adRightRead;
if((nRights & Privilege::REFERENCE) == Privilege::REFERENCE)
eRights |= adRightReference;
if((nRights & Privilege::DROP) == Privilege::DROP)
eRights |= adRightDrop;
return eRights;
}
// -----------------------------------------------------------------------------
2001-07-30 07:53:02 +00:00
WpADOField ADOS::getField(ADORecordset* _pRecordSet,sal_Int32 _nColumnIndex) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException)
{
ADOFields* pFields = NULL;
_pRecordSet->get_Fields(&pFields);
WpOLEAppendCollection<ADOFields, ADOField, WpADOField> aFields(pFields); \
if(_nColumnIndex <= 0 || _nColumnIndex > aFields.GetItemCount())
::dbtools::throwInvalidIndexException(NULL);
WpADOField aField(aFields.GetItem(_nColumnIndex-1));
if(!aField.IsValid())
::dbtools::throwInvalidIndexException(NULL);
return aField;
}
// -----------------------------------------------------------------------------
2001-04-12 11:33:30 +00:00
2000-09-18 15:18:56 +00:00