1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: swgstr.hxx,v $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
33 #include <tools/stream.hxx>
35 typedef long long3
; // Zur Dokumentation: 3-byte-Longs
37 #define MAX_BEGIN 64 // Maximale Blockschachtelung
38 #define PASSWDLEN 16 // Maximale Passwortlaenge
40 // Neue Version mit SvStreams
42 // Passwort- und Codierungs-Funktionalitaet
46 sal_Char cPasswd
[ PASSWDLEN
]; // Passwort-Puffer
47 BOOL bPasswd
; // TRUE wenn mit Passwort
48 void encode( sal_Char
*, USHORT
); // Puffer codieren/decodieren
51 BOOL
setpasswd( const String
& ); // Passwort setzen
52 void copypasswd( const sal_Char
* ); // Passwort direkt setzen
53 const sal_Char
* getpasswd() { return cPasswd
; }
56 // Reader/Writer-Stream-Basisklasse mit Pufferverwaltung fuer Texte
57 // und Spezial-I/O fuer 3-Byte-Longs
59 class swstreambase
: public swcrypter
{
61 SvStream
* pStrm
; // eigentlicher Stream
62 sal_Char
* pBuf
; // Zwischenpuffer
63 USHORT nBuflen
; // Laenge des Zwischenpuffers
64 short nLong
; // Long-Laenge (3 oder 4)
65 BOOL bTempStrm
; // TRUE: Stream loeschen
66 void checkbuf( USHORT
); // Testen der Pufferlaenge
68 swstreambase( SvStream
& );
70 swstreambase( const swstreambase
& );
71 int operator=( const swstreambase
& );
74 SvStream
& Strm() { return *pStrm
; }
75 void clear(); // Puffer loeschen
77 // Zusatzfunktionen zur I/O von LONGs als 3-Byte-Zahlen
79 void long3() { nLong
= 3; }
80 void long4() { nLong
= 4; }
82 // Alias- und Hilfsfunktionen
84 void seek( long nPos
) { pStrm
->Seek( nPos
); }
85 long tell() { return pStrm
->Tell(); }
86 long filesize(); // Dateigroesse
89 int good() { return ( pStrm
->GetError() == SVSTREAM_OK
); }
90 int operator!() { return ( pStrm
->GetError() != SVSTREAM_OK
); }
91 int eof() { return pStrm
->IsEof(); }
94 void get( void* p
, USHORT n
) { pStrm
->Read( (sal_Char
*) p
, n
); }
96 inline swstreambase
& operator>>( sal_Char
& );
97 inline swstreambase
& operator>>( BYTE
& );
98 inline swstreambase
& operator>>( short& );
99 inline swstreambase
& operator>>( USHORT
& );
100 swstreambase
& operator>>( long& );
101 inline swstreambase
& operator>>( ULONG
& );
104 inline swstreambase
& swstreambase::operator>>( sal_Char
& c
)
106 *pStrm
>> c
; return *this;
109 inline swstreambase
& swstreambase::operator>>( BYTE
& c
)
111 *pStrm
>> c
; return *this;
114 inline swstreambase
& swstreambase::operator>>( short& c
)
116 *pStrm
>> c
; return *this;
119 inline swstreambase
& swstreambase::operator>>( USHORT
& c
)
121 *pStrm
>> c
; return *this;
124 inline swstreambase
& swstreambase::operator>>( ULONG
& c
)
126 return *this >> (long&) c
;
129 class swistream
: public swstreambase
{
130 BYTE cType
; // Record-Typ
131 ULONG nOffset
; // Record-Offset-Portion
133 swistream( SvStream
& );
135 BYTE
peek(); // 1 Byte testen
136 BYTE
next(); // Blockstart
137 BYTE
cur() { return cType
; } // aktueller Block
138 BYTE
skipnext(); // Record ueberspringen
139 void undonext(); // next() rueckgaengig machen
140 long getskip() { return nOffset
; }
141 void skip( long = -1L ); // Block ueberspringen
142 sal_Char
* text(); // Textstring lesen (nach BEGIN)
143 long size(); // aktuelle Record-Laenge
146 swistream( const swistream
& );
147 int operator=( const swistream
& );