diff options
Diffstat (limited to 'sc/inc/refdata.hxx')
-rw-r--r-- | sc/inc/refdata.hxx | 216 |
1 files changed, 0 insertions, 216 deletions
diff --git a/sc/inc/refdata.hxx b/sc/inc/refdata.hxx deleted file mode 100644 index 7196b6d30..000000000 --- a/sc/inc/refdata.hxx +++ /dev/null @@ -1,216 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/************************************************************************* - * - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * Copyright 2000, 2010 Oracle and/or its affiliates. - * - * OpenOffice.org - a multi-platform office productivity suite - * - * This file is part of OpenOffice.org. - * - * OpenOffice.org is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License version 3 - * only, as published by the Free Software Foundation. - * - * OpenOffice.org is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Lesser General Public License version 3 for more details - * (a copy is included in the LICENSE file that accompanied this code). - * - * You should have received a copy of the GNU Lesser General Public License - * version 3 along with OpenOffice.org. If not, see - * <http://www.openoffice.org/license.html> - * for a copy of the LGPLv3 License. - * - ************************************************************************/ - -#ifndef SC_REFDATA_HXX -#define SC_REFDATA_HXX - -#include "global.hxx" -#include "address.hxx" -#include "scdllapi.h" - - -// Ref-Flags for old (until release 3.1) documents - -struct OldSingleRefBools -{ - sal_uInt8 bRelCol; // Flag values (see further down), 2 bits each in file format - sal_uInt8 bRelRow; - sal_uInt8 bRelTab; - sal_uInt8 bOldFlag3D; // two sal_Bool flags (see further down) -}; - -#define SR_ABSOLUTE 0 // Absolute value -#define SR_RELABS 1 // Relative value as absolute value (until release 3.1) -#define SR_RELATIVE 2 // Relative value as delta value (after release 3.1) -#define SR_DELETED 3 // Deleted col/row/tab - -#define SRF_3D 0x01 // 3D reference, was the sal_Bool (before build 304a) -#define SRF_RELNAME 0x02 // Reference derived from RangeName with relative values -#define SRF_BITS 0x03 // Mask of possible bits - - -struct SC_DLLPUBLIC ScSingleRefData // Single reference (one address) into the sheet -{ - SCsCOL nCol; // Absolute values - SCsROW nRow; - SCsTAB nTab; - SCsCOL nRelCol; // Values relative to the position - SCsROW nRelRow; - SCsTAB nRelTab; - - union - { - sal_Bool bFlags; - struct - { - sal_Bool bColRel :1; - sal_Bool bColDeleted :1; - sal_Bool bRowRel :1; - sal_Bool bRowDeleted :1; - sal_Bool bTabRel :1; - sal_Bool bTabDeleted :1; - sal_Bool bFlag3D :1; // 3D-Ref - sal_Bool bRelName :1; // Reference derived from RangeName with relative values - }Flags; - }; - - // No default ctor, because used in ScRawToken union, set InitFlags! - inline void InitFlags() { bFlags = 0; } // all FALSE - // InitAddress: InitFlags and set address - inline void InitAddress( const ScAddress& rAdr ); - inline void InitAddress( SCCOL nCol, SCROW nRow, SCTAB nTab ); - // InitAddressRel: InitFlags and set address, everything relative to rPos - inline void InitAddressRel( const ScAddress& rAdr, const ScAddress& rPos ); - inline void SetColRel( sal_Bool bVal ) { Flags.bColRel = (bVal ? sal_True : false ); } - inline sal_Bool IsColRel() const { return Flags.bColRel; } - inline void SetRowRel( sal_Bool bVal ) { Flags.bRowRel = (bVal ? sal_True : false ); } - inline sal_Bool IsRowRel() const { return Flags.bRowRel; } - inline void SetTabRel( sal_Bool bVal ) { Flags.bTabRel = (bVal ? sal_True : false ); } - inline sal_Bool IsTabRel() const { return Flags.bTabRel; } - - inline void SetColDeleted( sal_Bool bVal ) { Flags.bColDeleted = (bVal ? sal_True : false ); } - inline sal_Bool IsColDeleted() const { return Flags.bColDeleted; } - inline void SetRowDeleted( sal_Bool bVal ) { Flags.bRowDeleted = (bVal ? sal_True : false ); } - inline sal_Bool IsRowDeleted() const { return Flags.bRowDeleted; } - inline void SetTabDeleted( sal_Bool bVal ) { Flags.bTabDeleted = (bVal ? sal_True : false ); } - inline sal_Bool IsTabDeleted() const { return Flags.bTabDeleted; } - inline sal_Bool IsDeleted() const { return IsColDeleted() || IsRowDeleted() || IsTabDeleted(); } - - inline void SetFlag3D( sal_Bool bVal ) { Flags.bFlag3D = (bVal ? sal_True : false ); } - inline sal_Bool IsFlag3D() const { return Flags.bFlag3D; } - inline void SetRelName( sal_Bool bVal ) { Flags.bRelName = (bVal ? sal_True : false ); } - inline sal_Bool IsRelName() const { return Flags.bRelName; } - - inline sal_Bool Valid() const; - /// In external references nTab is -1 - inline bool ValidExternal() const; - - void SmartRelAbs( const ScAddress& rPos ); - void CalcRelFromAbs( const ScAddress& rPos ); - void CalcAbsIfRel( const ScAddress& rPos ); - sal_Bool operator==( const ScSingleRefData& ) const; - bool operator!=( const ScSingleRefData& ) const; -}; - -inline void ScSingleRefData::InitAddress( SCCOL nColP, SCROW nRowP, SCTAB nTabP ) -{ - InitFlags(); - nCol = nColP; - nRow = nRowP; - nTab = nTabP; -} - -inline void ScSingleRefData::InitAddress( const ScAddress& rAdr ) -{ - InitAddress( rAdr.Col(), rAdr.Row(), rAdr.Tab()); -} - -inline void ScSingleRefData::InitAddressRel( const ScAddress& rAdr, - const ScAddress& rPos ) -{ - InitAddress( rAdr.Col(), rAdr.Row(), rAdr.Tab()); - SetColRel( sal_True ); - SetRowRel( sal_True ); - SetTabRel( sal_True ); - CalcRelFromAbs( rPos ); -} - -inline sal_Bool ScSingleRefData::Valid() const -{ - return nCol >= 0 && nCol <= MAXCOL && - nRow >= 0 && nRow <= MAXROW && - nTab >= 0 && nTab <= MAXTAB; -} - -inline bool ScSingleRefData::ValidExternal() const -{ - return nCol >= 0 && nCol <= MAXCOL && - nRow >= 0 && nRow <= MAXROW && - nTab == -1; -} - - -struct ScComplexRefData // Complex reference (a range) into the sheet -{ - ScSingleRefData Ref1; - ScSingleRefData Ref2; - - inline void InitFlags() - { Ref1.InitFlags(); Ref2.InitFlags(); } - inline void InitRange( const ScRange& rRange ) - { - Ref1.InitAddress( rRange.aStart ); - Ref2.InitAddress( rRange.aEnd ); - } - inline void InitRangeRel( const ScRange& rRange, const ScAddress& rPos ) - { - Ref1.InitAddressRel( rRange.aStart, rPos ); - Ref2.InitAddressRel( rRange.aEnd, rPos ); - } - inline void InitRange( SCCOL nCol1, SCROW nRow1, SCTAB nTab1, - SCCOL nCol2, SCROW nRow2, SCTAB nTab2 ) - { - Ref1.InitAddress( nCol1, nRow1, nTab1 ); - Ref2.InitAddress( nCol2, nRow2, nTab2 ); - } - inline void SmartRelAbs( const ScAddress& rPos ) - { Ref1.SmartRelAbs( rPos ); Ref2.SmartRelAbs( rPos ); } - inline void CalcRelFromAbs( const ScAddress& rPos ) - { Ref1.CalcRelFromAbs( rPos ); Ref2.CalcRelFromAbs( rPos ); } - inline void CalcAbsIfRel( const ScAddress& rPos ) - { Ref1.CalcAbsIfRel( rPos ); Ref2.CalcAbsIfRel( rPos ); } - inline sal_Bool IsDeleted() const - { return Ref1.IsDeleted() || Ref2.IsDeleted(); } - inline sal_Bool Valid() const - { return Ref1.Valid() && Ref2.Valid(); } - /** In external references nTab is -1 for the start tab and -1 for the end - tab if one sheet, or >=0 if more than one sheets. */ - inline bool ValidExternal() const; - - /// Absolute references have to be up-to-date when calling this! - void PutInOrder(); - inline sal_Bool operator==( const ScComplexRefData& r ) const - { return Ref1 == r.Ref1 && Ref2 == r.Ref2; } - /** Enlarge range if reference passed is not within existing range. - ScAddress position is used to calculate absolute references from - relative references. */ - ScComplexRefData& Extend( const ScSingleRefData & rRef, const ScAddress & rPos ); - ScComplexRefData& Extend( const ScComplexRefData & rRef, const ScAddress & rPos ); -}; - -inline bool ScComplexRefData::ValidExternal() const -{ - return Ref1.ValidExternal() && - Ref2.nCol >= 0 && Ref2.nCol <= MAXCOL && - Ref2.nRow >= 0 && Ref2.nRow <= MAXROW && - Ref2.nTab >= Ref1.nTab; -} - -#endif - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |