LCOV - code coverage report
Current view: top level - lotuswordpro/source/filter - lwpobjhdr.cxx (source / functions) Hit Total Coverage
Test: commit 10e77ab3ff6f4314137acd6e2702a6e5c1ce1fae Lines: 56 75 74.7 %
Date: 2014-11-03 Functions: 2 2 100.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             :  *
       4             :  *  The Contents of this file are made available subject to the terms of
       5             :  *  either of the following licenses
       6             :  *
       7             :  *         - GNU Lesser General Public License Version 2.1
       8             :  *         - Sun Industry Standards Source License Version 1.1
       9             :  *
      10             :  *  Sun Microsystems Inc., October, 2000
      11             :  *
      12             :  *  GNU Lesser General Public License Version 2.1
      13             :  *  =============================================
      14             :  *  Copyright 2000 by Sun Microsystems, Inc.
      15             :  *  901 San Antonio Road, Palo Alto, CA 94303, USA
      16             :  *
      17             :  *  This library is free software; you can redistribute it and/or
      18             :  *  modify it under the terms of the GNU Lesser General Public
      19             :  *  License version 2.1, as published by the Free Software Foundation.
      20             :  *
      21             :  *  This library is distributed in the hope that it will be useful,
      22             :  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
      23             :  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
      24             :  *  Lesser General Public License for more details.
      25             :  *
      26             :  *  You should have received a copy of the GNU Lesser General Public
      27             :  *  License along with this library; if not, write to the Free Software
      28             :  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston,
      29             :  *  MA  02111-1307  USA
      30             :  *
      31             :  *
      32             :  *  Sun Industry Standards Source License Version 1.1
      33             :  *  =================================================
      34             :  *  The contents of this file are subject to the Sun Industry Standards
      35             :  *  Source License Version 1.1 (the "License"); You may not use this file
      36             :  *  except in compliance with the License. You may obtain a copy of the
      37             :  *  License at http://www.openoffice.org/license.html.
      38             :  *
      39             :  *  Software provided under this License is provided on an "AS IS" basis,
      40             :  *  WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
      41             :  *  WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
      42             :  *  MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
      43             :  *  See the License for the specific provisions governing your rights and
      44             :  *  obligations concerning the Software.
      45             :  *
      46             :  *  The Initial Developer of the Original Code is: IBM Corporation
      47             :  *
      48             :  *  Copyright: 2008 by IBM Corporation
      49             :  *
      50             :  *  All Rights Reserved.
      51             :  *
      52             :  *  Contributor(s): _______________________________________
      53             :  *
      54             :  *
      55             :  ************************************************************************/
      56             : /*************************************************************************
      57             :  * @file
      58             :  *  For LWP filter architecture prototype
      59             :  ************************************************************************/
      60             : /*************************************************************************
      61             :  * Change History
      62             :  Jan 2005           Created
      63             :  ************************************************************************/
      64             : 
      65             : #include "lwpobjhdr.hxx"
      66             : #include "lwpdefs.hxx"
      67             : #include "lwpfilehdr.hxx"
      68             : 
      69        1876 : LwpObjectHeader::LwpObjectHeader()
      70        1876 :     : m_nTag(0), m_ID(), m_nSize(0), m_bCompressed(false)
      71             :     // m_nHeaderSize(0), m_nVersionID(0), m_nRefCount(0), m_nFlagBits(0),
      72             :     //m_nNextVersionOffset(0), m_nNextVersionID(0),
      73        1876 : {}
      74             : /**
      75             :  * @descr  read header from stream
      76             :   */
      77        1876 : bool LwpObjectHeader::Read(LwpSvStream &rStrm)
      78             : {
      79        1876 :     sal_uInt32 nVersionID = 0;
      80        1876 :     sal_uInt32 nRefCount = 0;
      81        1876 :     sal_uInt32 nNextVersionOffset = 0;
      82        1876 :     sal_uInt32 nHeaderSize = 0;
      83             : 
      84        1876 :     sal_Int64 nStartPos = rStrm.Tell();
      85             : 
      86        1876 :     if ( LwpFileHeader::m_nFileRevision < 0x000B)
      87             :     {
      88          12 :         rStrm >> m_nTag;
      89          12 :         m_ID.Read(&rStrm);
      90          12 :         rStrm >> nVersionID;
      91          12 :         rStrm >> nRefCount;
      92          12 :         rStrm >> nNextVersionOffset;
      93             : 
      94          12 :         nHeaderSize = sizeof(m_nTag) + m_ID.DiskSize()
      95             :             + sizeof(nVersionID)
      96             :             + sizeof(nRefCount)
      97             :             + sizeof(nNextVersionOffset)
      98          24 :             + sizeof(m_nSize);
      99             : 
     100          12 :         if ((m_nTag == TAG_AMI) || ( LwpFileHeader::m_nFileRevision < 0x0006))
     101             :         {
     102          12 :             sal_uInt32 nNextVersionID = 0;
     103          12 :             rStrm >> nNextVersionID;
     104          12 :             nHeaderSize += sizeof(nNextVersionID);
     105             :         }
     106          12 :         rStrm >> m_nSize;
     107             :     }
     108             :     else
     109             :     {
     110        1864 :         sal_uInt8 nFlagBits = 0;
     111        1864 :         sal_uInt16 VOType = 0;
     112        1864 :         rStrm >> VOType;
     113        1864 :         rStrm >> nFlagBits;
     114             : 
     115        1864 :         m_nTag = static_cast<sal_uInt32>(VOType);
     116        1864 :         m_ID.ReadIndexed(&rStrm);
     117        1864 :         nHeaderSize = sizeof(VOType) + sizeof(nFlagBits) + m_ID.DiskSizeIndexed();
     118             : 
     119             :         sal_uInt8 tmpByte;
     120             :         sal_uInt16 tmpShort;
     121        1864 :         switch (nFlagBits & VERSION_BITS)
     122             :         {
     123             :             case ONE_BYTE_VERSION:
     124          36 :                 rStrm >> tmpByte;
     125          36 :                 nVersionID = static_cast<sal_uInt32>( tmpByte );
     126          36 :                 nHeaderSize++;
     127          36 :                 break;
     128             : 
     129             :             case TWO_BYTE_VERSION:
     130           0 :                 rStrm >> tmpShort;
     131           0 :                 nVersionID = static_cast<sal_uInt32>( tmpShort );
     132           0 :                 nHeaderSize += 2;
     133           0 :                 break;
     134             : 
     135             :             case FOUR_BYTE_VERSION:
     136           0 :                 rStrm >> nVersionID;
     137           0 :                 nHeaderSize += 4;
     138           0 :                 break;
     139             :             case DEFAULT_VERSION:   //fall through
     140             :             default:
     141        1828 :                 nVersionID = 2;
     142        1828 :                 break;      // nothing
     143             :         }
     144             : 
     145        1864 :         switch (nFlagBits & REFCOUNT_BITS)
     146             :         {
     147             :             case ONE_BYTE_REFCOUNT:
     148        1864 :                 rStrm >> tmpByte;
     149        1864 :                 nRefCount = static_cast<sal_uInt32>( tmpByte );
     150        1864 :                 nHeaderSize++;
     151        1864 :                 break;
     152             : 
     153             :             case TWO_BYTE_REFCOUNT:
     154           0 :                 rStrm >> tmpShort;
     155           0 :                 nRefCount = static_cast<sal_uInt32>( tmpShort );
     156           0 :                 nHeaderSize += 2;
     157           0 :                 break;
     158             : 
     159             :             case FOUR_BYTE_REFCOUNT:    //through
     160             :             default:
     161           0 :                 rStrm >> nRefCount;
     162           0 :                 nHeaderSize += 4;
     163           0 :                 break;
     164             :         }
     165             : 
     166        1864 :         if (nFlagBits & HAS_PREVOFFSET)
     167             :         {
     168           0 :             rStrm >> nNextVersionOffset;
     169           0 :             nHeaderSize += 4;
     170             :         }
     171             :         else
     172        1864 :             nNextVersionOffset = BAD_OFFSET;
     173             : 
     174        1864 :         switch (nFlagBits & SIZE_BITS)
     175             :         {
     176             :             case ONE_BYTE_SIZE:
     177        1742 :                 rStrm >> tmpByte;
     178        1742 :                 m_nSize = static_cast<sal_uInt32>( tmpByte );
     179        1742 :                 nHeaderSize++;
     180        1742 :                 break;
     181             : 
     182             :             case TWO_BYTE_SIZE:
     183         122 :                 rStrm >> tmpShort;
     184         122 :                 m_nSize = static_cast<sal_uInt32>(tmpShort);
     185         122 :                 nHeaderSize += 2;
     186         122 :                 break;
     187             : 
     188             :             case FOUR_BYTE_SIZE:    //go through
     189             :             default:
     190           0 :                 rStrm >> m_nSize;
     191           0 :                 nHeaderSize += 4;
     192           0 :                 break;
     193             :         }
     194             : 
     195        1864 :         if (nFlagBits & DATA_COMPRESSED)
     196             :         {
     197        1850 :             m_bCompressed = true;
     198             :         }
     199             :     }
     200        1876 :     sal_Int64 nEndPos = rStrm.Tell();
     201        1876 :     return (nStartPos + nHeaderSize == nEndPos);
     202             : }
     203             : 
     204             : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */

Generated by: LCOV version 1.10