2000-09-18 15:18:56 +00:00
|
|
|
|
/*************************************************************************
|
|
|
|
|
*
|
|
|
|
|
* $RCSfile: DTable.hxx,v $
|
|
|
|
|
*
|
2001-09-19 10:03:04 +00:00
|
|
|
|
* $Revision: 1.28 $
|
2000-09-18 15:18:56 +00:00
|
|
|
|
*
|
2001-09-19 10:03:04 +00:00
|
|
|
|
* last change: $Author: oj $ $Date: 2001-09-19 11:03:03 $
|
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 */
|
2000-12-11 07:42:48 +00:00
|
|
|
|
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
|
|
|
|
|
{
|
2000-12-11 07:42:48 +00:00
|
|
|
|
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;
|
2000-12-08 11:55:13 +00:00
|
|
|
|
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();
|
2001-06-29 07:29:14 +00:00
|
|
|
|
void copyData(ODbaseTable* _pNewTable,sal_Int32 _nPos);
|
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);
|
2001-08-24 05:19:41 +00:00
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet> isUniqueByColumnName(sal_Int32 _nColumnPos);
|
2000-09-18 15:18:56 +00:00
|
|
|
|
void AllocBuffer();
|
|
|
|
|
|
2001-08-02 06:59:15 +00:00
|
|
|
|
void throwInvalidDbaseFormat();
|
|
|
|
|
|
2000-11-03 12:54:44 +00:00
|
|
|
|
protected:
|
|
|
|
|
virtual void FileClose();
|
2001-03-30 09:16:42 +00:00
|
|
|
|
// using ::connectivity::sdbcx::OTableDescriptor_BASE::rBHelper;
|
2001-03-30 11:46:36 +00:00
|
|
|
|
|
2000-09-18 15:18:56 +00:00
|
|
|
|
public:
|
|
|
|
|
virtual void refreshColumns();
|
|
|
|
|
virtual void refreshIndexes();
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
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
|
|
|
|
|
|
2001-04-30 09:16:19 +00:00
|
|
|
|
virtual sal_Int32 getCurrentLastPos() const;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
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();
|
2001-08-10 10:05:34 +00:00
|
|
|
|
|
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);
|
2001-05-30 09:44:16 +00:00
|
|
|
|
virtual void dropColumn(sal_Int32 _nPos);
|
2001-08-10 10:05:34 +00:00
|
|
|
|
|
|
|
|
|
static String getEntry(file::OConnection* _pConnection,const ::rtl::OUString& _sURL );
|
|
|
|
|
static BOOL Drop_Static(const ::rtl::OUString& _sUrl,sal_Bool _bHasMemoFields,sdbcx::OCollection* _pIndexes );
|
2001-09-19 10:03:04 +00:00
|
|
|
|
|
|
|
|
|
virtual void refreshHeader();
|
2000-09-18 15:18:56 +00:00
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
#endif // _CONNECTIVITY_DBASE_TABLE_HXX_
|
|
|
|
|
|