LCOV - code coverage report
Current view: top level - libreoffice/svl/source/numbers - numhead.cxx (source / functions) Hit Total Coverage
Test: libreoffice_filtered.info Lines: 0 62 0.0 %
Date: 2012-12-27 Functions: 0 9 0.0 %
Legend: Lines: hit not hit

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

Generated by: LCOV version 1.10