diff options
Diffstat (limited to 'sot/source/sdstor/stgstrms.hxx')
-rw-r--r-- | sot/source/sdstor/stgstrms.hxx | 170 |
1 files changed, 170 insertions, 0 deletions
diff --git a/sot/source/sdstor/stgstrms.hxx b/sot/source/sdstor/stgstrms.hxx new file mode 100644 index 000000000000..9b09f51db43f --- /dev/null +++ b/sot/source/sdstor/stgstrms.hxx @@ -0,0 +1,170 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org 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 version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +#ifndef _STGSTRMS_HXX +#define _STGSTRMS_HXX + +#ifndef _TOOLS_STREAM_HXX +#include <tools/stream.hxx> +#endif + +class StgIo; +class StgStrm; +class StgPage; +class StgDirEntry; + +// The FAT class performs FAT operations on an underlying storage stream. +// This stream is either the physical FAT stream (bPhys == TRUE ) or a normal +// storage stream, which then holds the FAT for small data allocations. + +class StgFAT +{ // FAT allocator + StgStrm& rStrm; // underlying stream + INT32 nMaxPage; // highest page allocated so far + short nPageSize; // physical page size + short nEntries; // FAT entries per page + short nOffset; // current offset within page + INT32 nLimit; // search limit recommendation + BOOL bPhys; // TRUE: physical FAT + StgPage* GetPhysPage( INT32 nPage ); + BOOL MakeChain( INT32 nStart, INT32 nPages ); + BOOL InitNew( INT32 nPage1 ); +public: + StgFAT( StgStrm& rStrm, BOOL bMark ); + INT32 FindBlock( INT32& nPages ); + INT32 GetNextPage( INT32 nPg ); + INT32 AllocPages( INT32 nStart, INT32 nPages ); + BOOL FreePages( INT32 nStart, BOOL bAll ); + INT32 GetMaxPage() { return nMaxPage; } + void SetLimit( INT32 n ) { nLimit = n; } +}; + +// The base stream class provides basic functionality for seeking +// and accessing the data on a physical basis. It uses the built-in +// FAT class for the page allocations. + +class StgStrm { // base class for all streams +protected: + StgIo& rIo; // I/O system + StgFAT* pFat; // FAT stream for allocations + StgDirEntry* pEntry; // dir entry (for ownership) + INT32 nStart; // 1st data page + INT32 nSize; // stream size in bytes + INT32 nPos; // current byte position + INT32 nPage; // current logical page + short nOffset; // offset into current page + short nPageSize; // logical page size + BOOL Copy( INT32 nFrom, INT32 nBytes ); + StgStrm( StgIo& ); +public: + virtual ~StgStrm(); + StgIo& GetIo() { return rIo; } + INT32 GetPos() { return nPos; } + INT32 GetStart() { return nStart; } + INT32 GetSize() { return nSize; } + INT32 GetPage() { return nPage; } + short GetPageSize() { return nPageSize; } + INT32 GetPages(); + short GetOffset() { return nOffset;} + void SetEntry( StgDirEntry& ); + virtual BOOL SetSize( INT32 ); + virtual BOOL Pos2Page( INT32 nBytePos ); + virtual INT32 Read( void*, INT32 ) { return 0; } + virtual INT32 Write( const void*, INT32 ) { return 0; } + virtual StgPage* GetPhysPage( INT32 nBytePos, BOOL bForce = FALSE ); + virtual BOOL IsSmallStrm() { return FALSE; } +}; + +// The FAT stream class provides physical access to the master FAT. +// Since this access is implemented as a StgStrm, we can use the +// FAT allocator. + +class StgFATStrm : public StgStrm { // the master FAT stream + virtual BOOL Pos2Page( INT32 nBytePos ); + BOOL SetPage( short, INT32 ); +public: + StgFATStrm( StgIo& ); + virtual ~StgFATStrm() {} + using StgStrm::GetPage; + INT32 GetPage( short, BOOL, USHORT *pnMasterAlloc = 0); + virtual BOOL SetSize( INT32 ); + virtual StgPage* GetPhysPage( INT32 nBytePos, BOOL bForce = FALSE ); +}; + +// The stream has a size increment which normally is 1, but which can be +// set to any value is you want the size to be incremented by certain values. + +class StgDataStrm : public StgStrm // a physical data stream +{ + short nIncr; // size adjust increment + void Init( INT32 nBgn, INT32 nLen ); +public: + StgDataStrm( StgIo&, INT32 nBgn, INT32 nLen=-1 ); + StgDataStrm( StgIo&, StgDirEntry* ); + void* GetPtr( INT32 nPos, BOOL bForce, BOOL bDirty ); + void SetIncrement( short n ) { nIncr = n ; } + virtual BOOL SetSize( INT32 ); + virtual INT32 Read( void*, INT32 ); + virtual INT32 Write( const void*, INT32 ); +}; + +// The small stream class provides access to streams with a size < 4096 bytes. +// This stream is a StgStream containing small pages. The FAT for this stream +// is also a StgStream. The start of the FAT is in the header at DataRootPage, +// the stream itself is pointed to by the root entry (it holds start & size). + +class StgSmallStrm : public StgStrm // a logical data stream +{ + StgStrm* pData; // the data stream + void Init( INT32 nBgn, INT32 nLen ); +public: + StgSmallStrm( StgIo&, INT32 nBgn, INT32 nLen ); + StgSmallStrm( StgIo&, StgDirEntry* ); + virtual INT32 Read( void*, INT32 ); + virtual INT32 Write( const void*, INT32 ); + virtual BOOL IsSmallStrm() { return TRUE; } +}; + +class StgTmpStrm : public SvMemoryStream +{ + String aName; + SvFileStream* pStrm; + using SvMemoryStream::GetData; + virtual ULONG GetData( void* pData, ULONG nSize ); + virtual ULONG PutData( const void* pData, ULONG nSize ); + virtual ULONG SeekPos( ULONG nPos ); + virtual void FlushData(); + +public: + StgTmpStrm( ULONG=16 ); + ~StgTmpStrm(); + BOOL Copy( StgTmpStrm& ); + void SetSize( ULONG ); + ULONG GetSize() const; +}; + +#endif |