Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*
3 : * This file is part of the LibreOffice project.
4 : *
5 : * This Source Code Form is subject to the terms of the Mozilla Public
6 : * License, v. 2.0. If a copy of the MPL was not distributed with this
7 : * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 : *
9 : * This file incorporates work covered by the following license notice:
10 : *
11 : * Licensed to the Apache Software Foundation (ASF) under one or more
12 : * contributor license agreements. See the NOTICE file distributed
13 : * with this work for additional information regarding copyright
14 : * ownership. The ASF licenses this file to you under the Apache
15 : * License, Version 2.0 (the "License"); you may not use this file
16 : * except in compliance with the License. You may obtain a copy of
17 : * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18 : */
19 :
20 : #include <tools/debug.hxx>
21 :
22 : #include "numhead.hxx"
23 :
24 : // ID's fuer Dateien:
25 : #define SV_NUMID_SIZES 0x4200
26 :
27 : // STATIC DATA -----------------------------------------------------------
28 :
29 : //SEG_EOFGLOBALS()
30 :
31 : // =======================================================================
32 : /* wird fuer SvNumberformatter nicht gebraucht
33 : //#pragma SEG_FUNCDEF(numhead_01)
34 :
35 : SvNumReadHeader::SvNumReadHeader(SvStream& rNewStream) :
36 : rStream( rNewStream )
37 : {
38 : sal_uLong nDataSize;
39 : rStream >> nDataSize;
40 : nDataEnd = rStream.Tell() + nDataSize;
41 : }
42 :
43 : //#pragma SEG_FUNCDEF(numhead_02)
44 :
45 : SvNumReadHeader::~SvNumReadHeader()
46 : {
47 : sal_uLong nReadEnd = rStream.Tell();
48 : DBG_ASSERT( nReadEnd <= nDataEnd, "zuviele Bytes gelesen" );
49 : if ( nReadEnd != nDataEnd )
50 : rStream.Seek(nDataEnd); // Rest ueberspringen
51 : }
52 :
53 : //#pragma SEG_FUNCDEF(numhead_03)
54 :
55 : sal_uLong SvNumReadHeader::BytesLeft() const
56 : {
57 : sal_uLong nReadEnd = rStream.Tell();
58 : if (nReadEnd <= nDataEnd)
59 : return nDataEnd-nReadEnd;
60 :
61 : OSL_FAIL("Fehler bei SvNumReadHeader::BytesLeft");
62 : return 0;
63 : }
64 :
65 : // -----------------------------------------------------------------------
66 :
67 : //#pragma SEG_FUNCDEF(numhead_04)
68 :
69 : SvNumWriteHeader::SvNumWriteHeader(SvStream& rNewStream, sal_uLong nDefault) :
70 : rStream( rNewStream )
71 : {
72 : nDataSize = nDefault;
73 : rStream << nDataSize;
74 : nDataPos = rStream.Tell();
75 : }
76 :
77 : //#pragma SEG_FUNCDEF(numhead_05)
78 :
79 : SvNumWriteHeader::~SvNumWriteHeader()
80 : {
81 : sal_uLong nPos = rStream.Tell();
82 :
83 : if ( nPos - nDataPos != nDataSize ) // Default getroffen?
84 : {
85 : nDataSize = nPos - nDataPos;
86 : rStream.Seek(nDataPos - sizeof(sal_uInt32));
87 : rStream << nDataSize; // Groesse am Anfang eintragen
88 : rStream.Seek(nPos);
89 : }
90 : }
91 : */
92 :
93 : // =======================================================================
94 :
95 : //#pragma SEG_FUNCDEF(numhead_06)
96 :
97 : //! mit Skip() synchron
98 0 : ImpSvNumMultipleReadHeader::ImpSvNumMultipleReadHeader(SvStream& rNewStream) :
99 0 : rStream( rNewStream )
100 : {
101 : sal_uInt32 nDataSize;
102 0 : rStream >> nDataSize;
103 0 : sal_uLong nDataPos = rStream.Tell();
104 0 : nEntryEnd = nDataPos;
105 :
106 0 : rStream.SeekRel(nDataSize);
107 : sal_uInt16 nID;
108 0 : rStream >> nID;
109 0 : if (nID != SV_NUMID_SIZES)
110 : {
111 : OSL_FAIL("SV_NUMID_SIZES nicht gefunden");
112 : }
113 : sal_uInt32 nSizeTableLen;
114 0 : rStream >> nSizeTableLen;
115 0 : pBuf = new char[nSizeTableLen];
116 0 : rStream.Read( pBuf, nSizeTableLen );
117 0 : pMemStream = new SvMemoryStream( pBuf, nSizeTableLen, STREAM_READ );
118 :
119 0 : nEndPos = rStream.Tell();
120 0 : rStream.Seek( nDataPos );
121 0 : }
122 :
123 : //#pragma SEG_FUNCDEF(numhead_07)
124 :
125 0 : ImpSvNumMultipleReadHeader::~ImpSvNumMultipleReadHeader()
126 : {
127 : DBG_ASSERT( pMemStream->Tell() == pMemStream->GetEndOfData(),
128 : "Sizes nicht vollstaendig gelesen" );
129 0 : delete pMemStream;
130 0 : delete [] pBuf;
131 :
132 0 : rStream.Seek(nEndPos);
133 0 : }
134 :
135 : //#pragma SEG_FUNCDEF(numhead_08)
136 :
137 0 : void ImpSvNumMultipleReadHeader::EndEntry()
138 : {
139 0 : sal_uLong nPos = rStream.Tell();
140 : DBG_ASSERT( nPos <= nEntryEnd, "zuviel gelesen" );
141 0 : if ( nPos != nEntryEnd )
142 0 : rStream.Seek( nEntryEnd ); // Rest ueberspringen
143 0 : }
144 :
145 : //#pragma SEG_FUNCDEF(numhead_0d)
146 :
147 0 : void ImpSvNumMultipleReadHeader::StartEntry()
148 : {
149 0 : sal_uLong nPos = rStream.Tell();
150 : sal_uInt32 nEntrySize;
151 0 : (*pMemStream) >> nEntrySize;
152 :
153 0 : nEntryEnd = nPos + nEntrySize;
154 0 : }
155 :
156 : //#pragma SEG_FUNCDEF(numhead_09)
157 :
158 0 : sal_uLong ImpSvNumMultipleReadHeader::BytesLeft() const
159 : {
160 0 : sal_uLong nReadEnd = rStream.Tell();
161 0 : if (nReadEnd <= nEntryEnd)
162 0 : return nEntryEnd-nReadEnd;
163 :
164 : OSL_FAIL("Fehler bei ImpSvNumMultipleReadHeader::BytesLeft");
165 0 : return 0;
166 : }
167 :
168 : // -----------------------------------------------------------------------
169 :
170 : //#pragma SEG_FUNCDEF(numhead_0a)
171 :
172 0 : ImpSvNumMultipleWriteHeader::ImpSvNumMultipleWriteHeader(SvStream& rNewStream,
173 : sal_uLong nDefault) :
174 : rStream( rNewStream ),
175 0 : aMemStream( 4096, 4096 )
176 : {
177 0 : nDataSize = nDefault;
178 0 : rStream << nDataSize;
179 :
180 0 : nDataPos = rStream.Tell();
181 0 : nEntryStart = nDataPos;
182 0 : }
183 :
184 : //#pragma SEG_FUNCDEF(numhead_0b)
185 :
186 0 : ImpSvNumMultipleWriteHeader::~ImpSvNumMultipleWriteHeader()
187 : {
188 0 : sal_uLong nDataEnd = rStream.Tell();
189 :
190 0 : rStream << (sal_uInt16) SV_NUMID_SIZES;
191 0 : rStream << static_cast<sal_uInt32>(aMemStream.Tell());
192 0 : rStream.Write( aMemStream.GetData(), aMemStream.Tell() );
193 :
194 0 : if ( nDataEnd - nDataPos != nDataSize ) // Default getroffen?
195 : {
196 0 : nDataSize = nDataEnd - nDataPos;
197 0 : sal_uLong nPos = rStream.Tell();
198 0 : rStream.Seek(nDataPos-sizeof(sal_uInt32));
199 0 : rStream << nDataSize; // Groesse am Anfang eintragen
200 0 : rStream.Seek(nPos);
201 : }
202 0 : }
203 :
204 : //#pragma SEG_FUNCDEF(numhead_0c)
205 :
206 0 : void ImpSvNumMultipleWriteHeader::EndEntry()
207 : {
208 0 : sal_uLong nPos = rStream.Tell();
209 0 : aMemStream << static_cast<sal_uInt32>(nPos - nEntryStart);
210 0 : }
211 :
212 : //#pragma SEG_FUNCDEF(numhead_0e)
213 :
214 0 : void ImpSvNumMultipleWriteHeader::StartEntry()
215 : {
216 0 : sal_uLong nPos = rStream.Tell();
217 0 : nEntryStart = nPos;
218 0 : }
219 :
220 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|