Files
libreoffice/connectivity/source/inc/dbase/DTable.hxx

211 lines
11 KiB
C++
Raw Normal View History

2000-09-18 15:18:56 +00:00
/*************************************************************************
*
* $RCSfile: DTable.hxx,v $
*
2001-03-28 10:32:43 +00:00
* $Revision: 1.19 $
2000-09-18 15:18:56 +00:00
*
2001-03-28 10:32:43 +00:00
* last change: $Author: oj $ $Date: 2001-03-28 11:28:46 $
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): _______________________________________
*
*
************************************************************************/
#ifndef _CONNECTIVITY_DBASE_TABLE_HXX_
#define _CONNECTIVITY_DBASE_TABLE_HXX_
#ifndef _CONNECTIVITY_FILE_TABLE_HXX_
#include "file/FTable.hxx"
#endif
#ifndef _CONNECTIVITY_SDBCX_COLUMN_HXX_
#include "connectivity/sdbcx/VColumn.hxx"
#endif
#ifndef _CONNECTIVITY_COMMONTOOLS_HXX_
#include "connectivity/CommonTools.hxx"
#endif
2000-09-20 05:52:26 +00:00
#ifndef _URLOBJ_HXX //autogen wg. INetURLObject
#include <tools/urlobj.hxx>
2000-09-18 15:18:56 +00:00
#endif
namespace connectivity
{
namespace dbase
{
typedef file::OFileTable ODbaseTable_BASE;
class ODbaseConnection;
typedef ::std::map< ::rtl::OUString,
2000-10-11 09:48:50 +00:00
::com::sun::star::uno::Reference< ::com::sun::star::container::XNamed>, comphelper::UStringMixLess > OContainer;
2000-09-18 15:18:56 +00:00
class ODbaseTable : public ODbaseTable_BASE
{
// der Typ einer dBase datei wird mit dem ersten Byte bestimmt
public:
enum DBFType { dBaseIII = 0x03,
dBaseIV = 0x04,
dBaseV = 0x05,
dBaseFS = 0x43,
dBaseFSMemo = 0xB3,
dBaseIIIMemo = 0x83,
dBaseIVMemo = 0x8B,
dBaseIVMemoSQL = 0x8E,
FoxProMemo = 0xF5
};
enum DBFMemoType { MemodBaseIII = 0,
MemodBaseIV,
MemoFoxPro
};
private:
struct DBFHeader { /* Kopfsatz-Struktur */
DBFType db_typ; /* Dateityp */
2000-09-18 15:18:56 +00:00
BYTE db_aedat[3]; /* Datum der letzen Aenderung */
/* JJ MM TT */
ULONG db_anz; /* Anzahl der Saetze */
USHORT db_kopf; /* laenge Kopfsatz-Struktur */
USHORT db_slng; /* laenge der Daten-Saetze */
BYTE db_frei[20]; /* reserviert */
};
struct DBFColumn { /* Feldbezeichner */
BYTE db_fnm[11]; /* Feldname */
BYTE db_typ; /* Feldtyp */
ULONG db_adr; /* Feldadresse */
BYTE db_flng; /* Feldlaenge */
BYTE db_dez; /* Dezimalstellen fuer N */
BYTE db_frei2[14]; /* reserviert */
};
struct DBFMemoHeader
{
DBFMemoType db_typ; /* Dateityp */
2000-09-18 15:18:56 +00:00
UINT32 db_next; /* n<>chster freier Block */
USHORT db_size; /* Blockgr<67><72>e: dBase 3 fest */
};
2000-11-27 09:28:51 +00:00
::std::vector<sal_Int32> m_aTypes; // holds all type for columns just to avoid to ask the propertyset
::std::vector<sal_Int32> m_aPrecisions; // same as aboth
::std::vector<sal_Int32> m_aScales;
2000-09-18 15:18:56 +00:00
DBFHeader m_aHeader;
DBFMemoHeader m_aMemoHeader;
2000-11-16 09:47:23 +00:00
SvStream* m_pMemoStream;
sal_Bool m_bWriteableMemo;
2000-09-18 15:18:56 +00:00
2001-03-28 10:32:43 +00:00
void alterColumn(sal_Int32 index,
const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet>& descriptor ,
const ::com::sun::star::uno::Reference< ::com::sun::star::sdbcx::XDataDescriptorFactory>& xOldColumn );
2000-09-18 15:18:56 +00:00
void readHeader();
void fillColumns();
2001-03-28 10:32:43 +00:00
String createTempFile();
void copyData(ODbaseTable* _pNewTable);
2000-09-20 05:52:26 +00:00
BOOL CreateFile(const INetURLObject& aFile, BOOL& bCreateMemo);
BOOL CreateMemoFile(const INetURLObject& aFile);
2000-09-18 15:18:56 +00:00
BOOL HasMemoFields() const { return m_aHeader.db_typ > dBaseIV;}
BOOL ReadMemoHeader();
2001-03-28 10:32:43 +00:00
BOOL ReadMemo(ULONG nBlockNo, ORowSetValue& aVariable);
2000-09-18 15:18:56 +00:00
2001-03-28 10:32:43 +00:00
BOOL WriteMemo(ORowSetValue& aVariable, ULONG& rBlockNr);
2000-09-18 15:18:56 +00:00
BOOL WriteBuffer();
2001-03-28 10:32:43 +00:00
BOOL UpdateBuffer(OValueVector& rRow, OValueRow pOrgRow,const ::com::sun::star::uno::Reference< ::com::sun::star::container::XIndexAccess>& _xCols);
2000-10-30 06:34:16 +00:00
::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet> isUniqueByColumnName(const ::rtl::OUString& _rColName);
2000-09-18 15:18:56 +00:00
void AllocBuffer();
2000-11-03 12:54:44 +00:00
protected:
virtual void FileClose();
2000-09-18 15:18:56 +00:00
public:
virtual void refreshColumns();
virtual void refreshIndexes();
public:
// DECLARE_CTY_DEFAULTS( ODbaseTable_BASE);
ODbaseTable( ODbaseConnection* _pConnection);
ODbaseTable( ODbaseConnection* _pConnection,
const ::rtl::OUString& _Name,
const ::rtl::OUString& _Type,
const ::rtl::OUString& _Description = ::rtl::OUString(),
const ::rtl::OUString& _SchemaName = ::rtl::OUString(),
const ::rtl::OUString& _CatalogName = ::rtl::OUString()
);
2001-02-22 12:53:00 +00:00
void construct(); // can throw any exception
2000-09-18 15:18:56 +00:00
virtual sal_Int32 getCurrentLastPos() const {return m_aHeader.db_anz;}
virtual sal_Bool seekRow(FilePosition eCursorPosition, sal_Int32 nOffset, sal_Int32& nCurPos);
2001-03-28 10:32:43 +00:00
virtual sal_Bool fetchRow(OValueRow _rRow,const OSQLColumns& _rCols, sal_Bool _bUseTableDefs,sal_Bool bRetrieveData);
2000-09-18 15:18:56 +00:00
virtual ::com::sun::star::uno::Any SAL_CALL queryInterface( const ::com::sun::star::uno::Type & rType ) throw(::com::sun::star::uno::RuntimeException);
//XTypeProvider
virtual ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Type > SAL_CALL getTypes( ) throw(::com::sun::star::uno::RuntimeException);
virtual void SAL_CALL disposing(void);
// com::sun::star::lang::XUnoTunnel
virtual sal_Int64 SAL_CALL getSomething( const ::com::sun::star::uno::Sequence< sal_Int8 >& aIdentifier ) throw(::com::sun::star::uno::RuntimeException);
static ::com::sun::star::uno::Sequence< sal_Int8 > getUnoTunnelImplementationId();
2001-03-28 10:32:43 +00:00
// XAlterTable
virtual void SAL_CALL alterColumnByName( const ::rtl::OUString& colName, const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet >& descriptor ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::container::NoSuchElementException, ::com::sun::star::uno::RuntimeException);
virtual void SAL_CALL alterColumnByIndex( sal_Int32 index, const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet >& descriptor ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::lang::IndexOutOfBoundsException, ::com::sun::star::uno::RuntimeException);
// XRename
virtual void SAL_CALL rename( const ::rtl::OUString& newName ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::container::ElementExistException, ::com::sun::star::uno::RuntimeException);
2000-09-18 15:18:56 +00:00
2001-03-28 10:32:43 +00:00
BOOL DropImpl();
BOOL CreateImpl();
String getEntry();
2000-09-18 15:18:56 +00:00
2001-03-28 10:32:43 +00:00
virtual BOOL InsertRow(OValueVector& rRow, BOOL bFlush,const ::com::sun::star::uno::Reference< ::com::sun::star::container::XIndexAccess>& _xCols);
2000-09-18 15:18:56 +00:00
virtual BOOL DeleteRow(const OSQLColumns& _rCols);
2001-03-28 10:32:43 +00:00
virtual BOOL UpdateRow(OValueVector& rRow, OValueRow pOrgRow,const ::com::sun::star::uno::Reference< ::com::sun::star::container::XIndexAccess>& _xCols);
virtual void addColumn(const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet>& descriptor);
2000-09-18 15:18:56 +00:00
};
}
}
#endif // _CONNECTIVITY_DBASE_TABLE_HXX_