diff options
-rw-r--r-- | sc/Library_scfilt.mk | 3 | ||||
-rw-r--r-- | sc/source/filter/starcalc/collect.cxx | 131 | ||||
-rw-r--r-- | sc/source/filter/starcalc/collect.hxx | 58 | ||||
-rw-r--r-- | sc/source/filter/starcalc/scflt.cxx | 2403 | ||||
-rw-r--r-- | sc/source/filter/starcalc/scflt.hxx | 791 | ||||
-rw-r--r-- | sc/source/filter/starcalc/scfobj.cxx | 86 |
6 files changed, 0 insertions, 3472 deletions
diff --git a/sc/Library_scfilt.mk b/sc/Library_scfilt.mk index 6a02ec91db63..e4b6fe154e89 100644 --- a/sc/Library_scfilt.mk +++ b/sc/Library_scfilt.mk @@ -152,9 +152,6 @@ $(eval $(call gb_Library_add_exception_objects,scfilt,\ sc/source/filter/rtf/rtfexp \ sc/source/filter/rtf/rtfimp \ sc/source/filter/rtf/rtfparse \ - sc/source/filter/starcalc/collect \ - sc/source/filter/starcalc/scflt \ - sc/source/filter/starcalc/scfobj \ sc/source/filter/xcl97/XclExpChangeTrack \ sc/source/filter/xcl97/XclImpChangeTrack \ sc/source/filter/xcl97/xcl97esc \ diff --git a/sc/source/filter/starcalc/collect.cxx b/sc/source/filter/starcalc/collect.cxx deleted file mode 100644 index 3ed51bfba774..000000000000 --- a/sc/source/filter/starcalc/collect.cxx +++ /dev/null @@ -1,131 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/* - * This file is part of the LibreOffice project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - * - * This file incorporates work covered by the following license notice: - * - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed - * with this work for additional information regarding copyright - * ownership. The ASF licenses this file to you under the Apache - * License, Version 2.0 (the "License"); you may not use this file - * except in compliance with the License. You may obtain a copy of - * the License at http://www.apache.org/licenses/LICENSE-2.0 . - */ - -#include "collect.hxx" - -#include <string.h> - -#define MAXCOLLECTIONSIZE 16384 -#define MAXDELTA 1024 - -ScDataObject::~ScDataObject() -{ -} - -// Collection - -static void lcl_DeleteScDataObjects( ScDataObject** p, sal_uInt16 nCount ) -{ - if ( p ) - { - for (sal_uInt16 i = 0; i < nCount; i++) delete p[i]; - delete[] p; - } -} - -ScCollection::ScCollection(sal_uInt16 nLim, sal_uInt16 nDel) : - nCount ( 0 ), - nLimit ( nLim ), - nDelta ( nDel ), - pItems ( nullptr ) -{ - if (nDelta > MAXDELTA) - nDelta = MAXDELTA; - else if (nDelta == 0) - nDelta = 1; - if (nLimit > MAXCOLLECTIONSIZE) - nLimit = MAXCOLLECTIONSIZE; - else if (nLimit < nDelta) - nLimit = nDelta; - pItems = new ScDataObject*[nLimit]; -} - -ScCollection::ScCollection(const ScCollection& rCollection) - : ScDataObject(), - nCount ( 0 ), - nLimit ( 0 ), - nDelta ( 0 ), - pItems ( nullptr ) -{ - *this = rCollection; -} - -ScCollection::~ScCollection() -{ - lcl_DeleteScDataObjects( pItems, nCount ); -} - -bool ScCollection::AtInsert(sal_uInt16 nIndex, ScDataObject* pScDataObject) -{ - if ((nCount < MAXCOLLECTIONSIZE) && (nIndex <= nCount) && pItems) - { - if (nCount == nLimit) - { - ScDataObject** pNewItems = new ScDataObject*[nLimit + nDelta]; - nLimit = sal::static_int_cast<sal_uInt16>( nLimit + nDelta ); - memcpy(pNewItems, pItems, nCount * sizeof(ScDataObject*)); - delete[] pItems; - pItems = pNewItems; - } - if (nCount > nIndex) - memmove(&pItems[nIndex + 1], &pItems[nIndex], (nCount - nIndex) * sizeof(ScDataObject*)); - pItems[nIndex] = pScDataObject; - nCount++; - return true; - } - return false; -} - -bool ScCollection::Insert(ScDataObject* pScDataObject) -{ - return AtInsert(nCount, pScDataObject); -} - -ScDataObject* ScCollection::At(sal_uInt16 nIndex) const -{ - if (nIndex < nCount) - return pItems[nIndex]; - else - return nullptr; -} - -ScCollection& ScCollection::operator=( const ScCollection& r ) -{ - // Check for self-assignment - if (this == &r) - return *this; - - lcl_DeleteScDataObjects( pItems, nCount ); - - nCount = r.nCount; - nLimit = r.nLimit; - nDelta = r.nDelta; - pItems = new ScDataObject*[nLimit]; - for ( sal_uInt16 i=0; i<nCount; i++ ) - pItems[i] = r.pItems[i]->Clone(); - - return *this; -} - -ScDataObject* ScCollection::Clone() const -{ - return new ScCollection(*this); -} - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sc/source/filter/starcalc/collect.hxx b/sc/source/filter/starcalc/collect.hxx deleted file mode 100644 index 92457bbd8ad3..000000000000 --- a/sc/source/filter/starcalc/collect.hxx +++ /dev/null @@ -1,58 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/* - * This file is part of the LibreOffice project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - * - * This file incorporates work covered by the following license notice: - * - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed - * with this work for additional information regarding copyright - * ownership. The ASF licenses this file to you under the Apache - * License, Version 2.0 (the "License"); you may not use this file - * except in compliance with the License. You may obtain a copy of - * the License at http://www.apache.org/licenses/LICENSE-2.0 . - */ - -#ifndef INCLUDED_SC_SOURCE_FILTER_STARCALC_COLLECT_HXX -#define INCLUDED_SC_SOURCE_FILTER_STARCALC_COLLECT_HXX - -#include <sal/types.h> - -class ScDataObject -{ -public: - ScDataObject() {} - virtual ~ScDataObject(); - virtual ScDataObject* Clone() const = 0; -}; - -class ScCollection : public ScDataObject -{ -protected: - sal_uInt16 nCount; - sal_uInt16 nLimit; - sal_uInt16 nDelta; - ScDataObject** pItems; -public: - ScCollection(sal_uInt16 nLim, sal_uInt16 nDel); - ScCollection(const ScCollection& rCollection); - virtual ~ScCollection() override; - - virtual ScDataObject* Clone() const override; - - bool AtInsert(sal_uInt16 nIndex, ScDataObject* pScDataObject); - bool Insert(ScDataObject* pScDataObject); - - ScDataObject* At(sal_uInt16 nIndex) const; - sal_uInt16 GetCount() const { return nCount; } - - ScCollection& operator= ( const ScCollection& rCol ); -}; - -#endif - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sc/source/filter/starcalc/scflt.cxx b/sc/source/filter/starcalc/scflt.cxx deleted file mode 100644 index d15bf25b90cb..000000000000 --- a/sc/source/filter/starcalc/scflt.cxx +++ /dev/null @@ -1,2403 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/* - * This file is part of the LibreOffice project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - * - * This file incorporates work covered by the following license notice: - * - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed - * with this work for additional information regarding copyright - * ownership. The ASF licenses this file to you under the Apache - * License, Version 2.0 (the "License"); you may not use this file - * except in compliance with the License. You may obtain a copy of - * the License at http://www.apache.org/licenses/LICENSE-2.0 . - */ - -#include <scitems.hxx> -#include <editeng/eeitem.hxx> - -#include <com/sun/star/style/NumberingType.hpp> -#include <formula/errorcodes.hxx> -#include <svx/algitem.hxx> -#include <editeng/boxitem.hxx> -#include <editeng/brushitem.hxx> -#include <editeng/colritem.hxx> -#include <editeng/crossedoutitem.hxx> -#include <editeng/editdata.hxx> -#include <editeng/editeng.hxx> -#include <editeng/editobj.hxx> -#include <editeng/fhgtitem.hxx> -#include <editeng/fontitem.hxx> -#include <editeng/lrspitem.hxx> -#include <svx/pageitem.hxx> -#include <editeng/postitem.hxx> -#include <editeng/sizeitem.hxx> -#include <editeng/udlnitem.hxx> -#include <editeng/ulspitem.hxx> -#include <editeng/wghtitem.hxx> -#include <editeng/justifyitem.hxx> -#include <svl/zforlist.hxx> -#include <svl/PasswordHelper.hxx> -#include <cassert> -#include <math.h> -#include <string.h> - -#include <global.hxx> -#include <sc.hrc> -#include <attrib.hxx> -#include <patattr.hxx> -#include <docpool.hxx> -#include <document.hxx> -#include "collect.hxx" -#include <rangenam.hxx> -#include <dbdata.hxx> -#include <stlsheet.hxx> -#include <stlpool.hxx> -#include <filter.hxx> -#include "scflt.hxx" -#include <formulacell.hxx> -#include <scfobj.hxx> -#include <docoptio.hxx> -#include <viewopti.hxx> -#include <postit.hxx> -#include <globstr.hrc> -#include <ftools.hxx> -#include <tabprotection.hxx> - -#include <fprogressbar.hxx> -#include <memory> - -using namespace com::sun::star; - -#define DEFCHARSET RTL_TEXTENCODING_MS_1252 - -#define SC10TOSTRING(p) OUString((p), strlen(p), DEFCHARSET) - -const SCCOL SC10MAXCOL = 255; // #i85906# don't try to load more columns than there are in the file - -/** Those strings are used with SC10TOSTRING() and strcmp() and such, hence - need to be 0-terminated. */ -static void lcl_ReadFixedString( SvStream& rStream, void* pData, size_t nLen ) -{ - sal_Char* pBuf = static_cast<sal_Char*>(pData); - if (!nLen) - pBuf[0] = 0; - else - { - rStream.ReadBytes(pBuf, nLen); - pBuf[nLen-1] = 0; - } -} - -static void lcl_ReadFileHeader(SvStream& rStream, Sc10FileHeader& rFileHeader) -{ - lcl_ReadFixedString( rStream, &rFileHeader.CopyRight, sizeof(rFileHeader.CopyRight)); - rStream.ReadUInt16( rFileHeader.Version ); - rStream.ReadBytes(&rFileHeader.Reserved, sizeof(rFileHeader.Reserved)); -} - -static void lcl_ReadTabProtect(SvStream& rStream, Sc10TableProtect& rProtect) -{ - lcl_ReadFixedString( rStream, &rProtect.PassWord, sizeof(rProtect.PassWord)); - rStream.ReadUInt16( rProtect.Flags ); - rStream.ReadUChar( rProtect.Protect ); -} - -static void lcl_ReadSheetProtect(SvStream& rStream, Sc10SheetProtect& rProtect) -{ - lcl_ReadFixedString( rStream, &rProtect.PassWord, sizeof(rProtect.PassWord)); - rStream.ReadUInt16( rProtect.Flags ); - rStream.ReadUChar( rProtect.Protect ); -} - -static void lcl_ReadRGB(SvStream& rStream, Sc10Color& rColor) -{ - rStream.ReadUChar( rColor.Dummy ); - rStream.ReadUChar( rColor.Blue ); - rStream.ReadUChar( rColor.Green ); - rStream.ReadUChar( rColor.Red ); -} - -static void lcl_ReadPalette(SvStream& rStream, Sc10Color* pPalette) -{ - for (sal_uInt16 i = 0; i < 16; i++) - lcl_ReadRGB(rStream, pPalette[i]); -} - -static void lcl_ReadValueFormat(SvStream& rStream, Sc10ValueFormat& rFormat) -{ - rStream.ReadUChar( rFormat.Format ); - rStream.ReadUChar( rFormat.Info ); -} - -static void lcl_ReadLogFont(SvStream& rStream, Sc10LogFont& rFont) -{ - rStream.ReadInt16( rFont.lfHeight ); - rStream.ReadInt16( rFont.lfWidth ); - rStream.ReadInt16( rFont.lfEscapement ); - rStream.ReadInt16( rFont.lfOrientation ); - rStream.ReadInt16( rFont.lfWeight ); - rStream.ReadUChar( rFont.lfItalic ); - rStream.ReadUChar( rFont.lfUnderline ); - rStream.ReadUChar( rFont.lfStrikeOut ); - rStream.ReadUChar( rFont.lfCharSet ); - rStream.ReadUChar( rFont.lfOutPrecision ); - rStream.ReadUChar( rFont.lfClipPrecision ); - rStream.ReadUChar( rFont.lfQuality ); - rStream.ReadUChar( rFont.lfPitchAndFamily ); - lcl_ReadFixedString( rStream, &rFont.lfFaceName, sizeof(rFont.lfFaceName)); -} - -static void lcl_ReadBlockRect(SvStream& rStream, Sc10BlockRect& rBlock) -{ - rStream.ReadInt16( rBlock.x1 ); - rStream.ReadInt16( rBlock.y1 ); - rStream.ReadInt16( rBlock.x2 ); - rStream.ReadInt16( rBlock.y2 ); -} - -static void lcl_ReadHeadFootLine(SvStream& rStream, Sc10HeadFootLine& rLine) -{ - lcl_ReadFixedString( rStream, &rLine.Title, sizeof(rLine.Title)); - lcl_ReadLogFont(rStream, rLine.LogFont); - rStream.ReadUChar( rLine.HorJustify ); - rStream.ReadUChar( rLine.VerJustify ); - rStream.ReadUInt16( rLine.Raster ); - rStream.ReadUInt16( rLine.Frame ); - lcl_ReadRGB(rStream, rLine.TextColor); - lcl_ReadRGB(rStream, rLine.BackColor); - lcl_ReadRGB(rStream, rLine.RasterColor); - rStream.ReadUInt16( rLine.FrameColor ); - rStream.ReadUInt16( rLine.Reserved ); -} - -static void lcl_ReadPageFormat(SvStream& rStream, Sc10PageFormat& rFormat) -{ - lcl_ReadHeadFootLine(rStream, rFormat.HeadLine); - lcl_ReadHeadFootLine(rStream, rFormat.FootLine); - rStream.ReadInt16( rFormat.Orientation ); - rStream.ReadInt16( rFormat.Width ); - rStream.ReadInt16( rFormat.Height ); - rStream.ReadInt16( rFormat.NonPrintableX ); - rStream.ReadInt16( rFormat.NonPrintableY ); - rStream.ReadInt16( rFormat.Left ); - rStream.ReadInt16( rFormat.Top ); - rStream.ReadInt16( rFormat.Right ); - rStream.ReadInt16( rFormat.Bottom ); - rStream.ReadInt16( rFormat.Head ); - rStream.ReadInt16( rFormat.Foot ); - rStream.ReadUChar( rFormat.HorCenter ); - rStream.ReadUChar( rFormat.VerCenter ); - rStream.ReadUChar( rFormat.PrintGrid ); - rStream.ReadUChar( rFormat.PrintColRow ); - rStream.ReadUChar( rFormat.PrintNote ); - rStream.ReadUChar( rFormat.TopBottomDir ); - lcl_ReadFixedString( rStream, &rFormat.PrintAreaName, sizeof(rFormat.PrintAreaName)); - lcl_ReadBlockRect(rStream, rFormat.PrintArea); - rStream.ReadBytes(&rFormat.PrnZoom, sizeof(rFormat.PrnZoom)); - rStream.ReadInt16( rFormat.FirstPageNo ); - rStream.ReadInt16( rFormat.RowRepeatStart ); - rStream.ReadInt16( rFormat.RowRepeatEnd ); - rStream.ReadInt16( rFormat.ColRepeatStart ); - rStream.ReadInt16( rFormat.ColRepeatEnd ); - rStream.ReadBytes(&rFormat.Reserved, sizeof(rFormat.Reserved)); -} - -static void lcl_ReadGraphHeader(SvStream& rStream, Sc10GraphHeader& rHeader) -{ - rStream.ReadUChar( rHeader.Typ ); - rStream.ReadInt16( rHeader.CarretX ); - rStream.ReadInt16( rHeader.CarretY ); - rStream.ReadInt16( rHeader.CarretZ ); - rStream.ReadInt32( rHeader.x ); - rStream.ReadInt32( rHeader.y ); - rStream.ReadInt32( rHeader.w ); - rStream.ReadInt32( rHeader.h ); - rStream.ReadUChar( rHeader.IsRelPos ); - rStream.ReadUChar( rHeader.DoPrint ); - rStream.ReadUInt16( rHeader.FrameType ); - rStream.ReadUChar( rHeader.IsTransparent ); - lcl_ReadRGB(rStream, rHeader.FrameColor); - lcl_ReadRGB(rStream, rHeader.BackColor); - rStream.ReadBytes(&rHeader.Reserved, sizeof(rHeader.Reserved)); -} - -static void lcl_ReadImageHeaer(SvStream& rStream, Sc10ImageHeader& rHeader) -{ - lcl_ReadFixedString( rStream, &rHeader.FileName, sizeof(rHeader.FileName)); - rStream.ReadInt16( rHeader.Typ ); - rStream.ReadUChar( rHeader.Linked ); - rStream.ReadInt16( rHeader.x1 ); - rStream.ReadInt16( rHeader.y1 ); - rStream.ReadInt16( rHeader.x2 ); - rStream.ReadInt16( rHeader.y2 ); - rStream.ReadUInt32( rHeader.Size ); -} - -static void lcl_ReadChartHeader(SvStream& rStream, Sc10ChartHeader& rHeader) -{ - rStream.ReadInt16( rHeader.MM ); - rStream.ReadInt16( rHeader.xExt ); - rStream.ReadInt16( rHeader.yExt ); - rStream.ReadUInt32( rHeader.Size ); -} - -static void lcl_ReadChartSheetData(SvStream& rStream, Sc10ChartSheetData& rSheetData) -{ - rStream.ReadUChar( rSheetData.HasTitle ); - rStream.ReadInt16( rSheetData.TitleX ); - rStream.ReadInt16( rSheetData.TitleY ); - rStream.ReadUChar( rSheetData.HasSubTitle ); - rStream.ReadInt16( rSheetData.SubTitleX ); - rStream.ReadInt16( rSheetData.SubTitleY ); - rStream.ReadUChar( rSheetData.HasLeftTitle ); - rStream.ReadInt16( rSheetData.LeftTitleX ); - rStream.ReadInt16( rSheetData.LeftTitleY ); - rStream.ReadUChar( rSheetData.HasLegend ); - rStream.ReadInt16( rSheetData.LegendX1 ); - rStream.ReadInt16( rSheetData.LegendY1 ); - rStream.ReadInt16( rSheetData.LegendX2 ); - rStream.ReadInt16( rSheetData.LegendY2 ); - rStream.ReadUChar( rSheetData.HasLabel ); - rStream.ReadInt16( rSheetData.LabelX1 ); - rStream.ReadInt16( rSheetData.LabelY1 ); - rStream.ReadInt16( rSheetData.LabelX2 ); - rStream.ReadInt16( rSheetData.LabelY2 ); - rStream.ReadInt16( rSheetData.DataX1 ); - rStream.ReadInt16( rSheetData.DataY1 ); - rStream.ReadInt16( rSheetData.DataX2 ); - rStream.ReadInt16( rSheetData.DataY2 ); - rStream.ReadBytes(&rSheetData.Reserved, sizeof(rSheetData.Reserved)); -} - -static void lcl_ReadChartTypeData(SvStream& rStream, Sc10ChartTypeData& rTypeData) -{ - rStream.ReadInt16( rTypeData.NumSets ); - rStream.ReadInt16( rTypeData.NumPoints ); - rStream.ReadInt16( rTypeData.DrawMode ); - rStream.ReadInt16( rTypeData.GraphType ); - rStream.ReadInt16( rTypeData.GraphStyle ); - lcl_ReadFixedString( rStream, &rTypeData.GraphTitle, sizeof(rTypeData.GraphTitle)); - lcl_ReadFixedString( rStream, &rTypeData.BottomTitle, sizeof(rTypeData.BottomTitle)); - sal_uInt16 i; - for (i = 0; i < 256; i++) - rStream.ReadInt16( rTypeData.SymbolData[i] ); - for (i = 0; i < 256; i++) - rStream.ReadInt16( rTypeData.ColorData[i] ); - for (i = 0; i < 256; i++) - rStream.ReadInt16( rTypeData.ThickLines[i] ); - for (i = 0; i < 256; i++) - rStream.ReadInt16( rTypeData.PatternData[i] ); - for (i = 0; i < 256; i++) - rStream.ReadInt16( rTypeData.LinePatternData[i] ); - for (i = 0; i < 11; i++) - rStream.ReadInt16( rTypeData.NumGraphStyles[i] ); - rStream.ReadInt16( rTypeData.ShowLegend ); - for (i = 0; i < 256; i++) - lcl_ReadFixedString( rStream, &rTypeData.LegendText[i], sizeof(Sc10ChartText)); - rStream.ReadInt16( rTypeData.ExplodePie ); - rStream.ReadInt16( rTypeData.FontUse ); - for (i = 0; i < 5; i++) - rStream.ReadInt16( rTypeData.FontFamily[i] ); - for (i = 0; i < 5; i++) - rStream.ReadInt16( rTypeData.FontStyle[i] ); - for (i = 0; i < 5; i++) - rStream.ReadInt16( rTypeData.FontSize[i] ); - rStream.ReadInt16( rTypeData.GridStyle ); - rStream.ReadInt16( rTypeData.Labels ); - rStream.ReadInt16( rTypeData.LabelEvery ); - for (i = 0; i < 50; i++) - lcl_ReadFixedString( rStream, &rTypeData.LabelText[i], sizeof(Sc10ChartText)); - lcl_ReadFixedString( rStream, &rTypeData.LeftTitle, sizeof(rTypeData.LeftTitle)); - rStream.ReadBytes(&rTypeData.Reserved, sizeof(rTypeData.Reserved)); -} - -static double lcl_PascalToDouble(sal_Char* tp6) -{ - sal_uInt8* pnUnsigned = reinterpret_cast< sal_uInt8* >( tp6 ); - // biased exponent - sal_uInt8 be = pnUnsigned[ 0 ]; - // lower 16 bits of mantissa - sal_uInt16 v1 = static_cast< sal_uInt16 >( pnUnsigned[ 2 ] * 256 + pnUnsigned[ 1 ] ); - // next 16 bits of mantissa - sal_uInt16 v2 = static_cast< sal_uInt16 >( pnUnsigned[ 4 ] * 256 + pnUnsigned[ 3 ] ); - // upper 7 bits of mantissa - sal_uInt8 v3 = static_cast< sal_uInt8 >( pnUnsigned[ 5 ] & 0x7F ); - // sign bit - bool s = (pnUnsigned[ 5 ] & 0x80) != 0; - - if (be == 0) - return 0.0; - return (((((128 + v3) * 65536.0) + v2) * 65536.0 + v1) * - ldexp ((s ? -1.0 : 1.0), be - (129+39))); -} - -static void lcl_ChangeColor( sal_uInt16 nIndex, Color& rColor ) -{ - ColorData aCol; - - switch( nIndex ) - { - case 1: aCol = COL_RED; break; - case 2: aCol = COL_GREEN; break; - case 3: aCol = COL_BROWN; break; - case 4: aCol = COL_BLUE; break; - case 5: aCol = COL_MAGENTA; break; - case 6: aCol = COL_CYAN; break; - case 7: aCol = COL_GRAY; break; - case 8: aCol = COL_LIGHTGRAY; break; - case 9: aCol = COL_LIGHTRED; break; - case 10: aCol = COL_LIGHTGREEN; break; - case 11: aCol = COL_YELLOW; break; - case 12: aCol = COL_LIGHTBLUE; break; - case 13: aCol = COL_LIGHTMAGENTA; break; - case 14: aCol = COL_LIGHTCYAN; break; - case 15: aCol = COL_WHITE; break; - default: aCol = COL_BLACK; - } - - rColor.SetColor( aCol ); -} - -static OUString lcl_MakeOldPageStyleFormatName( sal_uInt16 i ) -{ - OUString aName = ScGlobal::GetRscString( STR_PAGESTYLE ) + " " + OUString::number( i + 1 ); - return aName; -} - -template < typename T > ErrCode insert_new( ScCollection* pCollection, SvStream& rStream ) -{ - std::unique_ptr<T> pData(new (::std::nothrow) T( rStream)); - ErrCode nError = rStream.GetError(); - if (pData) - { - if (!nError) - pCollection->Insert( pData.release() ); - } - else - nError = errOutOfMemory; - return nError; -} - -// Font - -Sc10FontData::Sc10FontData(SvStream& rStream) - : Height(0) - , CharSet(0) - , PitchAndFamily(0) -{ - rStream.ReadInt16( Height ); - rStream.ReadUChar( CharSet ); - rStream.ReadUChar( PitchAndFamily ); - sal_uInt16 nLen(0); - rStream.ReadUInt16( nLen ); - if (nLen < sizeof(FaceName)) - rStream.ReadBytes(FaceName, nLen); - else - rStream.SetError(ERRCODE_IO_WRONGFORMAT); -} - -Sc10FontCollection::Sc10FontCollection(SvStream& rStream) - : ScCollection(4, 4) - , nError(0) -{ - sal_uInt16 ID(0); - rStream.ReadUInt16( ID ); - if (ID == FontID) - { - sal_uInt16 nCnt(0); - rStream.ReadUInt16( nCnt ); - for (sal_uInt16 i=0; (i < nCnt) && (nError == ERRCODE_NONE); i++) - { - nError = insert_new<Sc10FontData>( this, rStream); - } - } - else - { - OSL_FAIL( "FontID" ); - nError = errUnknownID; - } -} - -// named regions - -Sc10NameData::Sc10NameData(SvStream& rStream) -{ - sal_uInt8 nLen; - rStream.ReadUChar( nLen ); - rStream.ReadBytes(Name, sizeof(Name) - 1); - if (nLen >= sizeof(Name)) - nLen = sizeof(Name) - 1; - Name[nLen] = 0; - - rStream.ReadUChar( nLen ); - rStream.ReadBytes(Reference, sizeof(Reference) - 1); - if (nLen >= sizeof(Reference)) - nLen = sizeof(Reference) - 1; - Reference[nLen] = 0; - rStream.ReadBytes(Reserved, sizeof(Reserved)); -} - -Sc10NameCollection::Sc10NameCollection(SvStream& rStream) : - ScCollection (4, 4), - nError (0) -{ - sal_uInt16 ID; - rStream.ReadUInt16( ID ); - if (ID == NameID) - { - sal_uInt16 nCnt; - rStream.ReadUInt16( nCnt ); - for (sal_uInt16 i=0; (i < nCnt) && (nError == ERRCODE_NONE); i++) - { - nError = insert_new<Sc10NameData>( this, rStream); - } - } - else - { - OSL_FAIL( "NameID" ); - nError = errUnknownID; - } -} - -// templates -Sc10PatternData::Sc10PatternData(SvStream& rStream) - : Attr(0) - , Justify(0) - , Frame(0) - , Raster(0) - , nColor(0) - , FrameColor(0) - , Flags(0) - , FormatFlags(0) -{ - memset(Name, 0, sizeof(Name)); - memset(Reserved, 0, sizeof(Reserved)); - lcl_ReadFixedString( rStream, Name, sizeof(Name)); - lcl_ReadValueFormat(rStream, ValueFormat); - lcl_ReadLogFont(rStream, LogFont); - - rStream.ReadUInt16( Attr ); - rStream.ReadUInt16( Justify ); - rStream.ReadUInt16( Frame ); - rStream.ReadUInt16( Raster ); - rStream.ReadUInt16( nColor ); - rStream.ReadUInt16( FrameColor ); - rStream.ReadUInt16( Flags ); - rStream.ReadUInt16( FormatFlags ); - rStream.ReadBytes(Reserved, sizeof(Reserved)); -} - -Sc10PatternCollection::Sc10PatternCollection(SvStream& rStream) - : ScCollection(4, 4) - , nError(0) -{ - sal_uInt16 ID; - rStream.ReadUInt16( ID ); - if (ID == PatternID) - { - sal_uInt16 nCnt; - rStream.ReadUInt16( nCnt ); - for (sal_uInt16 i=0; (i < nCnt) && (nError == ERRCODE_NONE); i++) - { - nError = insert_new<Sc10PatternData>( this, rStream); - } - } - else - { - OSL_FAIL( "PatternID" ); - nError = errUnknownID; - } -} - -// database - -Sc10DataBaseData::Sc10DataBaseData(SvStream& rStream) -{ - lcl_ReadFixedString( rStream, &DataBaseRec.Name, sizeof(DataBaseRec.Name)); - rStream.ReadInt16( DataBaseRec.Tab ); - lcl_ReadBlockRect(rStream, DataBaseRec.Block); - rStream.ReadUChar( DataBaseRec.RowHeader ); - rStream.ReadInt16( DataBaseRec.SortField0 ); - rStream.ReadUChar( DataBaseRec.SortUpOrder0 ); - rStream.ReadInt16( DataBaseRec.SortField1 ); - rStream.ReadUChar( DataBaseRec.SortUpOrder1 ); - rStream.ReadInt16( DataBaseRec.SortField2 ); - rStream.ReadUChar( DataBaseRec.SortUpOrder2 ); - rStream.ReadUChar( DataBaseRec.IncludeFormat ); - - rStream.ReadInt16( DataBaseRec.QueryField0 ); - rStream.ReadInt16( DataBaseRec.QueryOp0 ); - rStream.ReadUChar( DataBaseRec.QueryByString0 ); - lcl_ReadFixedString( rStream, &DataBaseRec.QueryString0, sizeof(DataBaseRec.QueryString0)); - DataBaseRec.QueryValue0 = ScfTools::ReadLongDouble(rStream); - - rStream.ReadInt16( DataBaseRec.QueryConnect1 ); - rStream.ReadInt16( DataBaseRec.QueryField1 ); - rStream.ReadInt16( DataBaseRec.QueryOp1 ); - rStream.ReadUChar( DataBaseRec.QueryByString1 ); - lcl_ReadFixedString( rStream, &DataBaseRec.QueryString1, sizeof(DataBaseRec.QueryString1)); - DataBaseRec.QueryValue1 = ScfTools::ReadLongDouble(rStream); - - rStream.ReadInt16( DataBaseRec.QueryConnect2 ); - rStream.ReadInt16( DataBaseRec.QueryField2 ); - rStream.ReadInt16( DataBaseRec.QueryOp2 ); - rStream.ReadUChar( DataBaseRec.QueryByString2 ); - lcl_ReadFixedString( rStream, &DataBaseRec.QueryString2, sizeof(DataBaseRec.QueryString2)); - DataBaseRec.QueryValue2 = ScfTools::ReadLongDouble(rStream); -} - -Sc10DataBaseCollection::Sc10DataBaseCollection(SvStream& rStream) - : ScCollection(4, 4) - , nError(0) -{ - sal_uInt16 ID; - rStream.ReadUInt16( ID ); - if (ID == DataBaseID) - { - lcl_ReadFixedString( rStream, ActName, sizeof(ActName)); - sal_uInt16 nCnt; - rStream.ReadUInt16( nCnt ); - for (sal_uInt16 i=0; (i < nCnt) && (nError == ERRCODE_NONE); i++) - { - nError = insert_new<Sc10DataBaseData>( this, rStream); - } - } - else - { - OSL_FAIL( "DataBaseID" ); - nError = errUnknownID; - } -} - -bool Sc10LogFont::operator==( const Sc10LogFont& rData ) const -{ - return !strcmp( lfFaceName, rData.lfFaceName ) - && lfHeight == rData.lfHeight - && lfWidth == rData.lfWidth - && lfEscapement == rData.lfEscapement - && lfOrientation == rData.lfOrientation - && lfWeight == rData.lfWeight - && lfItalic == rData.lfItalic - && lfUnderline == rData.lfUnderline - && lfStrikeOut == rData.lfStrikeOut - && lfCharSet == rData.lfCharSet - && lfOutPrecision == rData.lfOutPrecision - && lfClipPrecision == rData.lfClipPrecision - && lfQuality == rData.lfQuality - && lfPitchAndFamily == rData.lfPitchAndFamily; -} - -bool Sc10Color::operator==( const Sc10Color& rColor ) const -{ - return ((Red == rColor.Red) && (Green == rColor.Green) && (Blue == rColor.Blue)); -} - -bool Sc10HeadFootLine::operator==( const Sc10HeadFootLine& rData ) const -{ - return !strcmp(Title, rData.Title) - && LogFont == rData.LogFont - && HorJustify == rData.HorJustify - && VerJustify == rData.VerJustify - && Raster == rData.Raster - && Frame == rData.Frame - && TextColor == rData.TextColor - && BackColor == rData.BackColor - && RasterColor == rData.RasterColor - && FrameColor == rData.FrameColor - && Reserved == rData.Reserved; -} - -bool Sc10PageFormat::operator==( const Sc10PageFormat& rData ) const -{ - return !strcmp(PrintAreaName, rData.PrintAreaName) - && HeadLine == rData.HeadLine - && FootLine == rData.FootLine - && Orientation == rData.Orientation - && Width == rData.Width - && Height == rData.Height - && NonPrintableX == rData.NonPrintableX - && NonPrintableY == rData.NonPrintableY - && Left == rData.Left - && Top == rData.Top - && Right == rData.Right - && Bottom == rData.Bottom - && Head == rData.Head - && Foot == rData.Foot - && HorCenter == rData.HorCenter - && VerCenter == rData.VerCenter - && PrintGrid == rData.PrintGrid - && PrintColRow == rData.PrintColRow - && PrintNote == rData.PrintNote - && TopBottomDir == rData.TopBottomDir - && FirstPageNo == rData.FirstPageNo - && RowRepeatStart == rData.RowRepeatStart - && RowRepeatEnd == rData.RowRepeatEnd - && ColRepeatStart == rData.ColRepeatStart - && ColRepeatEnd == rData.ColRepeatEnd - && !memcmp( PrnZoom, rData.PrnZoom, sizeof(PrnZoom) ) - && !memcmp( &PrintArea, &rData.PrintArea, sizeof(PrintArea) ); -} - -sal_uInt16 Sc10PageCollection::InsertFormat( const Sc10PageFormat& rData ) -{ - for (sal_uInt16 i=0; i<nCount; i++) - if (At(i)->aPageFormat == rData) - return i; - - Insert( new Sc10PageData(rData) ); - - return nCount-1; -} - -static inline sal_uInt8 GetMixedCol( const sal_uInt8 nB, const sal_uInt8 nF, const sal_uInt16 nFak ) -{ - sal_Int32 nT = nB - nF; - nT *= ( sal_Int32 ) nFak; - nT /= 0xFFFF; - nT += nF; - return ( sal_uInt8 ) nT; -} -static inline Color GetMixedColor( const Color& rFore, const Color& rBack, sal_uInt16 nFact ) -{ - return Color( GetMixedCol( rBack.GetRed(), rFore.GetRed(), nFact ), - GetMixedCol( rBack.GetGreen(), rFore.GetGreen(), nFact ), - GetMixedCol( rBack.GetBlue(), rFore.GetBlue(), nFact ) ); -} - -void Sc10PageCollection::PutToDoc( ScDocument* pDoc ) -{ - ScStyleSheetPool* pStylePool = pDoc->GetStyleSheetPool(); - EditEngine aEditEngine( pDoc->GetEnginePool() ); - EditTextObject* pEmptyObject = aEditEngine.CreateTextObject(); - - for (sal_uInt16 i=0; i<nCount; i++) - { - Sc10PageFormat* pPage = &At(i)->aPageFormat; - - pPage->Width = (short) ( pPage->Width + 0.5 ); - pPage->Height = (short) ( pPage->Height + 0.5 ); - pPage->Top = (short) ( pPage->Top + 0.5 ); - pPage->Bottom = (short) ( pPage->Bottom + 0.5 ); - pPage->Left = (short) ( pPage->Left + 0.5 ); - pPage->Right = (short) ( pPage->Right + 0.5 ); - pPage->Head = (short) ( pPage->Head + 0.5 ); - pPage->Foot = (short) ( pPage->Foot + 0.5 ); - - OUString aName = lcl_MakeOldPageStyleFormatName( i ); - - ScStyleSheet* pSheet = static_cast<ScStyleSheet*>( &pStylePool->Make( aName, - SfxStyleFamily::Page, - SFXSTYLEBIT_USERDEF | SCSTYLEBIT_STANDARD ) ); - // #i68483# set page style name at sheet... - pDoc->SetPageStyle( static_cast< SCTAB >( i ), aName ); - - SfxItemSet* pSet = &pSheet->GetItemSet(); - - for (sal_uInt16 nHeadFoot=0; nHeadFoot<2; nHeadFoot++) - { - Sc10HeadFootLine* pHeadFootLine = nHeadFoot ? &pPage->FootLine : &pPage->HeadLine; - - SfxItemSet aEditAttribs(aEditEngine.GetEmptyItemSet()); - FontFamily eFam = FAMILY_DONTKNOW; - switch (pPage->HeadLine.LogFont.lfPitchAndFamily & 0xF0) - { - case ffDontCare: eFam = FAMILY_DONTKNOW; break; - case ffRoman: eFam = FAMILY_ROMAN; break; - case ffSwiss: eFam = FAMILY_SWISS; break; - case ffModern: eFam = FAMILY_MODERN; break; - case ffScript: eFam = FAMILY_SCRIPT; break; - case ffDecorative: eFam = FAMILY_DECORATIVE; break; - default: eFam = FAMILY_DONTKNOW; break; - } - aEditAttribs.Put( SvxFontItem( - eFam, - SC10TOSTRING( pHeadFootLine->LogFont.lfFaceName ), EMPTY_OUSTRING, - PITCH_DONTKNOW, RTL_TEXTENCODING_DONTKNOW, EE_CHAR_FONTINFO ) ); - aEditAttribs.Put( SvxFontHeightItem( std::abs( pHeadFootLine->LogFont.lfHeight ), 100, EE_CHAR_FONTHEIGHT ) ); - - Sc10Color nColor = pHeadFootLine->TextColor; - Color TextColor( nColor.Red, nColor.Green, nColor.Blue ); - aEditAttribs.Put(SvxColorItem(TextColor, EE_CHAR_COLOR)); - // FontAttr - if (pHeadFootLine->LogFont.lfWeight != fwNormal) - aEditAttribs.Put(SvxWeightItem(WEIGHT_BOLD, EE_CHAR_WEIGHT)); - if (pHeadFootLine->LogFont.lfItalic != 0) - aEditAttribs.Put(SvxPostureItem(ITALIC_NORMAL, EE_CHAR_ITALIC)); - if (pHeadFootLine->LogFont.lfUnderline != 0) - aEditAttribs.Put(SvxUnderlineItem(LINESTYLE_SINGLE, EE_CHAR_UNDERLINE)); - if (pHeadFootLine->LogFont.lfStrikeOut != 0) - aEditAttribs.Put(SvxCrossedOutItem(STRIKEOUT_SINGLE, EE_CHAR_STRIKEOUT)); - OUString aText( pHeadFootLine->Title, strlen(pHeadFootLine->Title), DEFCHARSET ); - aEditEngine.SetText( aText ); - aEditEngine.QuickSetAttribs( aEditAttribs, ESelection( 0, 0, 0, aText.getLength() ) ); - - EditTextObject* pObject = aEditEngine.CreateTextObject(); - ScPageHFItem aHeaderItem(nHeadFoot ? ATTR_PAGE_FOOTERRIGHT : ATTR_PAGE_HEADERRIGHT); - switch (pHeadFootLine->HorJustify) - { - case hjCenter: - aHeaderItem.SetLeftArea(*pEmptyObject); - aHeaderItem.SetCenterArea(*pObject); - aHeaderItem.SetRightArea(*pEmptyObject); - break; - case hjRight: - aHeaderItem.SetLeftArea(*pEmptyObject); - aHeaderItem.SetCenterArea(*pEmptyObject); - aHeaderItem.SetRightArea(*pObject); - break; - default: - aHeaderItem.SetLeftArea(*pObject); - aHeaderItem.SetCenterArea(*pEmptyObject); - aHeaderItem.SetRightArea(*pEmptyObject); - break; - } - delete pObject; - pSet->Put( aHeaderItem ); - - SfxItemSet aSetItemItemSet( - *pDoc->GetPool(), - svl::Items< - ATTR_BACKGROUND, ATTR_BACKGROUND, - ATTR_BORDER, ATTR_SHADOW, - ATTR_LRSPACE, ATTR_ULSPACE, - ATTR_PAGE_SIZE, ATTR_PAGE_SIZE, - ATTR_PAGE_ON, ATTR_PAGE_SHARED>{}); - nColor = pHeadFootLine->BackColor; - Color aBColor( nColor.Red, nColor.Green, nColor.Blue ); - nColor = pHeadFootLine->RasterColor; - Color aRColor( nColor.Red, nColor.Green, nColor.Blue ); - - sal_uInt16 nFact; - bool bSwapCol = false; - switch (pHeadFootLine->Raster) - { - case raNone: nFact = 0xffff; bSwapCol = true; break; - case raGray12: nFact = (0xffff / 100) * 12; break; - case raGray25: nFact = (0xffff / 100) * 25; break; - case raGray50: nFact = (0xffff / 100) * 50; break; - case raGray75: nFact = (0xffff / 100) * 75; break; - default: nFact = 0xffff; - } - if( bSwapCol ) - aSetItemItemSet.Put( SvxBrushItem( GetMixedColor( aBColor, aRColor, nFact ), ATTR_BACKGROUND ) ); - else - aSetItemItemSet.Put( SvxBrushItem( GetMixedColor( aRColor, aBColor, nFact ), ATTR_BACKGROUND ) ); - - if (pHeadFootLine->Frame != 0) - { - sal_uInt16 nLeft = 0; - sal_uInt16 nTop = 0; - sal_uInt16 nRight = 0; - sal_uInt16 nBottom = 0; - sal_uInt16 fLeft = (pHeadFootLine->Frame & 0x000F); - sal_uInt16 fTop = (pHeadFootLine->Frame & 0x00F0) / 0x0010; - sal_uInt16 fRight = (pHeadFootLine->Frame & 0x0F00) / 0x0100; - sal_uInt16 fBottom = (pHeadFootLine->Frame & 0xF000) / 0x1000; - if (fLeft > 1) - nLeft = 50; - else if (fLeft > 0) - nLeft = 20; - if (fTop > 1) - nTop = 50; - else if (fTop > 0) - nTop = 20; - if (fRight > 1) - nRight = 50; - else if (fRight > 0) - nRight = 20; - if (fBottom > 1) - nBottom = 50; - else if (fBottom > 0) - nBottom = 20; - Color ColorLeft(COL_BLACK); - Color ColorTop(COL_BLACK); - Color ColorRight(COL_BLACK); - Color ColorBottom(COL_BLACK); - sal_uInt16 cLeft = (pHeadFootLine->FrameColor & 0x000F); - sal_uInt16 cTop = (pHeadFootLine->FrameColor & 0x00F0) >> 4; - sal_uInt16 cRight = (pHeadFootLine->FrameColor & 0x0F00) >> 8; - sal_uInt16 cBottom = (pHeadFootLine->FrameColor & 0xF000) >> 12; - lcl_ChangeColor(cLeft, ColorLeft); - lcl_ChangeColor(cTop, ColorTop); - lcl_ChangeColor(cRight, ColorRight); - lcl_ChangeColor(cBottom, ColorBottom); - ::editeng::SvxBorderLine aLine; - SvxBoxItem aBox( ATTR_BORDER ); - aLine.SetWidth(nLeft); - aLine.SetColor(ColorLeft); - aBox.SetLine(&aLine, SvxBoxItemLine::LEFT); - aLine.SetWidth(nTop); - aLine.SetColor(ColorTop); - aBox.SetLine(&aLine, SvxBoxItemLine::TOP); - aLine.SetWidth(nRight); - aLine.SetColor(ColorRight); - aBox.SetLine(&aLine, SvxBoxItemLine::RIGHT); - aLine.SetWidth(nBottom); - aLine.SetColor(ColorBottom); - aBox.SetLine(&aLine, SvxBoxItemLine::BOTTOM); - - aSetItemItemSet.Put(aBox); - } - - pSet->Put( SvxULSpaceItem( 0, 0, ATTR_ULSPACE ) ); - - if (nHeadFoot==0) - aSetItemItemSet.Put( SvxSizeItem( ATTR_PAGE_SIZE, Size( 0, pPage->Top - pPage->Head ) ) ); - else - aSetItemItemSet.Put( SvxSizeItem( ATTR_PAGE_SIZE, Size( 0, pPage->Bottom - pPage->Foot ) ) ); - - aSetItemItemSet.Put(SfxBoolItem( ATTR_PAGE_ON, true )); - aSetItemItemSet.Put(SfxBoolItem( ATTR_PAGE_DYNAMIC, false )); - aSetItemItemSet.Put(SfxBoolItem( ATTR_PAGE_SHARED, true )); - - pSet->Put( SvxSetItem( nHeadFoot ? ATTR_PAGE_FOOTERSET : ATTR_PAGE_HEADERSET, - aSetItemItemSet ) ); - } - - SvxPageItem aPageItem(ATTR_PAGE); - aPageItem.SetPageUsage( SvxPageUsage::All ); - aPageItem.SetLandscape( pPage->Orientation != 1 ); - aPageItem.SetNumType( SVX_NUM_ARABIC ); - pSet->Put(aPageItem); - - pSet->Put(SvxLRSpaceItem( pPage->Left, pPage->Right, 0,0, ATTR_LRSPACE )); - pSet->Put(SvxULSpaceItem( pPage->Top, pPage->Bottom, ATTR_ULSPACE )); - - pSet->Put(SfxBoolItem( ATTR_PAGE_HORCENTER, pPage->HorCenter )); - pSet->Put(SfxBoolItem( ATTR_PAGE_VERCENTER, pPage->VerCenter )); - - // Area-Parameter: - - { - ScRange* pRepeatRow = nullptr; - ScRange* pRepeatCol = nullptr; - - if ( pPage->ColRepeatStart >= 0 ) - pRepeatCol = new ScRange( static_cast<SCCOL> (pPage->ColRepeatStart), 0, 0 ); - if ( pPage->RowRepeatStart >= 0 ) - pRepeatRow = new ScRange( 0, static_cast<SCROW> (pPage->RowRepeatStart), 0 ); - - if ( pRepeatRow || pRepeatCol ) - { - - // set for all tables - - for ( SCTAB nTab = 0, nTabCount = pDoc->GetTableCount(); nTab < nTabCount; ++nTab ) - { - pDoc->SetRepeatColRange( nTab, pRepeatCol ); - pDoc->SetRepeatRowRange( nTab, pRepeatRow ); - } - } - - delete pRepeatRow; - delete pRepeatCol; - } - - // Table-Parameter: - - pSet->Put( SfxBoolItem( ATTR_PAGE_NOTES, pPage->PrintNote ) ); - pSet->Put( SfxBoolItem( ATTR_PAGE_GRID, pPage->PrintGrid ) ); - pSet->Put( SfxBoolItem( ATTR_PAGE_HEADERS, pPage->PrintColRow ) ); - pSet->Put( SfxBoolItem( ATTR_PAGE_TOPDOWN, pPage->TopBottomDir ) ); - pSet->Put( ScViewObjectModeItem( ATTR_PAGE_CHARTS, VOBJ_MODE_SHOW ) ); - pSet->Put( ScViewObjectModeItem( ATTR_PAGE_OBJECTS, VOBJ_MODE_SHOW ) ); - pSet->Put( ScViewObjectModeItem( ATTR_PAGE_DRAWINGS, VOBJ_MODE_SHOW ) ); - pSet->Put( SfxUInt16Item( ATTR_PAGE_SCALE, - (sal_uInt16)( lcl_PascalToDouble( pPage->PrnZoom ) * 100 ) ) ); - pSet->Put( SfxUInt16Item( ATTR_PAGE_FIRSTPAGENO, 1 ) ); - - pSet->Put( SvxSizeItem( ATTR_PAGE_SIZE, Size( pPage->Width, pPage->Height ) ) ); - } - - delete pEmptyObject; -} - -ScDataObject* Sc10PageData::Clone() const -{ - return new Sc10PageData(aPageFormat); -} - -// Import - -Sc10Import::Sc10Import(SvStream& rStr, ScDocument* pDocument ) : - rStream (rStr), - pDoc (pDocument), - pFontCollection (nullptr), - pNameCollection (nullptr), - pPatternCollection (nullptr), - pDataBaseCollection (nullptr), - nError (0), - nShowTab (0) -{ - pPrgrsBar = nullptr; -} - -Sc10Import::~Sc10Import() -{ - delete pFontCollection; - delete pNameCollection; - delete pPatternCollection; - delete pDataBaseCollection; - - OSL_ENSURE( pPrgrsBar == nullptr, - "*Sc10Import::Sc10Import(): progress bar is still alive!?" ); -} - -ErrCode Sc10Import::Import() -{ - pPrgrsBar = new ScfStreamProgressBar( rStream, pDoc->GetDocumentShell() ); - - ScDocOptions aOpt = pDoc->GetDocOptions(); - aOpt.SetDate( 1, 1, 1900 ); - aOpt.SetYear2000( 18 + 1901 ); // 4-digit since SO51 src513e - pDoc->SetDocOptions( aOpt ); - pDoc->GetFormatTable()->ChangeNullDate( 1, 1, 1900 ); - - LoadFileHeader(); pPrgrsBar->Progress(); - if (!nError) { LoadFileInfo(); pPrgrsBar->Progress(); } - if (!nError) { LoadEditStateInfo(); pPrgrsBar->Progress(); } - if (!nError) { LoadProtect(); pPrgrsBar->Progress(); } - if (!nError) { LoadViewColRowBar(); pPrgrsBar->Progress(); } - if (!nError) { LoadScrZoom(); pPrgrsBar->Progress(); } - if (!nError) { LoadPalette(); pPrgrsBar->Progress(); } - if (!nError) { LoadFontCollection(); pPrgrsBar->Progress(); } - if (!nError) { LoadNameCollection(); pPrgrsBar->Progress(); } - if (!nError) { LoadPatternCollection(); pPrgrsBar->Progress(); } - if (!nError) { LoadDataBaseCollection(); pPrgrsBar->Progress(); } - if (!nError) { LoadTables(); pPrgrsBar->Progress(); } - if (!nError) { LoadObjects(); pPrgrsBar->Progress(); } - if (!nError) { ImportNameCollection(); pPrgrsBar->Progress(); } - pDoc->SetViewOptions( aSc30ViewOpt ); - - SAL_WARN_IF( nError, "sc", nError); - - delete pPrgrsBar; -#if OSL_DEBUG_LEVEL > 0 - pPrgrsBar = nullptr; -#endif - - pDoc->CalcAfterLoad(); - pDoc->UpdateAllCharts(); - - return nError; -} - -void Sc10Import::LoadFileHeader() -{ - Sc10FileHeader FileHeader; - lcl_ReadFileHeader(rStream, FileHeader); - - nError = rStream.GetError(); - if ( nError == ERRCODE_NONE ) - { - sal_Char Sc10CopyRight[32]; - strcpy(Sc10CopyRight, "Blaise-Tabelle"); - Sc10CopyRight[14] = 10; - Sc10CopyRight[15] = 13; - Sc10CopyRight[16] = 0; - if ((strcmp(FileHeader.CopyRight, Sc10CopyRight) != 0) - || (FileHeader.Version < 101) - || (FileHeader.Version > 102)) - nError = errUnknownFormat; - } -} - -void Sc10Import::LoadFileInfo() -{ - Sc10FileInfo FileInfo; - rStream.ReadBytes(&FileInfo, sizeof(FileInfo)); - - nError = rStream.GetError(); - // TODO: ? copy info, byte swapping -} - -void Sc10Import::LoadEditStateInfo() -{ - Sc10EditStateInfo EditStateInfo; - -#if !defined(NDEBUG) - sal_uInt64 const nOldPos(rStream.Tell()); -#endif - - rStream.ReadUInt16(EditStateInfo.CarretX); - rStream.ReadUInt16(EditStateInfo.CarretY); - rStream.ReadUInt16(EditStateInfo.CarretZ); - rStream.ReadUInt16(EditStateInfo.DeltaX); - rStream.ReadUInt16(EditStateInfo.DeltaY); - rStream.ReadUInt16(EditStateInfo.DeltaZ); - rStream.ReadUChar(EditStateInfo.DataBaseMode); - rStream.ReadBytes(EditStateInfo.Reserved, sizeof(EditStateInfo.Reserved)); - - assert(rStream.GetError() || rStream.Tell() == nOldPos + sizeof(Sc10EditStateInfo)); - - nError = rStream.GetError(); - nShowTab = static_cast<SCTAB>(EditStateInfo.DeltaZ); - // TODO: ? copy cursor position and offset of the table (shall we do that??) - -} - -void Sc10Import::LoadProtect() -{ - lcl_ReadSheetProtect(rStream, SheetProtect); - nError = rStream.GetError(); - - ScDocProtection aProtection; - aProtection.setProtected(static_cast<bool>(SheetProtect.Protect)); - aProtection.setPassword(SC10TOSTRING(SheetProtect.PassWord)); - pDoc->SetDocProtection(&aProtection); -} - -void Sc10Import::LoadViewColRowBar() -{ - bool bViewColRowBar; - rStream.ReadCharAsBool( bViewColRowBar ); - nError = rStream.GetError(); - aSc30ViewOpt.SetOption( VOPT_HEADER, bViewColRowBar ); -} - -void Sc10Import::LoadScrZoom() -{ - // TODO: unfortunately Zoom is a 6-byte TP real number (don't know how to translate that) - sal_Char cZoom[6]; - rStream.ReadBytes(cZoom, sizeof(cZoom)); - nError = rStream.GetError(); -} - -void Sc10Import::LoadPalette() -{ - lcl_ReadPalette(rStream, TextPalette); - lcl_ReadPalette(rStream, BackPalette); - lcl_ReadPalette(rStream, RasterPalette); - lcl_ReadPalette(rStream, FramePalette); - - nError = rStream.GetError(); -} - -void Sc10Import::LoadFontCollection() -{ - pFontCollection = new Sc10FontCollection(rStream); - if (!nError) - nError = pFontCollection->GetError(); -} - -void Sc10Import::LoadNameCollection() -{ - pNameCollection = new Sc10NameCollection(rStream); - if (!nError) - nError = pNameCollection->GetError(); -} - -void Sc10Import::ImportNameCollection() -{ - ScRangeName* pRN = pDoc->GetRangeName(); - - for (sal_uInt16 i = 0; i < pNameCollection->GetCount(); i++) - { - Sc10NameData* pName = pNameCollection->At( i ); - pRN->insert( - new ScRangeData( - pDoc, SC10TOSTRING(pName->Name), SC10TOSTRING(pName->Reference))); - } -} - -void Sc10Import::LoadPatternCollection() -{ - pPatternCollection = new Sc10PatternCollection( rStream ); - if (!nError) - nError = pPatternCollection->GetError(); - if (nError == errOutOfMemory) - return; // hopeless - ScStyleSheetPool* pStylePool = pDoc->GetStyleSheetPool(); - for( sal_uInt16 i = 0 ; i < pPatternCollection->GetCount() ; i++ ) - { - Sc10PatternData* pPattern = pPatternCollection->At( i ); - OUString aName( pPattern->Name, strlen(pPattern->Name), DEFCHARSET ); - SfxStyleSheetBase* pStyle = pStylePool->Find( aName, SfxStyleFamily::Para ); - if( pStyle == nullptr ) - pStylePool->Make( aName, SfxStyleFamily::Para ); - else - { - pPattern->Name[ 27 ] = 0; - strcat( pPattern->Name, "_Old" ); - aName = SC10TOSTRING( pPattern->Name ); - pStylePool->Make( aName, SfxStyleFamily::Para ); - } - pStyle = pStylePool->Find( aName, SfxStyleFamily::Para ); - if( pStyle != nullptr ) - { - SfxItemSet &rItemSet = pStyle->GetItemSet(); - // Font - if( ( pPattern->FormatFlags & pfFont ) == pfFont ) - { - FontFamily eFam = FAMILY_DONTKNOW; - switch( pPattern->LogFont.lfPitchAndFamily & 0xF0 ) - { - case ffDontCare : eFam = FAMILY_DONTKNOW; break; - case ffRoman : eFam = FAMILY_ROMAN; break; - case ffSwiss : eFam = FAMILY_SWISS; break; - case ffModern : eFam = FAMILY_MODERN; break; - case ffScript : eFam = FAMILY_SCRIPT; break; - case ffDecorative : eFam = FAMILY_DECORATIVE; break; - default: eFam = FAMILY_DONTKNOW; break; - } - rItemSet.Put( SvxFontItem( eFam, SC10TOSTRING( pPattern->LogFont.lfFaceName ), EMPTY_OUSTRING, - PITCH_DONTKNOW, RTL_TEXTENCODING_DONTKNOW, ATTR_FONT ) ); - rItemSet.Put( SvxFontHeightItem( std::abs( pPattern->LogFont.lfHeight ), 100, ATTR_FONT_HEIGHT ) ); - Color TextColor( COL_BLACK ); - lcl_ChangeColor( ( pPattern->nColor & 0x000F ), TextColor ); - rItemSet.Put( SvxColorItem( TextColor, ATTR_FONT_COLOR ) ); - // FontAttr - if( pPattern->LogFont.lfWeight != fwNormal ) - rItemSet.Put( SvxWeightItem( WEIGHT_BOLD, ATTR_FONT_WEIGHT ) ); - if( pPattern->LogFont.lfItalic != 0 ) - rItemSet.Put( SvxPostureItem( ITALIC_NORMAL, ATTR_FONT_POSTURE ) ); - if( pPattern->LogFont.lfUnderline != 0 ) - rItemSet.Put( SvxUnderlineItem( LINESTYLE_SINGLE, ATTR_FONT_UNDERLINE ) ); - if( pPattern->LogFont.lfStrikeOut != 0 ) - rItemSet.Put( SvxCrossedOutItem( STRIKEOUT_SINGLE, ATTR_FONT_CROSSEDOUT ) ); - } - // alignment - if( ( pPattern->FormatFlags & pfJustify ) == pfJustify ) - { - sal_uInt16 HorJustify = ( pPattern->Justify & 0x000F ); - sal_uInt16 VerJustify = ( pPattern->Justify & 0x00F0 ) >> 4; - sal_uInt16 OJustify = ( pPattern->Justify & 0x0F00 ) >> 8; - sal_uInt16 EJustify = ( pPattern->Justify & 0xF000 ) >> 12; - if( HorJustify != 0 ) - switch( HorJustify ) - { - case hjLeft: - rItemSet.Put( SvxHorJustifyItem( SvxCellHorJustify::Left, ATTR_HOR_JUSTIFY ) ); - break; - case hjCenter: - rItemSet.Put( SvxHorJustifyItem( SvxCellHorJustify::Center, ATTR_HOR_JUSTIFY ) ); - break; - case hjRight: - rItemSet.Put( SvxHorJustifyItem( SvxCellHorJustify::Right, ATTR_HOR_JUSTIFY ) ); - break; - } - if( VerJustify != 0 ) - switch( VerJustify ) - { - case vjTop: - rItemSet.Put( SvxVerJustifyItem( SvxCellVerJustify::Top, ATTR_VER_JUSTIFY ) ); - break; - case vjCenter: - rItemSet.Put( SvxVerJustifyItem( SvxCellVerJustify::Center, ATTR_VER_JUSTIFY ) ); - break; - case vjBottom: - rItemSet.Put( SvxVerJustifyItem( SvxCellVerJustify::Bottom, ATTR_VER_JUSTIFY ) ); - break; - } - - if( ( OJustify & ojWordBreak ) == ojWordBreak ) - rItemSet.Put( SfxBoolItem( ATTR_LINEBREAK, true ) ); - if( ( OJustify & ojBottomTop ) == ojBottomTop ) - rItemSet.Put( SfxInt32Item( ATTR_ROTATE_VALUE, 9000 ) ); - else if( ( OJustify & ojTopBottom ) == ojTopBottom ) - rItemSet.Put( SfxInt32Item( ATTR_ROTATE_VALUE, 27000 ) ); - - sal_Int16 Margin = std::max( ( sal_uInt16 ) 20, ( sal_uInt16 ) ( EJustify * 20 ) ); - if( ( OJustify & ojBottomTop ) == ojBottomTop ) - rItemSet.Put( SvxMarginItem( 20, Margin, 20, Margin, ATTR_MARGIN ) ); - else - rItemSet.Put( SvxMarginItem( Margin, 20, Margin, 20, ATTR_MARGIN ) ); - } - - // Frame - if( ( pPattern->FormatFlags & pfFrame ) == pfFrame ) - { - if( pPattern->Frame != 0 ) - { - sal_uInt16 nLeft = 0; - sal_uInt16 nTop = 0; - sal_uInt16 nRight = 0; - sal_uInt16 nBottom = 0; - sal_uInt16 fLeft = ( pPattern->Frame & 0x000F ); - sal_uInt16 fTop = ( pPattern->Frame & 0x00F0 ) / 0x0010; - sal_uInt16 fRight = ( pPattern->Frame & 0x0F00 ) / 0x0100; - sal_uInt16 fBottom = ( pPattern->Frame & 0xF000 ) / 0x1000; - - if( fLeft > 1 ) - nLeft = 50; - else if( fLeft > 0 ) - nLeft = 20; - - if( fTop > 1 ) - nTop = 50; - else if( fTop > 0 ) - nTop = 20; - - if( fRight > 1 ) - nRight = 50; - else if( fRight > 0 ) - nRight = 20; - - if( fBottom > 1 ) - nBottom = 50; - else if( fBottom > 0 ) - nBottom = 20; - - Color ColorLeft( COL_BLACK ); - Color ColorTop( COL_BLACK ); - Color ColorRight( COL_BLACK ); - Color ColorBottom( COL_BLACK ); - - sal_uInt16 cLeft = ( pPattern->FrameColor & 0x000F ); - sal_uInt16 cTop = ( pPattern->FrameColor & 0x00F0 ) >> 4; - sal_uInt16 cRight = ( pPattern->FrameColor & 0x0F00 ) >> 8; - sal_uInt16 cBottom = ( pPattern->FrameColor & 0xF000 ) >> 12; - - lcl_ChangeColor( cLeft, ColorLeft ); - lcl_ChangeColor( cTop, ColorTop ); - lcl_ChangeColor( cRight, ColorRight ); - lcl_ChangeColor( cBottom, ColorBottom ); - - ::editeng::SvxBorderLine aLine; - SvxBoxItem aBox( ATTR_BORDER ); - - aLine.SetWidth( nLeft ); - aLine.SetColor( ColorLeft ); - aBox.SetLine( &aLine, SvxBoxItemLine::LEFT ); - aLine.SetWidth( nTop ); - aLine.SetColor( ColorTop ); - aBox.SetLine( &aLine, SvxBoxItemLine::TOP ); - aLine.SetWidth( nRight ); - aLine.SetColor( ColorRight ); - aBox.SetLine( &aLine, SvxBoxItemLine::RIGHT ); - aLine.SetWidth( nBottom ); - aLine.SetColor( ColorBottom ); - aBox.SetLine( &aLine, SvxBoxItemLine::BOTTOM ); - rItemSet.Put( aBox ); - } - } - // grid - if( ( pPattern->FormatFlags & pfRaster ) == pfRaster ) - { - if( pPattern->Raster != 0 ) - { - sal_uInt16 nBColor = ( pPattern->nColor & 0x00F0 ) >> 4; - sal_uInt16 nRColor = ( pPattern->nColor & 0x0F00 ) >> 8; - Color aBColor( COL_BLACK ); - - lcl_ChangeColor( nBColor, aBColor ); - - if( nBColor == 0 ) - aBColor.SetColor( COL_WHITE ); - else if( nBColor == 15 ) - aBColor.SetColor( COL_BLACK ); - - Color aRColor( COL_BLACK ); - lcl_ChangeColor( nRColor, aRColor ); - sal_uInt16 nFact; - bool bSwapCol = false; - bool bSetItem = true; - switch (pPattern->Raster) - { - case raNone: nFact = 0xffff; bSwapCol = true; bSetItem = (nBColor > 0); break; - case raGray12: nFact = (0xffff / 100) * 12; break; - case raGray25: nFact = (0xffff / 100) * 25; break; - case raGray50: nFact = (0xffff / 100) * 50; break; - case raGray75: nFact = (0xffff / 100) * 75; break; - default: nFact = 0xffff; bSetItem = (nRColor < 15); - } - if ( bSetItem ) - { - if( bSwapCol ) - rItemSet.Put( SvxBrushItem( GetMixedColor( aBColor, aRColor, nFact ), ATTR_BACKGROUND ) ); - else - rItemSet.Put( SvxBrushItem( GetMixedColor( aRColor, aBColor, nFact ), ATTR_BACKGROUND ) ); - } - } - } - // number formats - if( ( pPattern->ValueFormat.Format != 0 ) && - ( ( pPattern->FormatFlags & pfValue ) == pfValue ) ) - { - sal_uLong nKey = 0; - ChangeFormat( pPattern->ValueFormat.Format, pPattern->ValueFormat.Info, nKey ); - rItemSet.Put( SfxUInt32Item( ATTR_VALUE_FORMAT, ( sal_uInt32 ) nKey ) ); - } - - // cell attributes (protected, hidden...) - if( ( pPattern->Flags != 0 ) && - ( ( pPattern->FormatFlags & pfProtection ) == pfProtection ) ) - { - bool bProtect = ( ( pPattern->Flags & paProtect ) == paProtect ); - bool bHFormula = ( ( pPattern->Flags & paHideFormula ) == paHideFormula ); - bool bHCell = ( ( pPattern->Flags & paHideAll ) == paHideAll ); - bool bHPrint = ( ( pPattern->Flags & paHidePrint ) == paHidePrint ); - rItemSet.Put( ScProtectionAttr( bProtect, bHFormula, bHCell, bHPrint ) ); - } - } // if Style != 0 - } // for (i = 0; i < GetCount() -} - -void Sc10Import::LoadDataBaseCollection() -{ - pDataBaseCollection = new Sc10DataBaseCollection(rStream); - if (!nError) - nError = pDataBaseCollection->GetError(); - if (nError == errOutOfMemory) - return; // hopeless - for( sal_uInt16 i = 0 ; i < pDataBaseCollection->GetCount() ; i++ ) - { - Sc10DataBaseData* pOldData = pDataBaseCollection->At(i); - ScDBData* pNewData = new ScDBData( SC10TOSTRING( pOldData->DataBaseRec.Name ), - pOldData->DataBaseRec.Tab, - ( SCCOL ) pOldData->DataBaseRec.Block.x1, - ( SCROW ) pOldData->DataBaseRec.Block.y1, - ( SCCOL ) pOldData->DataBaseRec.Block.x2, - ( SCROW ) pOldData->DataBaseRec.Block.y2, - true, - (bool) pOldData->DataBaseRec.RowHeader ); - bool ins = pDoc->GetDBCollection()->getNamedDBs().insert(pNewData); - assert(ins); (void)ins; - //TODO: or can this fail (and need delete pNewData)? - } -} - -namespace -{ - sal_uInt16 ReadAndSanitizeDataCount(SvStream &rStream) - { - sal_uInt16 nDataCount(0); - rStream.ReadUInt16(nDataCount); - const size_t nMinRecordSize = sizeof(sal_uInt16)*2; - const size_t nMaxRecords = rStream.remainingSize() / nMinRecordSize; - if (nDataCount > nMaxRecords) - { - SAL_WARN("sc", "Parsing error: " << nMaxRecords << - " max possible entries, but " << nDataCount << " claimed, truncating"); - nDataCount = nMaxRecords; - } - return nDataCount; - } -} - -void Sc10Import::LoadTables() -{ - Sc10PageCollection aPageCollection; - - sal_Int16 nTabCount; - rStream.ReadInt16( nTabCount ); - for (sal_Int16 Tab = 0; (Tab < nTabCount) && (nError == ERRCODE_NONE); Tab++) - { - Sc10PageFormat PageFormat; - sal_Int16 DataBaseIndex; - Sc10TableProtect TabProtect; - sal_Int16 TabNo; - sal_Char TabName[128]; - sal_uInt16 Display; - sal_uInt8 Visible; - sal_uInt16 ID; - sal_uInt16 DataCount; - sal_uInt16 DataStart; - sal_uInt16 DataEnd; - sal_uInt16 DataValue; - sal_uInt16 Count; - sal_uInt16 i; - - lcl_ReadPageFormat(rStream, PageFormat); - - sal_uInt16 nAt = aPageCollection.InsertFormat(PageFormat); - OUString aPageName = lcl_MakeOldPageStyleFormatName( nAt ); - - pPrgrsBar->Progress(); - - rStream.ReadInt16( DataBaseIndex ); - - lcl_ReadTabProtect(rStream, TabProtect); - - ScTableProtection aProtection; - aProtection.setProtected(static_cast<bool>(TabProtect.Protect)); - aProtection.setPassword(SC10TOSTRING(TabProtect.PassWord)); - pDoc->SetTabProtection(static_cast<SCTAB>(Tab), &aProtection); - - rStream.ReadInt16( TabNo ); - - sal_uInt8 nLen; - rStream.ReadUChar( nLen ); - rStream.ReadBytes(TabName, sizeof(TabName) - 1); - if (nLen >= sizeof(TabName)) - nLen = sizeof(TabName) - 1; - TabName[nLen] = 0; - - rStream.ReadUInt16( Display ); - - if ( Tab == (sal_Int16)nShowTab ) - { - ScVObjMode eObjMode = VOBJ_MODE_SHOW; - - aSc30ViewOpt.SetOption( VOPT_FORMULAS, IS_SET(dfFormula,Display) ); - aSc30ViewOpt.SetOption( VOPT_NULLVALS, IS_SET(dfZerro,Display) ); - aSc30ViewOpt.SetOption( VOPT_SYNTAX, IS_SET(dfSyntax,Display) ); - aSc30ViewOpt.SetOption( VOPT_NOTES, IS_SET(dfNoteMark,Display) ); - aSc30ViewOpt.SetOption( VOPT_VSCROLL ); - aSc30ViewOpt.SetOption( VOPT_HSCROLL ); - aSc30ViewOpt.SetOption( VOPT_TABCONTROLS ); - aSc30ViewOpt.SetOption( VOPT_OUTLINER ); - aSc30ViewOpt.SetOption( VOPT_GRID, IS_SET(dfGrid,Display) ); - - // VOPT_HEADER is set in LoadViewColRowBar() - - if ( IS_SET(dfObjectAll,Display) ) // show objects - eObjMode = VOBJ_MODE_SHOW; - else if ( IS_SET(dfObjectFrame,Display) ) // object as placeholder - eObjMode = VOBJ_MODE_SHOW; - else if ( IS_SET(dfObjectNone,Display) ) // don't show objects - eObjMode = VOBJ_MODE_HIDE; - - aSc30ViewOpt.SetObjMode( VOBJ_TYPE_OLE, eObjMode ); - aSc30ViewOpt.SetObjMode( VOBJ_TYPE_CHART, eObjMode ); - aSc30ViewOpt.SetObjMode( VOBJ_TYPE_DRAW, eObjMode ); - } - - rStream.ReadUChar( Visible ); - - nError = rStream.GetError(); - if (nError != ERRCODE_NONE) return; - - if (TabNo == 0) - pDoc->RenameTab(static_cast<SCTAB> (TabNo), SC10TOSTRING( TabName )); - else - pDoc->InsertTab(SC_TAB_APPEND, SC10TOSTRING( TabName ) ); - - pDoc->SetPageStyle( static_cast<SCTAB>(Tab), aPageName ); - - if (Visible == 0) pDoc->SetVisible(static_cast<SCTAB> (TabNo), false); - - // ColWidth - rStream.ReadUInt16( ID ); - if (ID != ColWidthID) - { - OSL_FAIL( "ColWidthID" ); - nError = errUnknownID; - return; - } - DataCount = ReadAndSanitizeDataCount(rStream); - DataStart = 0; - for (i=0; i < DataCount; i++) - { - rStream.ReadUInt16( DataEnd ); - DataEnd = SanitizeCol(DataEnd); - rStream.ReadUInt16( DataValue ); - for (SCCOL j = static_cast<SCCOL>(DataStart); j <= static_cast<SCCOL>(DataEnd); j++) - pDoc->SetColWidth(j, static_cast<SCTAB> (TabNo), DataValue); - DataStart = DataEnd + 1; - } - pPrgrsBar->Progress(); - - // ColAttr - rStream.ReadUInt16( ID ); - if (ID != ColAttrID) - { - OSL_FAIL( "ColAttrID" ); - nError = errUnknownID; - return; - } - - DataCount = ReadAndSanitizeDataCount(rStream); - DataStart = 0; - for (i=0; i < DataCount; i++) - { - rStream.ReadUInt16( DataEnd ); - rStream.ReadUInt16( DataValue ); - if (DataValue != 0) - { - bool bPageBreak = ((DataValue & crfSoftBreak) == crfSoftBreak); - bool bManualBreak = ((DataValue & crfHardBreak) == crfHardBreak); - bool bHidden = ((DataValue & crfHidden) == crfHidden); - for (SCCOL k = SanitizeCol(static_cast<SCCOL>(DataStart)); k <= SanitizeCol(static_cast<SCCOL>(DataEnd)); k++) - { - pDoc->SetColHidden(k, k, static_cast<SCTAB>(TabNo), bHidden); - pDoc->SetColBreak(k, static_cast<SCTAB> (TabNo), bPageBreak, bManualBreak); - } - } - DataStart = DataEnd + 1; - } - pPrgrsBar->Progress(); - - // RowHeight - rStream.ReadUInt16( ID ); - if (ID != RowHeightID) - { - OSL_FAIL( "RowHeightID" ); - nError = errUnknownID; - return; - } - - DataCount = ReadAndSanitizeDataCount(rStream); - DataStart = 0; - for (i=0; i < DataCount; i++) - { - rStream.ReadUInt16( DataEnd ); - rStream.ReadUInt16( DataValue ); - pDoc->SetRowHeightRange(SanitizeRow(static_cast<SCROW>(DataStart)), - SanitizeRow(static_cast<SCROW>(DataEnd)), - static_cast<SCTAB> (TabNo), DataValue); - DataStart = DataEnd + 1; - } - pPrgrsBar->Progress(); - - // RowAttr - rStream.ReadUInt16( ID ); - if (ID != RowAttrID) - { - OSL_FAIL( "RowAttrID" ); - nError = errUnknownID; - return; - } - - DataCount = ReadAndSanitizeDataCount(rStream); - DataStart = 0; - for (i=0; i < DataCount; i++) - { - rStream.ReadUInt16( DataEnd ); - rStream.ReadUInt16( DataValue ); - if (DataValue != 0) - { - bool bPageBreak = ((DataValue & crfSoftBreak) == crfSoftBreak); - bool bManualBreak = ((DataValue & crfHardBreak) == crfHardBreak); - bool bHidden = ((DataValue & crfHidden) == crfHidden); - for (SCROW l = SanitizeRow(static_cast<SCROW>(DataStart)); l <= SanitizeRow(static_cast<SCROW>(DataEnd)); ++l) - { - pDoc->SetRowHidden(l, l, static_cast<SCTAB> (TabNo), bHidden); - pDoc->SetRowBreak(l, static_cast<SCTAB> (TabNo), bPageBreak, bManualBreak); - } - } - DataStart = DataEnd + 1; - } - pPrgrsBar->Progress(); - - // Data table - rStream.ReadUInt16( ID ); - if (ID != TableID) - { - OSL_FAIL( "TableID" ); - nError = errUnknownID; - return; - } - for (SCCOL Col = 0; (Col <= SC10MAXCOL) && (nError == ERRCODE_NONE); Col++) - { - rStream.ReadUInt16( Count ); - nError = rStream.GetError(); - if ((Count != 0) && (nError == ERRCODE_NONE)) - LoadCol(Col, static_cast<SCTAB> (TabNo)); - } - OSL_ENSURE( nError == ERRCODE_NONE, "Stream" ); - } - pPrgrsBar->Progress(); - - aPageCollection.PutToDoc( pDoc ); -} - -void Sc10Import::LoadCol(SCCOL Col, SCTAB Tab) -{ - LoadColAttr(Col, Tab); - - sal_uInt16 CellCount; - sal_uInt8 CellType; - sal_uInt16 Row; - rStream.ReadUInt16( CellCount ); - SCROW nScCount = static_cast< SCROW >( CellCount ); - if (nScCount > MAXROW) nError = errUnknownFormat; - for (sal_uInt16 i = 0; (i < CellCount) && (nError == ERRCODE_NONE); i++) - { - rStream.ReadUChar( CellType ); - rStream.ReadUInt16( Row ); - nError = rStream.GetError(); - if (nError == ERRCODE_NONE) - { - switch (CellType) - { - case ctValue : - { - const SfxPoolItem* pValueFormat = pDoc->GetAttr(Col, static_cast<SCROW> (Row), Tab, ATTR_VALUE_FORMAT); - sal_uLong nFormat = static_cast<const SfxUInt32Item*>(pValueFormat)->GetValue(); - double Value = ScfTools::ReadLongDouble(rStream); - //rStream.Read(&Value, sizeof(Value)); - - // TODO: adjustment is needed if we change the Basis Date - // StarCalc 1.0: 01.01.1900 - // if ((nFormat >= 30) && (nFormat <= 35)) - // Value += 0; - if ((nFormat >= 40) && (nFormat <= 45)) - Value /= 86400.0; - pDoc->SetValue(Col, static_cast<SCROW> (Row), Tab, Value); - break; - } - case ctString : - { - sal_uInt8 Len; - sal_Char s[256]; - rStream.ReadUChar( Len ); - rStream.ReadBytes(s, Len); - s[Len] = 0; - - pDoc->SetString( Col, static_cast<SCROW> (Row), Tab, SC10TOSTRING( s ) ); - break; - } - case ctFormula : - { - /*double Value =*/ ScfTools::ReadLongDouble(rStream); - sal_uInt8 Len; - sal_Char s[256+1]; - rStream.ReadUChar( Len ); - rStream.ReadBytes(&s[1], Len); - s[0] = '='; - s[Len + 1] = 0; - ScFormulaCell* pCell = new ScFormulaCell( pDoc, ScAddress( Col, static_cast<SCROW> (Row), Tab ) ); - pCell->SetHybridFormula( SC10TOSTRING( s ),formula::FormulaGrammar::GRAM_NATIVE ); - pDoc->EnsureTable(Tab); - pDoc->SetFormulaCell(ScAddress(Col,Row,Tab), pCell); - break; - } - case ctNote : - break; - default : - nError = errUnknownFormat; - break; - } - sal_uInt16 nNoteLen(0); - rStream.ReadUInt16(nNoteLen); - size_t nAvailable = rStream.remainingSize(); - if (nNoteLen > nAvailable) - nNoteLen = nAvailable; - if (nNoteLen != 0) - { - std::unique_ptr<sal_Char[]> xNote(new sal_Char[nNoteLen+1]); - nNoteLen = rStream.ReadBytes(xNote.get(), nNoteLen); - xNote[nNoteLen] = 0; - OUString aNoteText( SC10TOSTRING(xNote.get())); - xNote.reset(); - ScAddress aPos( Col, static_cast<SCROW>(Row), Tab ); - ScNoteUtil::CreateNoteFromString( *pDoc, aPos, aNoteText, false, false ); - } - } - pPrgrsBar->Progress(); - } -} - -void Sc10Import::LoadColAttr(SCCOL Col, SCTAB Tab) -{ - Sc10ColAttr aFont; - Sc10ColAttr aAttr; - Sc10ColAttr aJustify; - Sc10ColAttr aFrame; - Sc10ColAttr aRaster; - Sc10ColAttr aValue; - Sc10ColAttr aColor; - Sc10ColAttr aFrameColor; - Sc10ColAttr aFlag; - Sc10ColAttr aPattern; - - if (nError == ERRCODE_NONE) LoadAttr(aFont); - if (nError == ERRCODE_NONE) LoadAttr(aAttr); - if (nError == ERRCODE_NONE) LoadAttr(aJustify); - if (nError == ERRCODE_NONE) LoadAttr(aFrame); - if (nError == ERRCODE_NONE) LoadAttr(aRaster); - if (nError == ERRCODE_NONE) LoadAttr(aValue); - if (nError == ERRCODE_NONE) LoadAttr(aColor); - if (nError == ERRCODE_NONE) LoadAttr(aFrameColor); - if (nError == ERRCODE_NONE) LoadAttr(aFlag); - if (nError == ERRCODE_NONE) LoadAttr(aPattern); - - if (nError) - return; - - SCROW nStart; - sal_uInt16 i; - sal_uInt16 nLimit; - sal_uInt16 nValue1; - Sc10ColData *pColData; - - // Font (Name, Size) - nStart = 0; - nLimit = aFont.Count; - pColData = aFont.pData.get(); - for( i = 0 ; i < nLimit ; i++, pColData++ ) - { - SCROW nEnd = static_cast<SCROW>(pColData->Row); - if ((nStart <= nEnd) && (pColData->Value)) - { - FontFamily eFam = FAMILY_DONTKNOW; - Sc10FontData* pFont = pFontCollection->At(pColData->Value); - if (pFont) - { - switch (pFont->PitchAndFamily & 0xF0) - { - case ffDontCare : eFam = FAMILY_DONTKNOW; break; - case ffRoman : eFam = FAMILY_ROMAN; break; - case ffSwiss : eFam = FAMILY_SWISS; break; - case ffModern : eFam = FAMILY_MODERN; break; - case ffScript : eFam = FAMILY_SCRIPT; break; - case ffDecorative : eFam = FAMILY_DECORATIVE; break; - default: eFam = FAMILY_DONTKNOW; break; - } - ScPatternAttr aScPattern(pDoc->GetPool()); - aScPattern.GetItemSet().Put(SvxFontItem(eFam, SC10TOSTRING( pFont->FaceName ), EMPTY_OUSTRING, - PITCH_DONTKNOW, RTL_TEXTENCODING_DONTKNOW, ATTR_FONT )); - aScPattern.GetItemSet().Put(SvxFontHeightItem(std::abs(pFont->Height), 100, ATTR_FONT_HEIGHT )); - pDoc->ApplyPatternAreaTab(Col, nStart, Col, nEnd, Tab, aScPattern); - } - } - nStart = nEnd + 1; - } - - // Font color - nStart = 0; - nLimit = aColor.Count; - pColData = aColor.pData.get(); - for( i = 0 ; i < nLimit ; i++, pColData++ ) - { - SCROW nEnd = static_cast<SCROW>(pColData->Row); - if ((nStart <= nEnd) && (pColData->Value)) - { - Color TextColor(COL_BLACK); - lcl_ChangeColor((pColData->Value & 0x000F), TextColor); - ScPatternAttr aScPattern(pDoc->GetPool()); - aScPattern.GetItemSet().Put(SvxColorItem(TextColor, ATTR_FONT_COLOR )); - pDoc->ApplyPatternAreaTab(Col, nStart, Col, nEnd, Tab, aScPattern); - } - nStart = nEnd + 1; - } - - // Font attributes (Bold, Italic...) - nStart = 0; - nLimit = aAttr.Count; - pColData = aAttr.pData.get(); - for( i = 0 ; i < nLimit ; i++, pColData++ ) - { - SCROW nEnd = static_cast<SCROW>(pColData->Row); - nValue1 = pColData->Value; - if ((nStart <= nEnd) && nValue1) - { - ScPatternAttr aScPattern(pDoc->GetPool()); - if ((nValue1 & atBold) == atBold) - aScPattern.GetItemSet().Put(SvxWeightItem(WEIGHT_BOLD, ATTR_FONT_WEIGHT)); - if ((nValue1 & atItalic) == atItalic) - aScPattern.GetItemSet().Put(SvxPostureItem(ITALIC_NORMAL, ATTR_FONT_POSTURE)); - if ((nValue1 & atUnderline) == atUnderline) - aScPattern.GetItemSet().Put(SvxUnderlineItem(LINESTYLE_SINGLE, ATTR_FONT_UNDERLINE)); - if ((nValue1 & atStrikeOut) == atStrikeOut) - aScPattern.GetItemSet().Put(SvxCrossedOutItem(STRIKEOUT_SINGLE, ATTR_FONT_CROSSEDOUT)); - pDoc->ApplyPatternAreaTab(Col, nStart, Col, nEnd, Tab, aScPattern); - } - nStart = nEnd + 1; - } - - // Cell alignment - nStart = 0; - nLimit = aJustify.Count; - pColData = aJustify.pData.get(); - for( i = 0 ; i < nLimit ; i++, pColData++ ) - { - SCROW nEnd = static_cast<SCROW>(pColData->Row); - nValue1 = pColData->Value; - if ((nStart <= nEnd) && nValue1) - { - ScPatternAttr aScPattern(pDoc->GetPool()); - sal_uInt16 HorJustify = (nValue1 & 0x000F); - sal_uInt16 VerJustify = (nValue1 & 0x00F0) >> 4; - sal_uInt16 OJustify = (nValue1 & 0x0F00) >> 8; - sal_uInt16 EJustify = (nValue1 & 0xF000) >> 12; - - switch (HorJustify) - { - case hjLeft: - aScPattern.GetItemSet().Put(SvxHorJustifyItem(SvxCellHorJustify::Left, ATTR_HOR_JUSTIFY)); - break; - case hjCenter: - aScPattern.GetItemSet().Put(SvxHorJustifyItem(SvxCellHorJustify::Center, ATTR_HOR_JUSTIFY)); - break; - case hjRight: - aScPattern.GetItemSet().Put(SvxHorJustifyItem(SvxCellHorJustify::Right, ATTR_HOR_JUSTIFY)); - break; - } - - switch (VerJustify) - { - case vjTop: - aScPattern.GetItemSet().Put(SvxVerJustifyItem(SvxCellVerJustify::Top, ATTR_VER_JUSTIFY)); - break; - case vjCenter: - aScPattern.GetItemSet().Put(SvxVerJustifyItem(SvxCellVerJustify::Center, ATTR_VER_JUSTIFY)); - break; - case vjBottom: - aScPattern.GetItemSet().Put(SvxVerJustifyItem(SvxCellVerJustify::Bottom, ATTR_VER_JUSTIFY)); - break; - } - - if (OJustify & ojWordBreak) - aScPattern.GetItemSet().Put(SfxBoolItem(ATTR_LINEBREAK, true)); - if (OJustify & ojBottomTop) - aScPattern.GetItemSet().Put(SfxInt32Item(ATTR_ROTATE_VALUE,9000)); - else if (OJustify & ojTopBottom) - aScPattern.GetItemSet().Put(SfxInt32Item(ATTR_ROTATE_VALUE,27000)); - - sal_Int16 Margin = std::max((sal_uInt16)20, (sal_uInt16)(EJustify * 20)); - if (OJustify & ojBottomTop) - aScPattern.GetItemSet().Put(SvxMarginItem(20, Margin, 20, Margin, ATTR_MARGIN)); - else - aScPattern.GetItemSet().Put(SvxMarginItem(Margin, 20, Margin, 20, ATTR_MARGIN)); - pDoc->ApplyPatternAreaTab(Col, nStart, Col, nEnd, Tab, aScPattern); - } - nStart = nEnd + 1; - } - // Border - bool bEnd = false; - sal_uInt16 nColorIndex = 0; - sal_uInt16 nFrameIndex = 0; - - // Special Fix... - const sal_uInt32 nHelpMeStart = 100; - sal_uInt32 nHelpMe = nHelpMeStart; - sal_uInt16 nColorIndexOld = nColorIndex; - sal_uInt16 nFrameIndexOld = nColorIndex; - - nStart = 0; - while( !bEnd && nHelpMe ) - { - SCROW nEnd = 0; - pColData = &aFrame.pData[ nFrameIndex ]; - - sal_uInt16 nValue = pColData->Value; - sal_uInt16 nLeft = 0; - sal_uInt16 nTop = 0; - sal_uInt16 nRight = 0; - sal_uInt16 nBottom = 0; - sal_uInt16 fLeft = ( nValue & 0x000F ); - sal_uInt16 fTop = ( nValue & 0x00F0 ) >> 4; - sal_uInt16 fRight = ( nValue & 0x0F00 ) >> 8; - sal_uInt16 fBottom = ( nValue & 0xF000 ) >> 12; - - if( fLeft > 1 ) - nLeft = 50; - else if( fLeft > 0 ) - nLeft = 20; - - if( fTop > 1 ) - nTop = 50; - else if( fTop > 0 ) - nTop = 20; - - if( fRight > 1 ) - nRight = 50; - else if( fRight > 0 ) - nRight = 20; - - if( fBottom > 1 ) - nBottom = 50; - else if( fBottom > 0 ) - nBottom = 20; - - Color ColorLeft( COL_BLACK ); - Color ColorTop( COL_BLACK ); - Color ColorRight( COL_BLACK ); - Color ColorBottom( COL_BLACK ); - sal_uInt16 nFrmColVal = aFrameColor.pData[ nColorIndex ].Value; - SCROW nFrmColRow = static_cast<SCROW>(aFrameColor.pData[ nColorIndex ].Row); - sal_uInt16 cLeft = ( nFrmColVal & 0x000F ); - sal_uInt16 cTop = ( nFrmColVal & 0x00F0 ) >> 4; - sal_uInt16 cRight = ( nFrmColVal & 0x0F00 ) >> 8; - sal_uInt16 cBottom = ( nFrmColVal & 0xF000 ) >> 12; - - lcl_ChangeColor( cLeft, ColorLeft ); - lcl_ChangeColor( cTop, ColorTop ); - lcl_ChangeColor( cRight, ColorRight ); - lcl_ChangeColor( cBottom, ColorBottom ); - - if( static_cast<SCROW>(pColData->Row) < nFrmColRow ) - { - nEnd = static_cast<SCROW>(pColData->Row); - if( nFrameIndex < ( aFrame.Count - 1 ) ) - nFrameIndex++; - } - else if( static_cast<SCROW>(pColData->Row) > nFrmColRow ) - { - nEnd = static_cast<SCROW>(aFrameColor.pData[ nColorIndex ].Row); - if( nColorIndex < ( aFrameColor.Count - 1 ) ) - nColorIndex++; - } - else - { - nEnd = nFrmColRow; - if( nFrameIndex < (aFrame.Count - 1 ) ) - nFrameIndex++; - if( nColorIndex < ( aFrameColor.Count - 1 ) ) - nColorIndex++; - } - if( ( nStart <= nEnd ) && ( nValue != 0 ) ) - { - ScPatternAttr aScPattern(pDoc->GetPool()); - ::editeng::SvxBorderLine aLine; - SvxBoxItem aBox( ATTR_BORDER ); - - aLine.SetWidth( nLeft ); - aLine.SetColor( ColorLeft ); - aBox.SetLine( &aLine, SvxBoxItemLine::LEFT ); - - aLine.SetWidth( nTop ); - aLine.SetColor( ColorTop ); - aBox.SetLine( &aLine, SvxBoxItemLine::TOP ); - - aLine.SetWidth( nRight ); - aLine.SetColor( ColorRight ); - aBox.SetLine( &aLine, SvxBoxItemLine::RIGHT ); - - aLine.SetWidth( nBottom ); - aLine.SetColor( ColorBottom ); - aBox.SetLine( &aLine, SvxBoxItemLine::BOTTOM ); - - aScPattern.GetItemSet().Put( aBox ); - pDoc->ApplyPatternAreaTab( Col, nStart, Col, nEnd, Tab, aScPattern ); - } - nStart = nEnd + 1; - - bEnd = ( nFrameIndex == ( aFrame.Count - 1 ) ) && ( nColorIndex == ( aFrameColor.Count - 1 ) ); - - if( nColorIndexOld != nColorIndex || nFrameIndexOld != nFrameIndex ) - { - nColorIndexOld = nColorIndex; - nFrameIndexOld = nFrameIndex; - nHelpMe = nHelpMeStart; - } - else - nHelpMe--; - - pColData++; - } - - // TODO: Code up to here works more or less ... from here I've had enough ! (GT) - - // Background (Color, Raster) - sal_uInt16 nRasterIndex = 0; - bEnd = false; - nColorIndex = 0; - nStart = 0; - - // Special Fix... - nHelpMe = nHelpMeStart; - sal_uInt16 nRasterIndexOld = nRasterIndex; - - while( !bEnd && nHelpMe ) - { - SCROW nEnd = 0; - sal_uInt16 nBColor = ( aColor.pData[ nColorIndex ].Value & 0x00F0 ) >> 4; - sal_uInt16 nRColor = ( aColor.pData[ nColorIndex ].Value & 0x0F00 ) >> 8; - Color aBColor( COL_BLACK ); - - lcl_ChangeColor( nBColor, aBColor ); - - if( nBColor == 0 ) - aBColor.SetColor( COL_WHITE ); - else if( nBColor == 15 ) - aBColor.SetColor( COL_BLACK ); - - Color aRColor( COL_BLACK ); - - lcl_ChangeColor( nRColor, aRColor ); - - ScPatternAttr aScPattern( pDoc->GetPool() ); - - sal_uInt16 nFact; - bool bSwapCol = false; - bool bSetItem = true; - switch ( aRaster.pData[ nRasterIndex ].Value ) - { - case raNone: nFact = 0xffff; bSwapCol = true; bSetItem = (nBColor > 0); break; - case raGray12: nFact = (0xffff / 100) * 12; break; - case raGray25: nFact = (0xffff / 100) * 25; break; - case raGray50: nFact = (0xffff / 100) * 50; break; - case raGray75: nFact = (0xffff / 100) * 75; break; - default: nFact = 0xffff; bSetItem = (nRColor < 15); - } - if ( bSetItem ) - { - if( bSwapCol ) - aScPattern.GetItemSet().Put( SvxBrushItem( GetMixedColor( aBColor, aRColor, nFact ), ATTR_BACKGROUND ) ); - else - aScPattern.GetItemSet().Put( SvxBrushItem( GetMixedColor( aRColor, aBColor, nFact ), ATTR_BACKGROUND ) ); - } - if( aRaster.pData[ nRasterIndex ].Row < aColor.pData[ nColorIndex ].Row ) - { - nEnd = static_cast<SCROW>(aRaster.pData[ nRasterIndex ].Row); - if( nRasterIndex < ( aRaster.Count - 1 ) ) - nRasterIndex++; - } - else if( aRaster.pData[ nRasterIndex ].Row > aColor.pData[ nColorIndex ].Row ) - { - nEnd = static_cast<SCROW>(aColor.pData[ nColorIndex ].Row); - if( nColorIndex < ( aColor.Count - 1 ) ) - nColorIndex++; - } - else - { - nEnd = static_cast<SCROW>(aColor.pData[ nColorIndex ].Row); - if( nRasterIndex < ( aRaster.Count - 1 ) ) - nRasterIndex++; - if( nColorIndex < ( aColor.Count - 1 ) ) - nColorIndex++; - } - if( nStart <= nEnd ) - pDoc->ApplyPatternAreaTab( Col, nStart, Col, nEnd, Tab, aScPattern ); - - nStart = nEnd + 1; - - bEnd = ( nRasterIndex == ( aRaster.Count - 1 ) ) && ( nColorIndex == ( aColor.Count - 1 ) ); - - if( nColorIndexOld != nColorIndex || nRasterIndexOld != nRasterIndex ) - { - nColorIndexOld = nColorIndex; - nRasterIndexOld = nRasterIndex; - nHelpMe = nHelpMeStart; - } - else - nHelpMe--; - - nHelpMe--; - } - - // Number format - nStart = 0; - nLimit = aValue.Count; - pColData = aValue.pData.get(); - for (i=0; i<nLimit; i++, pColData++) - { - SCROW nEnd = static_cast<SCROW>(pColData->Row); - nValue1 = pColData->Value; - if ((nStart <= nEnd) && nValue1) - { - sal_uLong nKey = 0; - sal_uInt16 nFormat = (nValue1 & 0x00FF); - sal_uInt16 nInfo = (nValue1 & 0xFF00) >> 8; - ChangeFormat(nFormat, nInfo, nKey); - ScPatternAttr aScPattern(pDoc->GetPool()); - aScPattern.GetItemSet().Put(SfxUInt32Item(ATTR_VALUE_FORMAT, (sal_uInt32)nKey)); - pDoc->ApplyPatternAreaTab(Col, nStart, Col, nEnd, Tab, aScPattern); - } - nStart = nEnd + 1; - } - - // Cell attributes (protected, hidden...) - nStart = 0; - for (i=0; i<aFlag.Count; i++) - { - SCROW nEnd = static_cast<SCROW>(aFlag.pData[i].Row); - if ((nStart <= nEnd) && (aFlag.pData[i].Value != 0)) - { - bool bProtect = ((aFlag.pData[i].Value & paProtect) == paProtect); - bool bHFormula = ((aFlag.pData[i].Value & paHideFormula) == paHideFormula); - bool bHCell = ((aFlag.pData[i].Value & paHideAll) == paHideAll); - bool bHPrint = ((aFlag.pData[i].Value & paHidePrint) == paHidePrint); - ScPatternAttr aScPattern(pDoc->GetPool()); - aScPattern.GetItemSet().Put(ScProtectionAttr(bProtect, bHFormula, bHCell, bHPrint)); - pDoc->ApplyPatternAreaTab(Col, nStart, Col, nEnd, Tab, aScPattern); - } - nStart = nEnd + 1; - } - - // Cell style - nStart = 0; - ScStyleSheetPool* pStylePool = pDoc->GetStyleSheetPool(); - for (i=0; i<aPattern.Count; i++) - { - SCROW nEnd = static_cast<SCROW>(aPattern.pData[i].Row); - if ((nStart <= nEnd) && (aPattern.pData[i].Value != 0)) - { - sal_uInt16 nPatternIndex = (aPattern.pData[i].Value & 0x00FF) - 1; - Sc10PatternData* pPattern = pPatternCollection->At(nPatternIndex); - if (pPattern != nullptr) - { - ScStyleSheet* pStyle = static_cast<ScStyleSheet*>( pStylePool->Find( - SC10TOSTRING( pPattern->Name ), SfxStyleFamily::Para) ); - - if (pStyle != nullptr) - pDoc->ApplyStyleAreaTab(Col, nStart, Col, nEnd, Tab, *pStyle); - } - } - nStart = nEnd + 1; - } -} - -void Sc10Import::LoadAttr(Sc10ColAttr& rAttr) -{ - // rAttr is not reused, otherwise we'd have to delete [] rAttr.pData; - rStream.ReadUInt16(rAttr.Count); - - const size_t nMaxEntries = rStream.remainingSize() / (sizeof(sal_uInt16) * 2); - if (rAttr.Count > nMaxEntries) - rAttr.Count = nMaxEntries; - - if (!rAttr.Count) - return; - - rAttr.pData.reset( new (::std::nothrow) Sc10ColData[rAttr.Count] ); - if (rAttr.pData == nullptr) - { - nError = errOutOfMemory; - rAttr.Count = 0; - return; - } - - for (sal_uInt16 i = 0; i < rAttr.Count; ++i) - { - rStream.ReadUInt16( rAttr.pData[i].Row ); - rStream.ReadUInt16( rAttr.pData[i].Value ); - } - - nError = rStream.GetError(); -} - -void Sc10Import::ChangeFormat(sal_uInt16 nFormat, sal_uInt16 nInfo, sal_uLong& nKey) -{ - // TODO: formats are mapped only for StarCalc 3.0 internal formats - // more correctly, at times new formats need to be created (Stephan: please check!) - nKey = 0; - switch (nFormat) - { - case vfStandard : - if (nInfo > 0) - nKey = 2; - break; - case vfMoney : - if (nInfo > 0) - nKey = 21; - else - nKey = 20; - break; - case vfThousend : - if (nInfo > 0) - nKey = 4; - else - nKey = 5; - break; - case vfPercent : - if (nInfo > 0) - nKey = 11; - else - nKey = 10; - break; - case vfExponent : - nKey = 60; - break; - case vfZerro : - // TODO: no equivalent - break; - case vfDate : - switch (nInfo) - { - case df_NDMY_Long : - nKey = 31; - break; - case df_DMY_Long : - nKey = 30; - break; - case df_MY_Long : - nKey = 32; - break; - case df_NDM_Long : - nKey = 31; - break; - case df_DM_Long : - nKey = 33; - break; - case df_M_Long : - nKey = 34; - break; - case df_NDMY_Short : - nKey = 31; - break; - case df_DMY_Short : - nKey = 30; - break; - case df_MY_Short : - nKey = 32; - break; - case df_NDM_Short : - nKey = 31; - break; - case df_DM_Short : - nKey = 33; - break; - case df_M_Short : - nKey = 34; - break; - case df_Q_Long : - nKey = 35; - break; - case df_Q_Short : - nKey = 35; - break; - default : - nKey = 30; - break; - } - break; - case vfTime : - switch (nInfo) - { - case tf_HMS_Long : - nKey = 41; - break; - case tf_HM_Long : - nKey = 40; - break; - case tf_HMS_Short : - nKey = 43; - break; - case tf_HM_Short : - nKey = 42; - break; - default : - nKey = 41; - break; - } - break; - case vfBoolean : - nKey = 99; - break; - case vfStandardRed : - if (nInfo > 0) - nKey = 2; - break; - case vfMoneyRed : - if (nInfo > 0) - nKey = 23; - else - nKey = 22; - break; - case vfThousendRed : - if (nInfo > 0) - nKey = 4; - else - nKey = 5; - break; - case vfPercentRed : - if (nInfo > 0) - nKey = 11; - else - nKey = 10; - break; - case vfExponentRed : - nKey = 60; - break; - case vfFormula : - break; - case vfString : - break; - default : - break; - } -} - -void Sc10Import::LoadObjects() -{ - sal_uInt16 ID; - rStream.ReadUInt16( ID ); - if (rStream.IsEof()) - return; - if (ID == ObjectID) - { - sal_uInt16 nCnt; - rStream.ReadUInt16( nCnt ); - sal_Char Reserved[32]; - rStream.ReadBytes(Reserved, sizeof(Reserved)); - nError = rStream.GetError(); - if ((nCnt > 0) && (nError == ERRCODE_NONE)) - { - sal_uInt8 ObjectType; - Sc10GraphHeader GraphHeader; - bool IsOleObject = false; // TODO: this is only a band-aid - for (sal_uInt16 i = 0; (i < nCnt) && (nError == ERRCODE_NONE) && !rStream.IsEof() && !IsOleObject; i++) - { - rStream.ReadUChar( ObjectType ); - lcl_ReadGraphHeader(rStream, GraphHeader); - - double nPPTX = ScGlobal::nScreenPPTX; - double nPPTY = ScGlobal::nScreenPPTY; - - long nStartX = 0; - SCCOL nMaxCol = SanitizeCol(GraphHeader.CarretX); - for (SCCOL nX = 0; nX < nMaxCol; ++nX) - nStartX += pDoc->GetColWidth(nX, static_cast<SCTAB>(GraphHeader.CarretZ)); - nStartX = (long) ( nStartX * HMM_PER_TWIPS ); - nStartX += (long) ( GraphHeader.x / nPPTX * HMM_PER_TWIPS ); - long nSizeX = (long) ( GraphHeader.w / nPPTX * HMM_PER_TWIPS ); - long nStartY = pDoc->GetRowHeight( 0, - SanitizeRow(static_cast<SCROW>(GraphHeader.CarretY) - 1), - SanitizeTab(static_cast<SCTAB>(GraphHeader.CarretZ))); - nStartY = (long) ( nStartY * HMM_PER_TWIPS ); - nStartY += (long) ( GraphHeader.y / nPPTY * HMM_PER_TWIPS ); - long nSizeY = (long) ( GraphHeader.h / nPPTY * HMM_PER_TWIPS ); - - switch (ObjectType) - { - case otOle : - // TODO: here we need to do something like OleLoadFromStream - IsOleObject = true; - break; - case otImage : - { - Sc10ImageHeader ImageHeader; - lcl_ReadImageHeaer(rStream, ImageHeader); - - // Attention: here come the data (Bitmap or Metafile) - // Typ = 1 Device-dependent Bitmap DIB - // Typ = 2 MetaFile - rStream.SeekRel(ImageHeader.Size); - - if( ImageHeader.Typ != 1 && ImageHeader.Typ != 2 ) - nError = errUnknownFormat; - break; - } - case otChart : - { - Sc10ChartHeader ChartHeader; - Sc10ChartSheetData ChartSheetData; - Sc10ChartTypeData* pTypeData = new (::std::nothrow) Sc10ChartTypeData; - if (!pTypeData) - nError = errOutOfMemory; - else - { - lcl_ReadChartHeader(rStream, ChartHeader); - - // TODO: use old Metafile ?? - rStream.SeekRel(ChartHeader.Size); - - lcl_ReadChartSheetData(rStream, ChartSheetData); - - lcl_ReadChartTypeData(rStream, *pTypeData); - - tools::Rectangle aRect( Point(nStartX,nStartY), Size(nSizeX,nSizeY) ); - Sc10InsertObject::InsertChart( pDoc, static_cast<SCTAB>(GraphHeader.CarretZ), aRect, - static_cast<SCTAB>(GraphHeader.CarretZ), - ChartSheetData.DataX1, ChartSheetData.DataY1, - ChartSheetData.DataX2, ChartSheetData.DataY2 ); - - delete pTypeData; - } - break; - } - default : - nError = errUnknownFormat; - break; - } - nError = rStream.GetError(); - } - } - } - else - { - OSL_FAIL( "ObjectID" ); - nError = errUnknownID; - } -} - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sc/source/filter/starcalc/scflt.hxx b/sc/source/filter/starcalc/scflt.hxx deleted file mode 100644 index 5cc363faa242..000000000000 --- a/sc/source/filter/starcalc/scflt.hxx +++ /dev/null @@ -1,791 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/* - * This file is part of the LibreOffice project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - * - * This file incorporates work covered by the following license notice: - * - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed - * with this work for additional information regarding copyright - * ownership. The ASF licenses this file to you under the Apache - * License, Version 2.0 (the "License"); you may not use this file - * except in compliance with the License. You may obtain a copy of - * the License at http://www.apache.org/licenses/LICENSE-2.0 . - */ - -#ifndef INCLUDED_SC_SOURCE_FILTER_STARCALC_SCFLT_HXX -#define INCLUDED_SC_SOURCE_FILTER_STARCALC_SCFLT_HXX - -#include <memory> -#include <viewopti.hxx> -#include "collect.hxx" -#include <tools/solar.h> - -// Error numbers -#define errUnknownFormat ErrCode(1) -#define errUnknownID ErrCode(2) -#define errOutOfMemory ErrCode(3) - -// Identifiers in FileFormat -#define ColWidthID 1 -#define ColAttrID 2 -#define RowHeightID 3 -#define RowAttrID 4 -#define FontID 5 -#define NameID 6 -#define TableID 7 -#define ObjectID 8 -#define PatternID 9 -#define DataBaseID 10 - -// Row/Column Flags -#define crfSoftBreak 1 -#define crfHardBreak 2 -#define crfHidden 4 - -// Cell types -#define ctValue 1 -#define ctString 2 -#define ctFormula 3 -#define ctNote 4 - -// Font Styles -#define ffDontCare 0x00 -#define ffRoman 0x10 -#define ffSwiss 0x20 -#define ffModern 0x30 -#define ffScript 0x40 -#define ffDecorative 0x50 - -// Font Weight -#define fwNormal 400 - -// Font attributes -#define atNone 0 -#define atBold 1 -#define atItalic 2 -#define atUnderline 4 -#define atStrikeOut 8 - -// Horizontal alignment -#define hjLeft 1 -#define hjCenter 2 -#define hjRight 3 - -// Vertical alignment -#define vjTop 1 -#define vjCenter 2 -#define vjBottom 3 - -// Alignment flags -#define ojWordBreak 0x01 -#define ojBottomTop 0x02 -#define ojTopBottom 0x04 - -// Cell grid -#define raNone 0 -#define raGray12 1 -#define raGray25 2 -#define raGray50 3 -#define raGray75 4 - -// Cell protection -#define paProtect 1 -#define paHideFormula 2 -#define paHideAll 4 -#define paHidePrint 8 - -// Number format flags -#define vfStandard 0 -#define vfMoney 1 -#define vfThousend 2 -#define vfPercent 3 -#define vfExponent 4 -#define vfZerro 5 -#define vfDate 6 -#define vfTime 7 -#define vfBoolean 8 -#define vfStandardRed 9 -#define vfMoneyRed 10 -#define vfThousendRed 11 -#define vfPercentRed 12 -#define vfExponentRed 13 -#define vfFormula 14 -#define vfString 15 - -// Date format flags -#define df_NDMY_Long 0 -#define df_DMY_Long 1 -#define df_MY_Long 2 -#define df_NDM_Long 3 -#define df_DM_Long 4 -#define df_M_Long 5 -#define df_NDMY_Short 6 -#define df_DMY_Short 7 -#define df_MY_Short 8 -#define df_NDM_Short 9 -#define df_DM_Short 10 -#define df_M_Short 11 -#define df_Q_Long 12 -#define df_Q_Short 13 - -// Time format flags -#define tf_HMS_Long 0 -#define tf_HM_Long 1 -#define tf_HMS_Short 2 -#define tf_HM_Short 3 - -// Attributes for format template -#define pfValue 0x01 -#define pfFont 0x02 -#define pfJustify 0x04 -#define pfFrame 0x08 -#define pfRaster 0x10 -#define pfProtection 0x20 - -// Display flags for table -#define dfFormula 0x0001 // formula -#define dfZerro 0x0002 // zero values -#define dfGrid 0x0004 // grid -#define dfSyntax 0x0020 // Syntax Highlighting -#define dfObjectAll 0x0080 // show objects -#define dfObjectFrame 0x0100 // objects as place holder -#define dfObjectNone 0x0200 // do not show objects -#define dfNoteMark 0x0400 // NoteMark - -// Object types -#define otOle 1 -#define otImage 2 -#define otChart 3 - -// Date/Time -struct Sc10DateTime -{ - sal_uInt16 Year; - sal_uInt16 Month; - sal_uInt16 Day; - sal_uInt16 Hour; - sal_uInt16 Min; - sal_uInt16 Sec; -}; - -// Number formats -struct Sc10ValueFormat -{ - sal_uInt8 Format; // number, currency, percentage,... - sal_uInt8 Info; // number of decimals, or positions, or Date/Time format - Sc10ValueFormat() - : Format(0) - , Info(0) - { - } -}; - -// Font definition -struct Sc10LogFont -{ - sal_Int16 lfHeight; - sal_Int16 lfWidth; - sal_Int16 lfEscapement; - sal_Int16 lfOrientation; - sal_Int16 lfWeight; - sal_uInt8 lfItalic; - sal_uInt8 lfUnderline; - sal_uInt8 lfStrikeOut; - sal_uInt8 lfCharSet; - sal_uInt8 lfOutPrecision; - sal_uInt8 lfClipPrecision; - sal_uInt8 lfQuality; - sal_uInt8 lfPitchAndFamily; - sal_Char lfFaceName[32]; - - Sc10LogFont() - : lfHeight(0) - , lfWidth(0) - , lfEscapement(0) - , lfOrientation(0) - , lfWeight(0) - , lfItalic(0) - , lfUnderline(0) - , lfStrikeOut(0) - , lfCharSet(0) - , lfOutPrecision(0) - , lfClipPrecision(0) - , lfQuality(0) - , lfPitchAndFamily(0) - { - memset(lfFaceName, 0, sizeof(lfFaceName)); - } - - bool operator==( const Sc10LogFont& rData ) const; -}; - -// RGB-Color values -struct Sc10Color -{ - sal_uInt8 Dummy; - sal_uInt8 Blue; - sal_uInt8 Green; - sal_uInt8 Red; - bool operator==( const Sc10Color& rColor ) const; - Sc10Color() - : Dummy(0) - , Blue(0) - , Green(0) - , Red(0) - { - } -}; - -// Block definition -struct Sc10BlockRect -{ - sal_Int16 x1; - sal_Int16 y1; - sal_Int16 x2; - sal_Int16 y2; - Sc10BlockRect() - : x1(0) - , y1(0) - , x2(0) - , y2(0) - { - } -}; - -// Data range -struct Sc10DataBaseRec -{ - sal_Char Name[32]; - SCTAB Tab; - Sc10BlockRect Block; - sal_uInt8 RowHeader; - sal_Int16 SortField0; - sal_uInt8 SortUpOrder0; - sal_Int16 SortField1; - sal_uInt8 SortUpOrder1; - sal_Int16 SortField2; - sal_uInt8 SortUpOrder2; - sal_uInt8 IncludeFormat; - sal_Int16 QueryField0; - sal_Int16 QueryOp0; - sal_uInt8 QueryByString0; - sal_Char QueryString0[64]; - double QueryValue0; - sal_Int16 QueryConnect1; - sal_Int16 QueryField1; - sal_Int16 QueryOp1; - sal_uInt8 QueryByString1; - sal_Char QueryString1[64]; - double QueryValue1; - sal_Int16 QueryConnect2; - sal_Int16 QueryField2; - sal_Int16 QueryOp2; - sal_uInt8 QueryByString2; - sal_Char QueryString2[64]; - double QueryValue2; - Sc10DataBaseRec() - : Tab(0) - , RowHeader(0) - , SortField0(0) - , SortUpOrder0(0) - , SortField1(0) - , SortUpOrder1(0) - , SortField2(0) - , SortUpOrder2(0) - , IncludeFormat(0) - , QueryField0(0) - , QueryOp0(0) - , QueryByString0(0) - , QueryValue0(0.0) - , QueryConnect1(0) - , QueryField1(0) - , QueryOp1(0) - , QueryByString1(0) - , QueryValue1(0.0) - , QueryConnect2(0) - , QueryField2(0) - , QueryOp2(0) - , QueryByString2(0) - , QueryValue2(0.0) - { - memset(Name, 0, sizeof(Name)); - memset(QueryString0, 0, sizeof(QueryString0)); - memset(QueryString1, 0, sizeof(QueryString1)); - memset(QueryString2, 0, sizeof(QueryString2)); - } -}; - -// Header/Footer -struct Sc10HeadFootLine -{ - sal_Char Title[128]; - Sc10LogFont LogFont; - sal_uInt8 HorJustify; - sal_uInt8 VerJustify; - sal_uInt16 Raster; - sal_uInt16 Frame; - Sc10Color TextColor; - Sc10Color BackColor; - Sc10Color RasterColor; - sal_uInt16 FrameColor; // Nibble coded colors left-top right-bottom - sal_uInt16 Reserved; - - bool operator==( const Sc10HeadFootLine& rData ) const; -}; - -// page format -struct Sc10PageFormat -{ - Sc10HeadFootLine HeadLine; - Sc10HeadFootLine FootLine; - sal_Int16 Orientation; - sal_Int16 Width; - sal_Int16 Height; - sal_Int16 NonPrintableX; - sal_Int16 NonPrintableY; - sal_Int16 Left; - sal_Int16 Top; - sal_Int16 Right; - sal_Int16 Bottom; - sal_Int16 Head; - sal_Int16 Foot; - sal_uInt8 HorCenter; - sal_uInt8 VerCenter; - sal_uInt8 PrintGrid; - sal_uInt8 PrintColRow; - sal_uInt8 PrintNote; - sal_uInt8 TopBottomDir; - sal_Char PrintAreaName[32]; - Sc10BlockRect PrintArea; - sal_Char PrnZoom[6]; // Pascal 6 Byte RealNumber - SCTAB FirstPageNo; - sal_Int16 RowRepeatStart; - sal_Int16 RowRepeatEnd; - sal_Int16 ColRepeatStart; - sal_Int16 ColRepeatEnd; - sal_Char Reserved[26]; - - bool operator==( const Sc10PageFormat& rData ) const; -}; - -// Table protection -struct Sc10TableProtect -{ - sal_Char PassWord[16]; - sal_uInt16 Flags; - sal_uInt8 Protect; -}; - -// Document protection -struct Sc10SheetProtect -{ - sal_Char PassWord[16]; - sal_uInt16 Flags; - sal_uInt8 Protect; - Sc10SheetProtect() - : Flags(0) - , Protect(0) - { - memset(PassWord, 0, sizeof(PassWord)); - } -}; - -// FileHeader StarCalc 1.0 Datei -struct Sc10FileHeader -{ - sal_Char CopyRight[30]; - sal_uInt16 Version; - sal_Char Reserved[32]; -}; - -// User-Defined File Definition -struct Sc10FileInfo -{ - sal_Char Title[64]; - sal_Char Thema[64]; - sal_Char Keys[64]; - sal_Char Note[256]; - sal_Char InfoLabel0[16]; - sal_Char InfoLabel1[16]; - sal_Char InfoLabel2[16]; - sal_Char InfoLabel3[16]; - sal_Char Info0[32]; - sal_Char Info1[32]; - sal_Char Info2[32]; - sal_Char Info3[32]; - sal_Char CreateAuthor[64]; - sal_Char ChangeAuthor[64]; - sal_Char PrintAuthor[64]; - Sc10DateTime CreateDate; - Sc10DateTime ChangeDate; - Sc10DateTime PrintDate; - sal_uInt32 PageCount; - sal_uInt32 ChartCount; - sal_uInt32 PictureCount; - sal_uInt32 GraphCount; - sal_uInt32 OleCount; - sal_uInt32 NoteCount; - sal_uInt32 TextCellCount; - sal_uInt32 ValueCellCount; - sal_uInt32 FormulaCellCount; - sal_uInt32 CellCount; - sal_Char Reserved[52]; -}; - -// Last Cursor position -struct Sc10EditStateInfo -{ - // Cursor Position - sal_uInt16 CarretX; - sal_uInt16 CarretY; - sal_uInt16 CarretZ; - // left-top corner of the table - sal_uInt16 DeltaX; - sal_uInt16 DeltaY; - sal_uInt16 DeltaZ; - // redundant in StarCalc 3.0 - sal_uInt8 DataBaseMode; - sal_Char Reserved[51]; -}; - -// Attribut entry -struct Sc10ColData -{ - sal_uInt16 Row; - sal_uInt16 Value; -}; - -// Cell-Attribute definition -struct Sc10ColAttr -{ - sal_uInt16 Count; - std::unique_ptr<Sc10ColData[]> pData; - - Sc10ColAttr() - : Count(0) - { - } -}; - -// GraphHeader -struct Sc10GraphHeader -{ - sal_uInt8 Typ; // Type of graphic (Ole-object, Image (Bitmap of MetaFile), Chart-object) - sal_Int16 CarretX; // Cell Position of graphic - sal_Int16 CarretY; - sal_Int16 CarretZ; - sal_Int32 x; // x,y distance to cell border in pixels (pixels, as graphics are stored in window) - sal_Int32 y; - sal_Int32 w; // w,h width and height in pixels - sal_Int32 h; - sal_uInt8 IsRelPos; // position relative to cell, or absolute in the table - sal_uInt8 DoPrint; // print graphic? - sal_uInt16 FrameType; // Frame type around graphic (none, simple, double, simple thick, double thick) - sal_uInt8 IsTransparent; // show background? - Sc10Color FrameColor; // FrameColor as RGB value - Sc10Color BackColor; // BackGroundColor as RGB value - sal_Char Reserved[32]; // Reserved -}; - -// ImageHeader -struct Sc10ImageHeader -{ - sal_Char FileName[128]; // file name of the original inserted image - sal_Int16 Typ; // image type (Bitmap or Metafile) - sal_uInt8 Linked; // not possible - sal_Int16 x1; // original image size (only for Metafiles) - sal_Int16 y1; - sal_Int16 x2; - sal_Int16 y2; - sal_uInt32 Size; // image size in BYTES -}; - -// ChartHeader -struct Sc10ChartHeader -{ - sal_Int16 MM; // Metafile structure MapMode, width, height - sal_Int16 xExt; - sal_Int16 yExt; - sal_uInt32 Size; // image size in BYTES -}; - -// ChartSheetData -struct Sc10ChartSheetData -{ - sal_uInt8 HasTitle; // has the Chart a title in the table - sal_Int16 TitleX; // cell position of title - sal_Int16 TitleY; - sal_uInt8 HasSubTitle; // has the Chart a sub-title in the table - sal_Int16 SubTitleX; // cell position of sub-title - sal_Int16 SubTitleY; - sal_uInt8 HasLeftTitle; // has the Chart a left-title in the table - sal_Int16 LeftTitleX; // cell position of left-title - sal_Int16 LeftTitleY; - sal_uInt8 HasLegend; // has the Chart a legend in the table - sal_Int16 LegendX1; // cells for legend - sal_Int16 LegendY1; - sal_Int16 LegendX2; - sal_Int16 LegendY2; - sal_uInt8 HasLabel; // has the Chart axis labels in the table - sal_Int16 LabelX1; // cells for axis labels - sal_Int16 LabelY1; - sal_Int16 LabelX2; - sal_Int16 LabelY2; - sal_Int16 DataX1; // cells for Data - sal_Int16 DataY1; - sal_Int16 DataX2; - sal_Int16 DataY2; - sal_Char Reserved[64]; -}; - -typedef sal_Char Sc10ChartText[30]; - -struct Sc10ChartTypeData -{ - sal_Int16 NumSets; - sal_Int16 NumPoints; - sal_Int16 DrawMode; - sal_Int16 GraphType; - sal_Int16 GraphStyle; - sal_Char GraphTitle[80]; - sal_Char BottomTitle[80]; - sal_Int16 SymbolData[256]; - sal_Int16 ColorData[256]; - sal_Int16 ThickLines[256]; - sal_Int16 PatternData[256]; - sal_Int16 LinePatternData[256]; - sal_Int16 NumGraphStyles[11]; - sal_Int16 ShowLegend; - Sc10ChartText LegendText[256]; - sal_Int16 ExplodePie; - sal_Int16 FontUse; - sal_Int16 FontFamily[5]; - sal_Int16 FontStyle[5]; - sal_Int16 FontSize[5]; - sal_Int16 GridStyle; - sal_Int16 Labels; - sal_Int16 LabelEvery; - Sc10ChartText LabelText[50]; - sal_Char LeftTitle[80]; - sal_Char Reserved[4646]; -}; - -// FontAttribut -class Sc10FontData : public ScDataObject -{ -public: - sal_Int16 Height; - sal_uInt8 CharSet; - sal_uInt8 PitchAndFamily; - sal_Char FaceName[32]; - - Sc10FontData( const Sc10FontData& rData ) - : ScDataObject( rData ) - , Height( rData.Height ) - , CharSet( rData.CharSet ) - , PitchAndFamily( rData.PitchAndFamily ) - { - strncpy( FaceName, rData.FaceName, sizeof(FaceName) ); - FaceName[sizeof(FaceName)-1] = 0; - } - Sc10FontData( SvStream& rStream ); - virtual ScDataObject* Clone() const override { return new Sc10FontData(*this); } -}; - -// Font-Collection -class Sc10FontCollection final : public ScCollection -{ -public: - Sc10FontCollection( SvStream& rStream ); - ErrCode GetError() { return nError; } - Sc10FontData* At(sal_uInt16 nIndex) { return static_cast<Sc10FontData*>(ScCollection::At(nIndex)); } -private: - using ScCollection::At; - ErrCode nError; -}; - -//Range-Data -class Sc10NameData : public ScDataObject -{ -public: - sal_Char Name[32]; - sal_Char Reference[64]; - sal_Char Reserved[12]; - - Sc10NameData(const Sc10NameData& rData) : - ScDataObject( rData ) - { - strncpy(Name, rData.Name, sizeof(Name)); - Name[sizeof(Name)-1] = 0; - strncpy(Reference, rData.Reference, sizeof(Reference)); - Reference[sizeof(Reference)-1] = 0; - memcpy(Reserved, rData.Reserved, sizeof(Reserved)); - } - Sc10NameData(SvStream& rStream); - virtual ScDataObject* Clone() const override { return new Sc10NameData(*this); } -}; - -// Range-Collection -class Sc10NameCollection final : public ScCollection -{ -public: - Sc10NameCollection(SvStream& rStream); - ErrCode GetError() { return nError; } - Sc10NameData* At(sal_uInt16 nIndex) { return static_cast<Sc10NameData*>(ScCollection::At(nIndex)); } -private: - using ScCollection::At; - ErrCode nError; -}; - -// Template-Data -class Sc10PatternData : public ScDataObject -{ -public: - sal_Char Name[32]; - Sc10ValueFormat ValueFormat; - Sc10LogFont LogFont; - sal_uInt16 Attr; - sal_uInt16 Justify; - sal_uInt16 Frame; - sal_uInt16 Raster; - sal_uInt16 nColor; - sal_uInt16 FrameColor; - sal_uInt16 Flags; - sal_uInt16 FormatFlags; - sal_Char Reserved[8]; - - Sc10PatternData(const Sc10PatternData& rData) : - ScDataObject( rData ) - { - strncpy(Name, rData.Name, sizeof(Name)); - Name[sizeof(Name)-1] = 0; - memcpy(&ValueFormat, &rData.ValueFormat, sizeof(ValueFormat)); - memcpy(&LogFont, &rData.LogFont, sizeof(LogFont)); - Attr = rData.Attr; - Justify = rData.Justify; - Frame = rData.Frame; - Raster = rData.Raster; - nColor = rData.nColor; - FrameColor = rData.FrameColor; - Flags = rData.Flags; - FormatFlags = rData.FormatFlags; - memcpy(Reserved, rData.Reserved, sizeof(Reserved)); - } - Sc10PatternData(SvStream& rStream); -virtual ScDataObject* Clone() const override { return new Sc10PatternData(*this); } -}; - -// Template-Collection -class Sc10PatternCollection final : public ScCollection -{ -public: - Sc10PatternCollection(SvStream& rStream); - ErrCode GetError() { return nError; } - Sc10PatternData* At(sal_uInt16 nIndex) { return static_cast<Sc10PatternData*>(ScCollection::At(nIndex)); } -private: - using ScCollection::At; - ErrCode nError; -}; - -// DataBank-Data -class Sc10DataBaseData : public ScDataObject -{ -public: - Sc10DataBaseRec DataBaseRec; - - Sc10DataBaseData(const Sc10DataBaseData& rData) : - ScDataObject( rData ) - { - memcpy(&DataBaseRec, &rData.DataBaseRec, sizeof(DataBaseRec)); - } - Sc10DataBaseData(SvStream& rStream); -virtual ScDataObject* Clone() const override { return new Sc10DataBaseData(*this); } -}; - -// DataBank-Collection -class Sc10DataBaseCollection final : public ScCollection -{ -public: - Sc10DataBaseCollection(SvStream& rStream); - ErrCode GetError() { return nError; } - Sc10DataBaseData* At(sal_uInt16 nIndex) { return static_cast<Sc10DataBaseData*>(ScCollection::At(nIndex)); } -private: - using ScCollection::At; - ErrCode nError; - sal_Char ActName[32]; -}; - -class Sc10PageData : public ScDataObject -{ -public: - Sc10PageFormat aPageFormat; - Sc10PageData( const Sc10PageFormat& rFormat ) : aPageFormat(rFormat) {} - virtual ScDataObject* Clone() const override; -}; - -// PageFormat-Collection -class Sc10PageCollection : public ScCollection -{ -public: - Sc10PageCollection() : ScCollection(1,1) {}; - Sc10PageData* At(sal_uInt16 nIndex) { return static_cast<Sc10PageData*>(ScCollection::At(nIndex)); } - sal_uInt16 InsertFormat( const Sc10PageFormat& rData ); - void PutToDoc( ScDocument* pDoc ); -private: - using ScCollection::At; -}; - -class ScfStreamProgressBar; - -// Import-Class -class Sc10Import -{ - SvStream& rStream; - ScDocument* pDoc; - Sc10Color TextPalette[16]; - Sc10Color BackPalette[16]; - Sc10Color RasterPalette[16]; - Sc10Color FramePalette[16]; - Sc10SheetProtect SheetProtect; - Sc10FontCollection* pFontCollection; - Sc10NameCollection* pNameCollection; - Sc10PatternCollection* pPatternCollection; - Sc10DataBaseCollection* pDataBaseCollection; - ErrCode nError; - SCTAB nShowTab; - ScViewOptions aSc30ViewOpt; - ScfStreamProgressBar* pPrgrsBar; - -public: - Sc10Import( SvStream& rStr, ScDocument* pDocument ); - ~Sc10Import(); - - ErrCode Import(); - void LoadFileHeader(); - void LoadFileInfo(); - void LoadEditStateInfo(); - void LoadProtect(); - void LoadViewColRowBar(); - void LoadScrZoom(); - void LoadPalette(); - void LoadFontCollection(); - void LoadNameCollection(); - void ImportNameCollection(); - void LoadPatternCollection(); - void LoadDataBaseCollection(); - void LoadTables(); - void LoadCol(SCCOL Col, SCTAB Tab); - void LoadColAttr(SCCOL Col, SCTAB Tab); - void LoadAttr(Sc10ColAttr& rAttr); - static void ChangeFormat(sal_uInt16 nFormat, sal_uInt16 nInfo, sal_uLong& nKey); - void LoadObjects(); -}; - -#endif - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sc/source/filter/starcalc/scfobj.cxx b/sc/source/filter/starcalc/scfobj.cxx deleted file mode 100644 index 9cbce392c03b..000000000000 --- a/sc/source/filter/starcalc/scfobj.cxx +++ /dev/null @@ -1,86 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/* - * This file is part of the LibreOffice project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - * - * This file incorporates work covered by the following license notice: - * - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed - * with this work for additional information regarding copyright - * ownership. The ASF licenses this file to you under the Apache - * License, Version 2.0 (the "License"); you may not use this file - * except in compliance with the License. You may obtain a copy of - * the License at http://www.apache.org/licenses/LICENSE-2.0 . - */ - -#include <com/sun/star/embed/XEmbeddedObject.hpp> -#include <com/sun/star/embed/XVisualObject.hpp> -#include <com/sun/star/embed/Aspects.hpp> - -using namespace com::sun::star; - -#include <unotools/moduleoptions.hxx> -#include <svx/charthelper.hxx> -#include <svx/svdoole2.hxx> -#include <svx/svdpage.hxx> -#include <svtools/embedhlp.hxx> -#include <sfx2/objsh.hxx> -#include <sot/storage.hxx> -#include <sfx2/app.hxx> -#include <comphelper/classids.hxx> -#include <address.hxx> - -#include <scfobj.hxx> -#include <document.hxx> -#include <drwlayer.hxx> -#include <chartarr.hxx> - -void Sc10InsertObject::InsertChart( ScDocument* pDoc, SCTAB nDestTab, const tools::Rectangle& rRect, - SCTAB nSrcTab, sal_uInt16 nX1, sal_uInt16 nY1, sal_uInt16 nX2, sal_uInt16 nY2 ) -{ - // if Chart is not installed, SCH_MOD cannot be used! - if ( !SvtModuleOptions().IsChart() ) - return; - - OUString aName; - uno::Reference < embed::XEmbeddedObject > xObj = pDoc->GetDocumentShell()-> - GetEmbeddedObjectContainer().CreateEmbeddedObject( SvGlobalName( SO3_SCH_CLASSID ).GetByteSequence(), aName ); - if ( xObj.is() ) - { - SdrOle2Obj* pSdrOle2Obj = new SdrOle2Obj( ::svt::EmbeddedObjectRef( xObj, embed::Aspects::MSOLE_CONTENT ), aName, rRect ); - - ScDrawLayer* pModel = pDoc->GetDrawLayer(); - if (!pModel) - { - pDoc->InitDrawLayer(); - pModel = pDoc->GetDrawLayer(); - OSL_ENSURE(pModel,"Draw Layer ?"); - } - - SdrPage* pPage = pModel->GetPage(static_cast<sal_uInt16>(nDestTab)); - OSL_ENSURE(pPage,"Page ?"); - pPage->InsertObject(pSdrOle2Obj); - - pSdrOle2Obj->SetLogicRect(rRect); // only after InsertObject !!! - awt::Size aSz; - aSz.Width = rRect.GetSize().Width(); - aSz.Height = rRect.GetSize().Height(); - xObj->setVisualAreaSize( embed::Aspects::MSOLE_CONTENT, aSz ); - - // #i121334# This call will change the chart's default background fill from white to transparent. - // Add here again if this is wanted (see task description for details) - // ChartHelper::AdaptDefaultsForChart( xObj ); - - // Cannot set source of chart here yet as formulas are not calculated yet. - // Thus push into ChartCollection; the data is set in Sc10Import dtor. - - ScChartCollection* pColl = pDoc->GetChartCollection(); - pColl->push_back( new ScChartArray( pDoc, nSrcTab, static_cast<SCCOL>(nX1), static_cast<SCROW>(nY1), static_cast<SCCOL>(nX2), static_cast<SCROW>(nY2), aName ) ); - } -} - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |