1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
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>
29 #include <com/sun/star/container/XIndexReplace.hpp>
30 #include <xmloff/xmlictxt.hxx>
33 class XMLTextListBlockContext
;
34 class XMLTextListItemContext
;
35 class XMLNumberedParaContext
;
37 class 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
& 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);
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> )
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> )
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
> >
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
<
172 css::uno::Reference
< css::container::XIndexReplace
> > > NumParaList_t
;
173 ::std::map
< OUString
, NumParaList_t
> mNPLists
;
178 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */