summaryrefslogtreecommitdiff
path: root/tools/inc/tools/stream.hxx
blob: a50138913e45f95aa9008777491746bc57557297 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*************************************************************************
 *
 * 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 _STREAM_HXX
#define _STREAM_HXX

#include "tools/toolsdllapi.h"
#include <tools/solar.h>
#include <tools/string.hxx>
#include <tools/errinf.hxx>
#include <tools/ref.hxx>
#include <tools/rtti.hxx>

class FileCopier;
class StreamData;

// ------------------------
// - FileFormat-Functions -
// ------------------------

inline rtl_TextEncoding GetStoreCharSet( rtl_TextEncoding eEncoding )
{
    if ( eEncoding == RTL_TEXTENCODING_ISO_8859_1 )
        return RTL_TEXTENCODING_MS_1252;
    else
        return eEncoding;
}

// ---------------
// - StreamTypes -
// ---------------

typedef sal_uInt16 StreamMode;

// read, write, create,... options
#define STREAM_READ 					0x0001	// allow read accesses
#define STREAM_WRITE					0x0002	// allow write accesses
// file i/o
#define STREAM_NOCREATE 				0x0004	// 1 == Dont create file
#define STREAM_TRUNC					0x0008	// Truncate _existing_ file to zero length
#define STREAM_COPY_ON_SYMLINK			0x0010	// copy-on-write for symlinks (UNX)

#define STREAM_READWRITEBITS			(STREAM_READ | STREAM_WRITE | \
                                         STREAM_NOCREATE | STREAM_TRUNC)

// sharing options
#define STREAM_SHARE_DENYNONE			0x0100
#define STREAM_SHARE_DENYREAD			0x0200	// overrides denynone
#define STREAM_SHARE_DENYWRITE		0x0400	// overrides denynone
#define STREAM_SHARE_DENYALL			0x0800	// overrides denyread,write,none

#define STREAM_SHAREBITS				(STREAM_SHARE_DENYNONE | STREAM_SHARE_DENYREAD |\
                                         STREAM_SHARE_DENYWRITE | STREAM_SHARE_DENYALL)

#define STREAM_READWRITE				(STREAM_READ | STREAM_WRITE)
#define STREAM_SHARE_DENYREADWRITE		(STREAM_SHARE_DENYREAD | STREAM_SHARE_DENYWRITE)

#define STREAM_STD_READ 				(STREAM_READ | STREAM_SHARE_DENYNONE | STREAM_NOCREATE)
#define STREAM_STD_WRITE				(STREAM_WRITE | STREAM_SHARE_DENYALL)
#define STREAM_STD_READWRITE			(STREAM_READWRITE | STREAM_SHARE_DENYALL)

#define STREAM_SEEK_TO_BEGIN			0L
#define STREAM_SEEK_TO_END				ULONG_MAX

#define NUMBERFORMAT_INT_BIGENDIAN		(sal_uInt16)0x0000
#define NUMBERFORMAT_INT_LITTLEENDIAN	(sal_uInt16)0xFFFF

#define COMPRESSMODE_FULL			(sal_uInt16)0xFFFF
#define COMPRESSMODE_NONE			(sal_uInt16)0x0000
#define COMPRESSMODE_ZBITMAP			(sal_uInt16)0x0001
#define COMPRESSMODE_NATIVE 			(sal_uInt16)0x0010

#define JUSTIFY_RIGHT				0x00
#define JUSTIFY_LEFT				0x01

#define STREAM_IO_DONTKNOW			0
#define STREAM_IO_READ				1
#define STREAM_IO_WRITE 				2

#define ID_STREAM						1
#define ID_FILESTREAM					2
#define ID_MEMORYSTREAM 				3
#define ID_SHAREDMEMORYSTREAM			4
#define ID_STORAGESTREAM				5
#define ID_PERSISTSTREAM				6

class SvStream;
typedef SvStream& (*SvStrPtr)( SvStream& );

// forward declaration with internal linkage
inline SvStream& operator<<( SvStream& rStr, SvStrPtr f );

// ---------------
// - SvLockBytes -
// ---------------

enum LockType {};

struct SvLockBytesStat
{
    sal_Size nSize;

    SvLockBytesStat(): nSize(0) {}
};

enum SvLockBytesStatFlag { SVSTATFLAG_DEFAULT };

class TOOLS_DLLPUBLIC SvLockBytes: public virtual SvRefBase
{
    SvStream * m_pStream;
    sal_Bool m_bOwner;
    sal_Bool m_bSync;

protected:
    void close();

public:
    TYPEINFO();

    SvLockBytes(): m_pStream(0), m_bOwner(FALSE), m_bSync(FALSE) {}

    SvLockBytes(SvStream * pTheStream, sal_Bool bTheOwner = FALSE):
        m_pStream(pTheStream), m_bOwner(bTheOwner), m_bSync(FALSE) {}

    virtual ~SvLockBytes() { close(); }

    virtual const SvStream * GetStream() const { return m_pStream; }

    virtual void SetSynchronMode(sal_Bool bTheSync = TRUE) { m_bSync = bTheSync; }

    virtual sal_Bool IsSynchronMode() const { return m_bSync; }

    virtual ErrCode ReadAt(sal_Size nPos, void * pBuffer, sal_Size nCount,
                           sal_Size * pRead) const;

    virtual ErrCode WriteAt(sal_Size nPos, const void * pBuffer, sal_Size nCount,
                            sal_Size * pWritten);

    virtual ErrCode Flush() const;

    virtual ErrCode SetSize(sal_Size nSize);

    virtual ErrCode LockRegion(sal_Size, sal_Size, LockType);

    virtual ErrCode UnlockRegion(sal_Size, sal_Size, LockType);

    virtual ErrCode Stat(SvLockBytesStat * pStat, SvLockBytesStatFlag) const;
};

SV_DECL_IMPL_REF(SvLockBytes);

// -------------------
// - SvOpenLockBytes -
// -------------------

class TOOLS_DLLPUBLIC SvOpenLockBytes: public SvLockBytes
{
public:
    TYPEINFO();

    SvOpenLockBytes(): SvLockBytes(0, FALSE) {}

    SvOpenLockBytes(SvStream * pStream, sal_Bool bOwner):
        SvLockBytes(pStream, bOwner) {}

    virtual ErrCode FillAppend(const void * pBuffer, sal_Size nCount,
                               sal_Size * pWritten) = 0;

    virtual sal_Size Tell() const = 0;

    virtual sal_Size Seek(sal_Size nPos) = 0;

    virtual void Terminate() = 0;
};

SV_DECL_IMPL_REF(SvOpenLockBytes);

// --------------------
// - SvAsyncLockBytes -
// --------------------

class SvAsyncLockBytes: public SvOpenLockBytes
{
    sal_Size m_nSize;
    sal_Bool m_bTerminated;

public:
    TYPEINFO();

    SvAsyncLockBytes(SvStream * pStream, sal_Bool bOwner):
        SvOpenLockBytes(pStream, bOwner), m_nSize(0), m_bTerminated(FALSE) {}

    virtual ErrCode ReadAt(sal_Size nPos, void * pBuffer, sal_Size nCount,
                           sal_Size * pRead) const;

    virtual ErrCode WriteAt(sal_Size nPos, const void * pBuffer, sal_Size nCount,
                            sal_Size * pWritten);

    virtual ErrCode FillAppend(const void * pBuffer, sal_Size nCount,
                               sal_Size * pWritten);

    virtual sal_Size Tell() const { return m_nSize; }

    virtual sal_Size Seek(sal_Size nPos);

    virtual void Terminate() { m_bTerminated = TRUE; }
};

SV_DECL_IMPL_REF(SvAsyncLockBytes);

// ----------
// - Stream -
// ----------

class TOOLS_DLLPUBLIC SvStream
{
private:
    // LockBytes Interface
    void*		pImp;			// unused
    SvLockBytesRef	xLockBytes; 	// Default Implmentierung
    sal_Size		nActPos;		//

    // Puffer-Verwaltung
    sal_uInt8*	pRWBuf; 		// Zeigt auf Read/Write-Puffer
    sal_uInt8*	pBufPos;		// pRWBuf + nBufActualPos
    sal_uInt16	nBufSize;		// Allozierte Groesse des Puffers
    sal_uInt16	nBufActualLen;	// Laenge des beschriebenen Teils des Puffers
                                    // Entspricht nBufSize, wenn EOF nicht
                                    // ueberschritten wurde
    sal_uInt16	nBufActualPos;	// aktuelle Position im Puffer (0..nBufSize-1)
    sal_uInt16	nBufFree;		// freier Platz im Puffer fuer IO vom Typ eIOMode
    unsigned int	eIOMode:2;		// STREAM_IO_*

    // Error-Codes, Konvertierung, Komprimierung, ...
    int 			bIsDirty:1; 	// TRUE: Stream != Pufferinhalt
    int 			bIsConsistent:1;// FALSE: Buffer enthaelt Daten, die NICHT
                                    // per PutData in den abgeleiteten Stream
                                    // geschrieben werden duerfen (siehe PutBack)
    int 			bSwap:1;
    int 			bIsEof:1;
    sal_uInt32	nError;
    sal_uInt16	nNumberFormatInt;
    sal_uInt16	nCompressMode;
    LineEnd 		eLineDelimiter;
    CharSet 		eStreamCharSet;
//	CharSet 		eTargetCharSet;

    // Verschluesselung
    ByteString		aKey;			// aKey.Len != 0  -> Verschluesselung
    unsigned char	nCryptMask;

    // Formatierung von Strings
    char			cFiller;
    sal_uInt8			nRadix;
    sal_uInt8			nPrecision;
    sal_uInt8			nWidth;
    sal_uInt8			nPrintfParams;
    sal_uInt8			nJustification;
    ByteString		aFormatString;

    // Userdata
    long			nVersion;		// for external use

    // Hilfsmethoden
    void			CreateFormatString();
    TOOLS_DLLPRIVATE void			ImpInit();

                     SvStream ( const SvStream& rStream ); // not implemented
    SvStream&		operator=( const SvStream& rStream ); // not implemented

protected:
    sal_Size			nBufFilePos;	// Fileposition von pBuf[0]
    sal_uInt16			eStreamMode;
    sal_Bool			bIsWritable;

    virtual sal_Size	GetData( void* pData, sal_Size nSize );
    virtual sal_Size	PutData( const void* pData, sal_Size nSize );
    virtual sal_Size	SeekPos( sal_Size nPos );
    virtual void	FlushData();
    virtual void	SetSize( sal_Size nSize );

    void			ClearError();
    void			ClearBuffer();

    // verschluesselt & schreibt blockweise
    sal_Size			CryptAndWriteBuffer( const void* pStart, sal_Size nLen );
    sal_Bool			EncryptBuffer( void* pStart, sal_Size nLen );

    void			SyncSvStream( sal_Size nNewStreamPos ); // SvStream <- Medium
    void			SyncSysStream(); // SvStream -> Medium

public:
                    SvStream();
                    SvStream( SvLockBytes *pLockBytes);
    virtual 		~SvStream();

    ErrCode 		SetLockBytes( SvLockBytesRef& rBytes );
    SvLockBytes*	GetLockBytes() const { return xLockBytes; }

    sal_uInt32	GetError() const { return ERRCODE_TOERROR(nError); }
    sal_uInt32	GetErrorCode() const { return nError; }

    void			SetError( sal_uInt32 nErrorCode );
    virtual void	ResetError();

    void			SetNumberFormatInt( sal_uInt16 nNewFormat );
    sal_uInt16			GetNumberFormatInt() const { return nNumberFormatInt; }
                    /// Enable/disable swapping of endians, may be needed for Unicode import/export
    inline void		SetEndianSwap( sal_Bool bVal );
                    // returns status of endian swap flag
    sal_Bool			IsEndianSwap() const { return 0 != bSwap; }

    void			SetCompressMode( sal_uInt16 nNewMode )
                        { nCompressMode = nNewMode; }
    sal_uInt16			GetCompressMode() const { return nCompressMode; }

    void			SetKey( const ByteString& rKey );
    const ByteString&	GetKey() const { return aKey; }

    void			SetStreamCharSet( CharSet eCharSet )
                        { eStreamCharSet = eCharSet; }
    CharSet 		GetStreamCharSet() const { return eStreamCharSet; }
//	void			SetTargetCharSet( CharSet eCharSet )
//						{ eTargetCharSet = eCharSet; }
//	CharSet 		GetTargetCharSet() const { return eTargetCharSet; }

    void			SetLineDelimiter( LineEnd eLineEnd )
                        { eLineDelimiter = eLineEnd; }
    LineEnd 		GetLineDelimiter() const { return eLineDelimiter; }

    SvStream&		operator>>( sal_uInt16& rUInt16 );
    SvStream&		operator>>( sal_uInt32& rUInt32 );
    SvStream&		operator>>( long& rLong );
    SvStream&		operator>>( short& rShort );
    SvStream&		operator>>( int& rInt );
    SvStream&		operator>>( signed char& rChar );
    SvStream&		operator>>( char& rChar );
    SvStream&		operator>>( unsigned char& rChar );
    SvStream&		operator>>( float& rFloat );
    SvStream&		operator>>( double& rDouble );
#ifdef ENABLE_BYTESTRING_STREAM_OPERATORS
    SvStream&		operator>>( ByteString& rString ) { return ReadByteString(rString); }
#endif
#ifdef ENABLE_STRING_STREAM_OPERATORS
    SvStream&		operator>>( UniString& rString ) { return ReadByteString(rString); }
#endif
    SvStream&		operator>>( SvStream& rStream );

    SvStream&		operator<<( sal_uInt16 nUInt16 );
    SvStream&		operator<<( sal_uInt32 nUInt32 );
    SvStream&		operator<<( long nLong );
    SvStream&		operator<<( short nShort );
    SvStream&		operator<<( int nInt );
    SvStream&		operator<<( signed char nChar );
    SvStream&		operator<<( char nChar );
    SvStream&		operator<<( unsigned char nChar );
    SvStream&		operator<<( float nFloat );
    SvStream&		operator<<( const double& rDouble );
    SvStream&		operator<<( const char* pBuf );
    SvStream&		operator<<( const unsigned char* pBuf );
#ifdef ENABLE_BYTESTRING_STREAM_OPERATORS
    SvStream&		operator<<( const ByteString& rString ) { return WriteByteString( rString ); }
#endif
#ifdef ENABLE_STRING_STREAM_OPERATORS
    SvStream&		operator<<( const UniString& rString ) { return WriteByteString(rString); }
#endif
    SvStream&		operator<<( SvStream& rStream );

    SvStream&		ReadByteString( UniString& rStr, rtl_TextEncoding eSrcCharSet );
    SvStream&		ReadByteString( UniString& rStr ) { return ReadByteString( rStr, GetStreamCharSet() ); }
    SvStream&       ReadByteString( ByteString& rStr );
    SvStream&		WriteByteString( const UniString& rStr, rtl_TextEncoding eDestCharSet );
    SvStream&		WriteByteString( const UniString& rStr ) { return WriteByteString( rStr, GetStreamCharSet() ); }
    SvStream&       WriteByteString( const ByteString& rStr );

    void			SetRadix( sal_uInt8 nRad )
                        { nRadix = nRad; CreateFormatString(); }
    sal_uInt8			GetRadix() const { return nRadix; }
    void			SetPrecision( sal_uInt8 nPrec )
                        { nPrecision = nPrec; CreateFormatString(); }
    sal_uInt8			GetPrecision() const { return nPrecision; }
    void			SetWidth( sal_uInt8 nWid)
                        { nWidth = nWid; CreateFormatString(); }
    sal_uInt8			GetWidth() const { return nWidth; }
    void			SetFiller( char cFil )
                        { cFiller = cFil; CreateFormatString(); }
    char			GetFiller() const { return cFiller; }
    void			SetJustification( sal_uInt8 nJus )
                         { nJustification = nJus; CreateFormatString(); }
    sal_uInt8			GetJustification() const { return nJustification; }

    SvStream&		ReadNumber( short& rShort );
    SvStream&		ReadNumber( sal_uInt16& rUInt16 );
    SvStream&		ReadNumber( long& rLong );
    SvStream&		ReadNumber( sal_uInt32& rUInt32 );
    SvStream&		ReadNumber( int& rInt );
    SvStream&		ReadNumber( float& rFloat );
    SvStream&		ReadNumber( double& rDouble );

    SvStream&		WriteNumber( short nShort );
    SvStream&		WriteNumber( sal_uInt16 nUInt16 );
    SvStream&		WriteNumber( long nLong );
    SvStream&		WriteNumber( sal_uInt32 nUInt32 );
    SvStream&		WriteNumber( int nInt );
    SvStream&		WriteNumber( float nFloat );
    SvStream&		WriteNumber( const double& rDouble );

    sal_Size		Read( void* pData, sal_Size nSize );
    sal_Size		Write( const void* pData, sal_Size nSize );
    sal_Size		Seek( sal_Size nPos );
    sal_Size		SeekRel( sal_sSize nPos );
    sal_Size		Tell() const { return nBufFilePos+nBufActualPos;  }
    void			Flush();
    sal_Bool		IsEof() const { return bIsEof; }
    // next Tell() <= nSize
    sal_Bool		SetStreamSize( sal_Size nSize );

                /// Read in the stream to a zero character and put all
                /// read chracters in the Bytestring. The String interface
                /// convert the BytString with the given encoding to a String
    sal_Bool		ReadCString( ByteString& rStr );
    sal_Bool 		ReadCString( String& rStr, rtl_TextEncoding eToEncode );
    sal_Bool 		ReadCString( String& rStr ) { return ReadCString( rStr, GetStreamCharSet()); }

    sal_Bool		ReadLine( ByteString& rStr );
    sal_Bool		WriteLine( const ByteString& rStr );
    sal_Bool		WriteLines( const ByteString& rStr );

    sal_Bool		ReadByteStringLine( String& rStr, rtl_TextEncoding eSrcCharSet );
    sal_Bool		ReadByteStringLine( String& rStr ) { return ReadByteStringLine( rStr, GetStreamCharSet()); }
    sal_Bool		WriteByteStringLine( const String& rStr, rtl_TextEncoding eDestCharSet );
    sal_Bool		WriteByteStringLine( const String& rStr ) { return WriteByteStringLine( rStr, GetStreamCharSet()); }
    sal_Bool		WriteByteStringLines( const String& rStr, rtl_TextEncoding eDestCharSet );
    sal_Bool		WriteByteStringLines( const String& rStr ) { return WriteByteStringLine( rStr, GetStreamCharSet()); }

                /// Switch to no endian swapping and write 0xfeff
    sal_Bool		StartWritingUnicodeText();
                /// Read 16bit, if 0xfeff do nothing, if 0xfffe switch
                /// endian swapping, if none of them put back
    sal_Bool		StartReadingUnicodeText();

                /// Read a line of Unicode
    sal_Bool		ReadUniStringLine( String& rStr );
                /// Read a line of Unicode if eSrcCharSet==RTL_TEXTENCODING_UNICODE,
                /// otherwise read a line of Bytecode and convert from eSrcCharSet
    sal_Bool		ReadUniOrByteStringLine( String& rStr, rtl_TextEncoding eSrcCharSet );
    sal_Bool		ReadUniOrByteStringLine( String& rStr )
                    { return ReadUniOrByteStringLine( rStr, GetStreamCharSet() ); }
                /// Write a sequence of Unicode characters
    sal_Bool		WriteUnicodeText( const String& rStr );
                /// Write a sequence of Unicode characters if eDestCharSet==RTL_TEXTENCODING_UNICODE,
                /// otherwise write a sequence of Bytecodes converted to eDestCharSet
    sal_Bool		WriteUnicodeOrByteText( const String& rStr, rtl_TextEncoding eDestCharSet );
    sal_Bool		WriteUnicodeOrByteText( const String& rStr )
                    { return WriteUnicodeOrByteText( rStr, GetStreamCharSet() ); }
                /// Write a line of Unicode and append line end (endlu())
    sal_Bool		WriteUniStringLine( const String& rStr );
                /// Write multiple lines of Unicode (with CovertLineEnd) and append line end (endlu())
    sal_Bool		WriteUniStringLines( const String& rStr );
                /// Write a line of Unicode if eDestCharSet==RTL_TEXTENCODING_UNICODE,
                /// otherwise write a line of Bytecode converted to eDestCharSet
    sal_Bool		WriteUniOrByteStringLine( const String& rStr, rtl_TextEncoding eDestCharSet );
    sal_Bool		WriteUniOrByteStringLine( const String& rStr )
                    { return WriteUniOrByteStringLine( rStr, GetStreamCharSet() ); }
                /// Write multiple lines of Unicode if eDestCharSet==RTL_TEXTENCODING_UNICODE,
                /// otherwise write multiple lines of Bytecode converted to eDestCharSet,
                /// CovertLineEnd is applied.
    sal_Bool		WriteUniOrByteStringLines( const String& rStr, rtl_TextEncoding eDestCharSet );
    sal_Bool		WriteUniOrByteStringLines( const String& rStr )
                    { return WriteUniOrByteStringLines( rStr, GetStreamCharSet() ); }
                /// Write a Unicode character if eDestCharSet==RTL_TEXTENCODING_UNICODE,
                /// otherwise write as Bytecode converted to eDestCharSet.
                /// This may result in more than one byte being written
                /// if a multi byte encoding (e.g. UTF7, UTF8) is chosen.
    sal_Bool		WriteUniOrByteChar( sal_Unicode ch, rtl_TextEncoding eDestCharSet );
    sal_Bool		WriteUniOrByteChar( sal_Unicode ch )
                    { return WriteUniOrByteChar( ch, GetStreamCharSet() ); }

                /** Read a CSV (comma separated values) data line using
                    ReadUniOrByteStringLine().

                    @param bEmbeddedLineBreak
                    If sal_True and a line-break occurs inside a field of data,
                    a line feed LF '\n' and the next line are appended. Repeats
                    until a line-break is not in a field. A field is determined
                    by delimiting rFieldSeparators and optionally surrounded by
                    a pair of cFieldQuote characters. For a line-break to be
                    within a field, the field content MUST be surrounded by
                    cFieldQuote characters, and the opening cFieldQuote MUST be
                    at the very start of a line or follow right behind a field
                    separator with no extra characters in between. Anything,
                    including field separators and escaped quotes (by doubling
                    them, or preceding them with a backslash if
                    bAllowBackslashEscape==sal_True) may appear in a quoted
                    field.

                    If bEmbeddedLineBreak==sal_False, nothing is parsed and the
                    string returned is simply one ReadUniOrByteStringLine().

                    @param rFieldSeparators
                    A list of characters that each may act as a field separator.

                    @param cFieldQuote
                    The quote character used.

                    @param bAllowBackslashEscape
                    If sal_True, an embedded quote character inside a quoted
                    field may also be escaped with a preceding backslash.
                    Normally, quotes are escaped by doubling them.

                    @return
                    sal_True if no stream error.

                    @ATTENTION
                    Note that the string returned may be truncated even inside
                    a quoted field if STRING_MAXLEN was reached. There
                    currently is no way to exactly determine the conditions,
                    whether this was at a line end, or whether open quotes
                    would have closed the field before the line end, as even a
                    ReadUniOrByteStringLine() may return prematurely but the
                    stream was positioned ahead until the real end of line.
                    Additionally, due to character encoding conversions, string
                    length and bytes read don't necessarily match, and
                    resyncing to a previous position matching the string's
                    length isn't always possible. As a result, a logical line
                    with embedded line breaks and more than STRING_MAXLEN
                    characters will be spoiled, and a subsequent ReadCsvLine()
                    may start under false preconditions.
                  */
    sal_Bool        ReadCsvLine( String& rStr, sal_Bool bEmbeddedLineBreak,
                        const String& rFieldSeparators, sal_Unicode cFieldQuote,
                        sal_Bool bAllowBackslashEscape = sal_False);

    void			SetBufferSize( sal_uInt16 nBufSize );
    sal_uInt16	GetBufferSize() const { return nBufSize; }

    void			RefreshBuffer();
    SvStream&		PutBack( char aCh );
    void			EatWhite();

    sal_Bool			IsWritable() const { return bIsWritable; }
    StreamMode		GetStreamMode() const { return eStreamMode; }
    virtual sal_uInt16	IsA() const;

    long			GetVersion() { return nVersion; }
    void			SetVersion( long n ) { nVersion = n; }

    /** Add a mark to indicate to which position in the stream you want to be
        able to seek back.

        @descr	If you set a mark at nPos, you indicate to the stream that you
        won't issue seek operations to any position 'before' nPos.  This can
        be exploited by 'transient streams' that do not permanently store
        their data; they can discard any buffered data up to nPos.

        @descr	However, if the stream is already positioned past nPos, this
        method is not guaranteed to have the desired effect.  A 'transient
        stream' may have already discarded the buffered data at nPos, so that
        a seek operation to nPos will fail nonetheless.

        @descr	There can be more than one mark for a stream, indicating that
        you want to be able to seek back in the stream as far as the 'lowest'
        off all the marks.	There can even be multiple marks at the same
        position (and they must all be individually removed with
        RemoveMark()).

        @param nPos  The position in the stream at which to add a mark.
     */
    virtual void	AddMark(sal_Size nPos);

    /** Remove a mark introduced with AddMark().

        @descr	If you no longer need to seek back to some position for which
        you added a mark, you should remove that mark.	(And a 'transient
        stream' that does not permanently store its data can then potentially
        discard some of its buffered data.)

        @descr	Removing one mark does not have any effects on any other
        marks.	Especially, if you have multiple marks at the same position,
        you must call this method multiple times to effectively 'unmark' that
        position.

        @descr	If you specify a position for which there is no mark, this
        method simply has no effect.

        @param nPos  The position in the stream at which to remove the mark.
     */
    virtual void	RemoveMark(sal_Size nPos);

    friend SvStream& operator<<( SvStream& rStr, SvStrPtr f ); // fuer Manips
};

inline SvStream& operator<<( SvStream& rStr, SvStrPtr f )
{
    (*f)(rStr);
    return rStr;
}

inline SvStream& SvStream::ReadNumber( short& rShort )
{
    long nTmp;
    ReadNumber( nTmp );
    rShort = (short)nTmp;
    return *this;
}

inline SvStream& SvStream::ReadNumber( sal_uInt16& rUShort )
{
    sal_uInt32 nTmp;
    ReadNumber( nTmp );
    rUShort = (sal_uInt16)nTmp;
    return *this;
}

inline SvStream& SvStream::ReadNumber( int& rInt )
{
    long nTmp;
    ReadNumber( nTmp );
    rInt = (int)nTmp;
    return *this;
}

/*
inline SvStream& SvStream::ReadNumber( unsigned int& rUInt )
{
    ULONG nTmp;
    ReadNumber( nTmp );
    rUInt = (unsigned int)nTmp;
    return *this;
}
*/

inline SvStream& SvStream::ReadNumber( float& rFloat )
{
    double nTmp;
    ReadNumber( nTmp );
    rFloat = (float)nTmp;
    return *this;
}

inline SvStream& SvStream::WriteNumber( short nShort )
{
    WriteNumber( (long)nShort );
    return *this;
}

inline SvStream& SvStream::WriteNumber( sal_uInt16 nUShort )
{
    WriteNumber( (sal_uInt32)nUShort );
    return *this;
}

inline SvStream& SvStream::WriteNumber( int nInt )
{
    WriteNumber( (long)nInt );
    return *this;
}

/*
inline SvStream& SvStream::WriteNumber( unsigned int nUInt )
{
    WriteNumber( (ULONG)nUInt );
    return *this;
}
*/

inline SvStream& SvStream::WriteNumber( float nFloat )
{
    double nTemp = nFloat;
    WriteNumber( nTemp );
    return *this;
}

inline void SvStream::SetEndianSwap( sal_Bool bVal )
{
#ifdef OSL_BIGENDIAN
    SetNumberFormatInt( bVal ? NUMBERFORMAT_INT_LITTLEENDIAN : NUMBERFORMAT_INT_BIGENDIAN );
#else
    SetNumberFormatInt( bVal ? NUMBERFORMAT_INT_BIGENDIAN : NUMBERFORMAT_INT_LITTLEENDIAN );
#endif
}

TOOLS_DLLPUBLIC SvStream& endl( SvStream& rStr );
/// same as endl() but Unicode
TOOLS_DLLPUBLIC SvStream& endlu( SvStream& rStr );
/// call endlu() if eStreamCharSet==RTL_TEXTECODING_UNICODE otherwise endl()
TOOLS_DLLPUBLIC SvStream& endlub( SvStream& rStr );

// --------------
// - FileStream -
// --------------

class TOOLS_DLLPUBLIC SvFileStream : public SvStream
{
    friend class ImpEaMgr;
    friend class CORmFileStream;
    friend class FileCopier;

private:
    StreamData* 		pInstanceData;
    String			aFilename;
    sal_uInt16		nLockCounter;
    sal_Bool			bIsOpen;
    sal_uInt32		GetFileHandle() const;

    // Forbidden and not implemented.
    SvFileStream (const SvFileStream&);
    SvFileStream & operator= (const SvFileStream&);

protected:

    virtual sal_Size	GetData( void* pData, sal_Size nSize );
    virtual sal_Size	PutData( const void* pData, sal_Size nSize );
    virtual sal_Size	SeekPos( sal_Size nPos );
    virtual void	SetSize( sal_Size nSize );
    virtual void	FlushData();

public:
                    // Schaltet bei fehlgeschlagenem Schreiboeffnen auf Lesen zurueck
                    SvFileStream( const String& rFileName, StreamMode eOpenMode );
                    SvFileStream();
                    ~SvFileStream();

    virtual void	ResetError();

    sal_Bool			LockRange( sal_Size nByteOffset, sal_Size nBytes );
    sal_Bool			UnlockRange( sal_Size nByteOffset, sal_Size nBytes );
    sal_Bool			LockFile();
    sal_Bool			UnlockFile();

    void			Open( const String& rFileName, StreamMode eOpenMode );
    void			Close();
    void			ReOpen(); // Aufruf nach Close, FilePointer == 0
    sal_Bool			IsOpen() const { return bIsOpen; }
    sal_Bool			IsLocked() const { return ( nLockCounter!=0 ); }
    virtual sal_uInt16	IsA() const;

    const String&	GetFileName() const { return aFilename; }
};

// ----------------
// - MemoryStream -
// ----------------

class TOOLS_DLLPUBLIC SvMemoryStream : public SvStream
{
    // Forbidden and not implemented.
    SvMemoryStream (const SvMemoryStream&);
    SvMemoryStream & operator= (const SvMemoryStream&);

    friend class SvCacheStream;
    sal_Size            GetSize() const { return nSize; }

protected:
    sal_Size			nSize;
    sal_Size			nResize;
    sal_Size			nPos;
    sal_Size			nEndOfData;
    sal_uInt8*			pBuf;
    sal_Bool			bOwnsData;

    virtual sal_Size	GetData( void* pData, sal_Size nSize );
    virtual sal_Size	PutData( const void* pData, sal_Size nSize );
    virtual sal_Size	SeekPos( sal_Size nPos );
    virtual void	SetSize( sal_Size nSize );
    virtual void	FlushData();

    // AllocateMemory muss folgende Variable mitpflegen:
    // - pBuf: Adresse des neuen Blocks
    virtual sal_Bool	AllocateMemory( sal_Size nSize );

    // ReAllocateMemory muss folgende Variablen mitpflegen:
    // - pBuf: Adresse des neuen Blocks
    // - nEndOfData: Muss auf nNewSize-1L gesetzt werden, wenn ausserhalb des Blocks
    //				 Muss auf 0 gesetzt werden, wenn neuer Block 0 Byte gross
    // - nSize: Neue Groesse des Blocks
    // - nPos: Muss auf 0 gesetzt werden, wenn ausserhalb des Blocks
    virtual sal_Bool	ReAllocateMemory( long nDiff );

    // wird aufgerufen, wenn dem Stream der Speicher gehoert oder wenn
    // der Speicher in der Groesse veraendert wird.
    // FreeMemory muss folgende Variablen mitpflegen:
    // - in abgeleiteten Klassen muessen ggf. Handles genullt werden
    virtual void	FreeMemory();

                    SvMemoryStream(void*) { }	// Fuer unsere Subklassen

public:
                    SvMemoryStream( void* pBuf, sal_Size nSize, StreamMode eMode);
                    SvMemoryStream( sal_Size nInitSize=512, sal_Size nResize=64 );
                    ~SvMemoryStream();

    virtual void	ResetError();

    sal_Size        GetEndOfData() const { return nEndOfData; }
    const void* 	GetData() { Flush(); return pBuf; }
    operator const	void*() { Flush(); return pBuf; }
    virtual sal_uInt16	IsA() const;

    void*			SwitchBuffer( sal_Size nInitSize=512, sal_Size nResize=64 );
    void*			SetBuffer( void* pBuf, sal_Size nSize,
                               sal_Bool bOwnsData=TRUE, sal_Size nEOF=0 );

    void			ObjectOwnsMemory( sal_Bool bOwn ) { bOwnsData = bOwn; }
    sal_Bool			IsObjectMemoryOwner() { return bOwnsData; }
    void			SetResizeOffset( sal_Size nNewResize ) { nResize = nNewResize; }
    sal_Size			GetResizeOffset() const { return nResize; }
};

// --------------------
// - SvDataCopyStream -
// --------------------

// AB 10.5.1996: Diese Klasse bildet die Basis fuer Klassen, die mittels
// SvData (SO2\DTRANS.HXX/CXX) transportiert werden sollen, z.B. Graphik
// Die abgeleiteten Klassen muessen die virtuellen Funktionen ueberladen.

class TOOLS_DLLPUBLIC SvDataCopyStream
{
public:
    /*-----------------MM 30.04.96 11:01-----------------
     mehrfaches Aufrufen von Load und Assign erlaubt
    --------------------------------------------------*/
                    TYPEINFO();
    virtual 		~SvDataCopyStream(){}
    virtual void	Load( SvStream & ) = 0;
    virtual void	Save( SvStream & ) = 0;
    virtual void	Assign( const SvDataCopyStream & );
};

#endif // _STREAM_HXX

/* vim:set shiftwidth=4 softtabstop=4 expandtab: */