nss: upgrade to release 3.73
[LibreOffice.git] / xmloff / inc / txtlists.hxx
blob1d335be473f910ca53e7b215d9b77a0df5daa52a
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef INCLUDED_XMLOFF_INC_TXTLISTS_HXX
21 #define INCLUDED_XMLOFF_INC_TXTLISTS_HXX
23 #include <rtl/ustring.hxx>
24 #include <map>
25 #include <memory>
26 #include <stack>
27 #include <tuple>
28 #include <vector>
29 #include <com/sun/star/container/XIndexReplace.hpp>
30 #include <xmloff/xmlictxt.hxx>
32 class SvXMLImport;
33 class XMLTextListBlockContext;
34 class XMLTextListItemContext;
35 class XMLNumberedParaContext;
37 class XMLTextListsHelper
39 public:
40 XMLTextListsHelper();
41 XMLTextListsHelper(const XMLTextListsHelper&) = delete;
42 XMLTextListsHelper& operator=(const XMLTextListsHelper&) = delete;
44 /// list stack for importing:
46 /// push a list context on the list context stack
47 void PushListContext(XMLTextListBlockContext *i_pListBlock);
48 void PushListContext(XMLNumberedParaContext *i_pNumberedParagraph);
49 /// pop the list context stack
50 void PopListContext();
51 /// peek at the top of the list context stack
52 void ListContextTop(XMLTextListBlockContext*& o_pListBlockContext,
53 XMLTextListItemContext*& o_pListItemContext,
54 XMLNumberedParaContext*& o_pNumberedParagraphContext );
55 /// set list item on top of the list context stack
56 void SetListItem( XMLTextListItemContext *pListItem );
59 // keeping track of processed lists for import and export
60 // Add optional parameter <sListStyleDefaultListId> (#i92811#)
61 void KeepListAsProcessed( const OUString& sListId,
62 const OUString& sListStyleName,
63 const OUString& sContinueListId,
64 const OUString& sListStyleDefaultListId = OUString() );
66 bool IsListProcessed( const OUString& sListId ) const;
67 OUString GetListStyleOfProcessedList(
68 const OUString& sListId ) const;
69 OUString GetContinueListIdOfProcessedList(
70 const OUString& sListId ) const;
71 const OUString& GetLastProcessedListId() const { return msLastProcessedListId;}
72 const OUString& GetListStyleOfLastProcessedList() const { return msListStyleOfLastProcessedList;}
74 OUString GenerateNewListId() const;
76 // Provide list id for a certain list block for import (#i92811#)
77 OUString GetListIdForListBlock( XMLTextListBlockContext const & rListBlock );
79 // keep track of continue list chain for export
80 void StoreLastContinuingList( const OUString& sListId,
81 const OUString& sContinuingListId );
83 OUString GetLastContinuingListId( const OUString& sListId ) const;
85 // keep track of opened list elements of a certain list for export
86 void PushListOnStack( const OUString& sListId,
87 const OUString& sListStyleName );
88 void PopListFromStack();
89 bool EqualsToTopListStyleOnStack( const OUString& sListId ) const;
91 /** for importing numbered-paragraph
92 note that the ID namespace for numbered-paragraph and regular list
93 is distinct; we never combine a list and a n-p
95 css::uno::Reference< css::container::XIndexReplace>
96 EnsureNumberedParagraph(
97 SvXMLImport & i_rImport,
98 const OUString& i_ListId,
99 sal_Int16 & io_rLevel, const OUString& i_StyleName);
101 /// get ID of the last numbered-paragraph iff it has given style-name
102 OUString GetNumberedParagraphListId(
103 const sal_uInt16 i_Level,
104 const OUString& i_StyleName);
106 /** Creates a NumRule from given style-name.
107 @param i_rImport the SvXMLImport
108 @param i_xNumRule parent num rule
109 @param i_ParentStyleName parent list style name
110 @param i_StyleName the list style name
111 @param io_rLevel the list level (may be reset if too large)
112 @param o_rRestartNumbering set to true if no style (defaulting)
113 @param io_rSetDefaults set to true if no style (defaulting)
115 static css::uno::Reference< css::container::XIndexReplace> MakeNumRule(
116 SvXMLImport & i_rImport,
117 const css::uno::Reference< css::container::XIndexReplace>& i_xNumRule,
118 const OUString& i_ParentStyleName,
119 const OUString& i_StyleName,
120 sal_Int16 & io_rLevel,
121 bool* o_pRestartNumbering = nullptr,
122 bool* io_pSetDefaults = nullptr);
124 private:
126 /** list context: list, list-item, numbered-paragraph
127 XMLTextListBlockContext, XMLTextListItemContext,
128 XMLNumberedParaContext
130 typedef std::tuple<SvXMLImportContextRef,
131 SvXMLImportContextRef, SvXMLImportContextRef> ListStackFrame_t;
132 std::stack< ListStackFrame_t > mListStack;
134 // container type for processed lists:
135 // map with <ListId> as key and pair( <ListStyleName, ContinueListId> )
136 // as value
137 typedef ::std::map< OUString,
138 ::std::pair< OUString, OUString > > tMapForLists;
139 std::unique_ptr<tMapForLists> mpProcessedLists;
140 OUString msLastProcessedListId;
141 OUString msListStyleOfLastProcessedList;
143 /* additional container for processed lists.
144 map with <ListStyleName> as key and pair( <ListId, ListStyleDefaultListId> )
145 as value. (#i92811#)
147 std::unique_ptr<tMapForLists> mpMapListIdToListStyleDefaultListId;
149 // container type to build up continue list chain:
150 // map with <ListId> of master list as key and <ListId> of last list
151 // continuing the master list as value
152 typedef ::std::map< OUString, OUString > tMapForContinuingLists;
153 std::unique_ptr<tMapForContinuingLists> mpContinuingLists;
155 // stack type for opened list elements and its list style:
156 // vector with pair( <ListId>, <ListStyleName> ) as value
157 typedef ::std::vector< ::std::pair< OUString, OUString > >
158 tStackForLists;
159 std::unique_ptr<tStackForLists> mpListStack;
161 /// to connect numbered-paragraphs that have no list-id attribute:
162 /// vector of pair of style-name and list-id (indexed by level)
163 typedef ::std::vector< ::std::pair< OUString, OUString > >
164 LastNumberedParagraphs_t;
166 LastNumberedParagraphs_t mLastNumberedParagraphs;
168 /// numbered-paragraphs
169 typedef ::std::vector<
170 ::std::pair<
171 OUString,
172 css::uno::Reference< css::container::XIndexReplace > > > NumParaList_t;
173 ::std::map< OUString, NumParaList_t > mNPLists;
176 #endif
178 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */