Branch data Line data Source code
1 : : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : : /*************************************************************************
3 : : *
4 : : * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 : : *
6 : : * Copyright 2000, 2010 Oracle and/or its affiliates.
7 : : *
8 : : * OpenOffice.org - a multi-platform office productivity suite
9 : : *
10 : : * This file is part of OpenOffice.org.
11 : : *
12 : : * OpenOffice.org is free software: you can redistribute it and/or modify
13 : : * it under the terms of the GNU Lesser General Public License version 3
14 : : * only, as published by the Free Software Foundation.
15 : : *
16 : : * OpenOffice.org is distributed in the hope that it will be useful,
17 : : * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 : : * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 : : * GNU Lesser General Public License version 3 for more details
20 : : * (a copy is included in the LICENSE file that accompanied this code).
21 : : *
22 : : * You should have received a copy of the GNU Lesser General Public License
23 : : * version 3 along with OpenOffice.org. If not, see
24 : : * <http://www.openoffice.org/license.html>
25 : : * for a copy of the LGPLv3 License.
26 : : *
27 : : ************************************************************************/
28 : : #ifndef _FTNIDX_HXX
29 : : #define _FTNIDX_HXX
30 : :
31 : : #include <vector>
32 : : #include <sal/types.h>
33 : : #include <o3tl/sorted_vector.hxx>
34 : :
35 : : class SwTxtFtn;
36 : : class SwNodeIndex;
37 : : class SwSectionNode;
38 : :
39 : : // Everywhere where NodeIndex is used, the header files missing here
40 : : // are already included. Therefore put here as defines only and
41 : : // not as inline methods (saves compile time).
42 : : #define _SwTxtFtn_GetIndex( pFIdx ) (pFIdx->GetTxtNode().GetIndex())
43 : :
44 : :
45 : : struct CompareSwFtnIdxs
46 : : {
47 : : bool operator()(SwTxtFtn* const& lhs, SwTxtFtn* const& rhs) const;
48 : : };
49 : :
50 : 1590 : class SwFtnIdxs : public o3tl::sorted_vector<SwTxtFtn*, CompareSwFtnIdxs>
51 : : {
52 : : public:
53 : 1681 : SwFtnIdxs() {}
54 : :
55 : : void UpdateFtn( const SwNodeIndex& rStt ); // Update all from pos.
56 : : void UpdateAllFtn(); // Update all footnotes.
57 : :
58 : : SwTxtFtn* SeekEntry( const SwNodeIndex& rIdx, sal_uInt16* pPos = 0 ) const;
59 : : };
60 : :
61 : :
62 : 112 : class SwUpdFtnEndNtAtEnd
63 : : {
64 : : std::vector<const SwSectionNode*> aFtnSects, aEndSects;
65 : : std::vector<sal_uInt16> aFtnNums, aEndNums;
66 : :
67 : : public:
68 [ + - ][ + - ]: 112 : SwUpdFtnEndNtAtEnd() : aFtnSects(), aEndSects() {}
[ + - ]
69 : :
70 : : static const SwSectionNode* FindSectNdWithEndAttr(
71 : : const SwTxtFtn& rTxtFtn );
72 : :
73 : : sal_uInt16 GetNumber( const SwTxtFtn& rTxtFtn, const SwSectionNode& rNd );
74 : : sal_uInt16 ChkNumber( const SwTxtFtn& rTxtFtn );
75 : : };
76 : :
77 : :
78 : :
79 : : #endif // _FTNIDX_HXX
80 : :
81 : : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|