Branch data 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: */
|