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 .
21 #include "PageMasterImportPropMapper.hxx"
22 #include <PageMasterStyleMap.hxx>
23 #include <xmloff/maptype.hxx>
24 #include <com/sun/star/table/BorderLine2.hpp>
25 #include <com/sun/star/container/XNameContainer.hpp>
26 #include <com/sun/star/lang/XServiceInfo.hpp>
27 #include <com/sun/star/lang/XMultiServiceFactory.hpp>
28 #include <com/sun/star/frame/XModel.hpp>
29 #include <com/sun/star/beans/XPropertySet.hpp>
30 #include <xmloff/xmlimp.hxx>
31 #include <xmloff/xmlprmap.hxx>
34 #define XML_LINE_LEFT 0
35 #define XML_LINE_RIGHT 1
36 #define XML_LINE_TOP 2
37 #define XML_LINE_BOTTOM 3
39 using namespace ::com::sun::star
;
40 using namespace ::com::sun::star::uno
;
41 using namespace ::com::sun::star::container
;
43 PageMasterImportPropertyMapper::PageMasterImportPropertyMapper(
44 const rtl::Reference
< XMLPropertySetMapper
>& rMapper
,
46 SvXMLImportPropertyMapper( rMapper
, rImp
),
51 PageMasterImportPropertyMapper::~PageMasterImportPropertyMapper()
55 bool PageMasterImportPropertyMapper::handleSpecialItem(
56 XMLPropertyState
& rProperty
,
57 std::vector
< XMLPropertyState
>& rProperties
,
58 const OUString
& rValue
,
59 const SvXMLUnitConverter
& rUnitConverter
,
60 const SvXMLNamespaceMap
& rNamespaceMap
) const
63 sal_Int16 nContextID
=
64 getPropertySetMapper()->GetEntryContextId(rProperty
.mnIndex
);
66 if( CTF_PM_REGISTER_STYLE
==nContextID
)
68 OUString
sDisplayName( rImport
.GetStyleDisplayName(
69 XmlStyleFamily::TEXT_PARAGRAPH
, rValue
) );
70 Reference
< XNameContainer
> xParaStyles
=
71 rImport
.GetTextImport()->GetParaStyles();
72 if( xParaStyles
.is() && xParaStyles
->hasByName( sDisplayName
) )
74 rProperty
.maValue
<<= sDisplayName
;
80 bRet
= SvXMLImportPropertyMapper::handleSpecialItem(
81 rProperty
, rProperties
, rValue
,
82 rUnitConverter
, rNamespaceMap
);
89 void PageMasterImportPropertyMapper::finished(std::vector
< XMLPropertyState
>& rProperties
, sal_Int32 nStartIndex
, sal_Int32 nEndIndex
) const
91 SvXMLImportPropertyMapper::finished(rProperties
, nStartIndex
, nEndIndex
);
92 XMLPropertyState
* pAllPaddingProperty
= nullptr;
93 XMLPropertyState
* pPadding
[4] = { nullptr, nullptr, nullptr, nullptr };
94 XMLPropertyState
* pNewPadding
[4] = { nullptr, nullptr, nullptr, nullptr };
95 XMLPropertyState
* pAllBorderProperty
= nullptr;
96 XMLPropertyState
* pBorders
[4] = { nullptr, nullptr, nullptr, nullptr };
97 XMLPropertyState
* pNewBorders
[4] = { nullptr, nullptr, nullptr, nullptr };
98 XMLPropertyState
* pAllBorderWidthProperty
= nullptr;
99 XMLPropertyState
* pBorderWidths
[4] = { nullptr, nullptr, nullptr, nullptr };
100 XMLPropertyState
* pAllHeaderPaddingProperty
= nullptr;
101 XMLPropertyState
* pHeaderPadding
[4] = { nullptr, nullptr, nullptr, nullptr };
102 XMLPropertyState
* pHeaderNewPadding
[4] = { nullptr, nullptr, nullptr, nullptr };
103 XMLPropertyState
* pAllHeaderBorderProperty
= nullptr;
104 XMLPropertyState
* pHeaderBorders
[4] = { nullptr, nullptr, nullptr, nullptr };
105 XMLPropertyState
* pHeaderNewBorders
[4] = { nullptr, nullptr, nullptr, nullptr };
106 XMLPropertyState
* pAllHeaderBorderWidthProperty
= nullptr;
107 XMLPropertyState
* pHeaderBorderWidths
[4] = { nullptr, nullptr, nullptr, nullptr };
108 XMLPropertyState
* pAllFooterPaddingProperty
= nullptr;
109 XMLPropertyState
* pFooterPadding
[4] = { nullptr, nullptr, nullptr, nullptr };
110 XMLPropertyState
* pFooterNewPadding
[4] = { nullptr, nullptr, nullptr, nullptr };
111 XMLPropertyState
* pAllFooterBorderProperty
= nullptr;
112 XMLPropertyState
* pFooterBorders
[4] = { nullptr, nullptr, nullptr, nullptr };
113 XMLPropertyState
* pFooterNewBorders
[4] = { nullptr, nullptr, nullptr, nullptr };
114 XMLPropertyState
* pAllFooterBorderWidthProperty
= nullptr;
115 XMLPropertyState
* pFooterBorderWidths
[4] = { nullptr, nullptr, nullptr, nullptr };
116 XMLPropertyState
* pHeaderHeight
= nullptr;
117 XMLPropertyState
* pHeaderMinHeight
= nullptr;
118 std::optional
<XMLPropertyState
> xHeaderDynamic
;
119 XMLPropertyState
* pFooterHeight
= nullptr;
120 XMLPropertyState
* pFooterMinHeight
= nullptr;
121 std::optional
<XMLPropertyState
> xFooterDynamic
;
122 XMLPropertyState
* pAllMarginProperty
= nullptr;
123 XMLPropertyState
* pMargins
[4] = { nullptr, nullptr, nullptr, nullptr };
124 std::optional
<XMLPropertyState
> pNewMargins
[4];
125 XMLPropertyState
* pAllHeaderMarginProperty
= nullptr;
126 XMLPropertyState
* pHeaderMargins
[4] = { nullptr, nullptr, nullptr, nullptr };
127 std::optional
<XMLPropertyState
> pNewHeaderMargins
[4];
128 XMLPropertyState
* pAllFooterMarginProperty
= nullptr;
129 XMLPropertyState
* pFooterMargins
[4] = { nullptr, nullptr, nullptr, nullptr };
130 std::optional
<XMLPropertyState
> pNewFooterMargins
[4];
131 XMLPropertyState
* pMarginGutter
= nullptr;
132 XMLPropertyState
* pRtlGutter
= nullptr;
134 for (auto& rProp
: rProperties
)
136 XMLPropertyState
*property
= &rProp
;
137 sal_Int16 nContextID
= getPropertySetMapper()->GetEntryContextId(property
->mnIndex
);
138 if (property
->mnIndex
>= nStartIndex
&& property
->mnIndex
< nEndIndex
)
142 case CTF_PM_PADDINGALL
: pAllPaddingProperty
= property
; break;
143 case CTF_PM_PADDINGLEFT
: pPadding
[XML_LINE_LEFT
] = property
; break;
144 case CTF_PM_PADDINGRIGHT
: pPadding
[XML_LINE_RIGHT
] = property
; break;
145 case CTF_PM_PADDINGTOP
: pPadding
[XML_LINE_TOP
] = property
; break;
146 case CTF_PM_PADDINGBOTTOM
: pPadding
[XML_LINE_BOTTOM
] = property
; break;
147 case CTF_PM_BORDERALL
: pAllBorderProperty
= property
; break;
148 case CTF_PM_BORDERLEFT
: pBorders
[XML_LINE_LEFT
] = property
; break;
149 case CTF_PM_BORDERRIGHT
: pBorders
[XML_LINE_RIGHT
] = property
; break;
150 case CTF_PM_BORDERTOP
: pBorders
[XML_LINE_TOP
] = property
; break;
151 case CTF_PM_BORDERBOTTOM
: pBorders
[XML_LINE_BOTTOM
] = property
; break;
152 case CTF_PM_BORDERWIDTHALL
: pAllBorderWidthProperty
= property
; break;
153 case CTF_PM_BORDERWIDTHLEFT
: pBorderWidths
[XML_LINE_LEFT
] = property
; break;
154 case CTF_PM_BORDERWIDTHRIGHT
: pBorderWidths
[XML_LINE_RIGHT
] = property
; break;
155 case CTF_PM_BORDERWIDTHTOP
: pBorderWidths
[XML_LINE_TOP
] = property
; break;
156 case CTF_PM_BORDERWIDTHBOTTOM
: pBorderWidths
[XML_LINE_BOTTOM
] = property
; break;
157 case CTF_PM_HEADERPADDINGALL
: pAllHeaderPaddingProperty
= property
; break;
158 case CTF_PM_HEADERPADDINGLEFT
: pHeaderPadding
[XML_LINE_LEFT
] = property
; break;
159 case CTF_PM_HEADERPADDINGRIGHT
: pHeaderPadding
[XML_LINE_RIGHT
] = property
; break;
160 case CTF_PM_HEADERPADDINGTOP
: pHeaderPadding
[XML_LINE_TOP
] = property
; break;
161 case CTF_PM_HEADERPADDINGBOTTOM
: pHeaderPadding
[XML_LINE_BOTTOM
] = property
; break;
162 case CTF_PM_HEADERBORDERALL
: pAllHeaderBorderProperty
= property
; break;
163 case CTF_PM_HEADERBORDERLEFT
: pHeaderBorders
[XML_LINE_LEFT
] = property
; break;
164 case CTF_PM_HEADERBORDERRIGHT
: pHeaderBorders
[XML_LINE_RIGHT
] = property
; break;
165 case CTF_PM_HEADERBORDERTOP
: pHeaderBorders
[XML_LINE_TOP
] = property
; break;
166 case CTF_PM_HEADERBORDERBOTTOM
: pHeaderBorders
[XML_LINE_BOTTOM
] = property
; break;
167 case CTF_PM_HEADERBORDERWIDTHALL
: pAllHeaderBorderWidthProperty
= property
; break;
168 case CTF_PM_HEADERBORDERWIDTHLEFT
: pHeaderBorderWidths
[XML_LINE_LEFT
] = property
; break;
169 case CTF_PM_HEADERBORDERWIDTHRIGHT
: pHeaderBorderWidths
[XML_LINE_RIGHT
] = property
; break;
170 case CTF_PM_HEADERBORDERWIDTHTOP
: pHeaderBorderWidths
[XML_LINE_TOP
] = property
; break;
171 case CTF_PM_HEADERBORDERWIDTHBOTTOM
: pHeaderBorderWidths
[XML_LINE_BOTTOM
] = property
; break;
172 case CTF_PM_FOOTERPADDINGALL
: pAllFooterPaddingProperty
= property
; break;
173 case CTF_PM_FOOTERPADDINGLEFT
: pFooterPadding
[XML_LINE_LEFT
] = property
; break;
174 case CTF_PM_FOOTERPADDINGRIGHT
: pFooterPadding
[XML_LINE_RIGHT
] = property
; break;
175 case CTF_PM_FOOTERPADDINGTOP
: pFooterPadding
[XML_LINE_TOP
] = property
; break;
176 case CTF_PM_FOOTERPADDINGBOTTOM
: pFooterPadding
[XML_LINE_BOTTOM
] = property
; break;
177 case CTF_PM_FOOTERBORDERALL
: pAllFooterBorderProperty
= property
; break;
178 case CTF_PM_FOOTERBORDERLEFT
: pFooterBorders
[XML_LINE_LEFT
] = property
; break;
179 case CTF_PM_FOOTERBORDERRIGHT
: pFooterBorders
[XML_LINE_RIGHT
] = property
; break;
180 case CTF_PM_FOOTERBORDERTOP
: pFooterBorders
[XML_LINE_TOP
] = property
; break;
181 case CTF_PM_FOOTERBORDERBOTTOM
: pFooterBorders
[XML_LINE_BOTTOM
] = property
; break;
182 case CTF_PM_FOOTERBORDERWIDTHALL
: pAllFooterBorderWidthProperty
= property
; break;
183 case CTF_PM_FOOTERBORDERWIDTHLEFT
: pFooterBorderWidths
[XML_LINE_LEFT
] = property
; break;
184 case CTF_PM_FOOTERBORDERWIDTHRIGHT
: pFooterBorderWidths
[XML_LINE_RIGHT
] = property
; break;
185 case CTF_PM_FOOTERBORDERWIDTHTOP
: pFooterBorderWidths
[XML_LINE_TOP
] = property
; break;
186 case CTF_PM_FOOTERBORDERWIDTHBOTTOM
: pFooterBorderWidths
[XML_LINE_BOTTOM
] = property
; break;
187 case CTF_PM_HEADERHEIGHT
: pHeaderHeight
= property
; break;
188 case CTF_PM_HEADERMINHEIGHT
: pHeaderMinHeight
= property
; break;
189 case CTF_PM_FOOTERHEIGHT
: pFooterHeight
= property
; break;
190 case CTF_PM_FOOTERMINHEIGHT
: pFooterMinHeight
= property
; break;
191 case CTF_PM_MARGINALL
:
192 pAllMarginProperty
= property
; break;
193 case CTF_PM_MARGINTOP
:
194 pMargins
[XML_LINE_TOP
] = property
; break;
195 case CTF_PM_MARGINBOTTOM
:
196 pMargins
[XML_LINE_BOTTOM
] = property
; break;
197 case CTF_PM_MARGINLEFT
:
198 pMargins
[XML_LINE_LEFT
] = property
; break;
199 case CTF_PM_MARGINRIGHT
:
200 pMargins
[XML_LINE_RIGHT
] = property
; break;
201 case CTF_PM_MARGINGUTTER
:
202 pMarginGutter
= property
;
204 case CTF_PM_RTLGUTTER
:
205 pRtlGutter
= property
;
207 case CTF_PM_HEADERMARGINALL
:
208 pAllHeaderMarginProperty
= property
; break;
209 case CTF_PM_HEADERMARGINTOP
:
210 pHeaderMargins
[XML_LINE_TOP
] = property
; break;
211 case CTF_PM_HEADERMARGINBOTTOM
:
212 pHeaderMargins
[XML_LINE_BOTTOM
] = property
; break;
213 case CTF_PM_HEADERMARGINLEFT
:
214 pHeaderMargins
[XML_LINE_LEFT
] = property
; break;
215 case CTF_PM_HEADERMARGINRIGHT
:
216 pHeaderMargins
[XML_LINE_RIGHT
] = property
; break;
217 case CTF_PM_FOOTERMARGINALL
:
218 pAllFooterMarginProperty
= property
; break;
219 case CTF_PM_FOOTERMARGINTOP
:
220 pFooterMargins
[XML_LINE_TOP
] = property
; break;
221 case CTF_PM_FOOTERMARGINBOTTOM
:
222 pFooterMargins
[XML_LINE_BOTTOM
] = property
; break;
223 case CTF_PM_FOOTERMARGINLEFT
:
224 pFooterMargins
[XML_LINE_LEFT
] = property
; break;
225 case CTF_PM_FOOTERMARGINRIGHT
:
226 pFooterMargins
[XML_LINE_RIGHT
] = property
; break;
231 for (sal_uInt16 i
= 0; i
< 4; i
++)
233 if (pAllMarginProperty
&& !pMargins
[i
])
235 pNewMargins
[i
].emplace(
236 pAllMarginProperty
->mnIndex
+ 1 + i
,
237 pAllMarginProperty
->maValue
);
239 if (pAllHeaderMarginProperty
&& !pHeaderMargins
[i
])
241 pNewHeaderMargins
[i
].emplace(
242 pAllHeaderMarginProperty
->mnIndex
+ 1 + i
,
243 pAllHeaderMarginProperty
->maValue
);
245 if (pAllFooterMarginProperty
&& !pFooterMargins
[i
])
247 pNewFooterMargins
[i
].emplace(
248 pAllFooterMarginProperty
->mnIndex
+ 1 + i
,
249 pAllFooterMarginProperty
->maValue
);
251 if (pAllPaddingProperty
&& !pPadding
[i
])
252 pNewPadding
[i
] = new XMLPropertyState(pAllPaddingProperty
->mnIndex
+ 1 + i
, pAllPaddingProperty
->maValue
);
253 if (pAllBorderProperty
&& !pBorders
[i
])
255 pNewBorders
[i
] = new XMLPropertyState(pAllBorderProperty
->mnIndex
+ 1 + i
, pAllBorderProperty
->maValue
);
256 pBorders
[i
] = pNewBorders
[i
];
258 if( !pBorderWidths
[i
] )
259 pBorderWidths
[i
] = pAllBorderWidthProperty
;
261 pBorderWidths
[i
]->mnIndex
= -1;
264 table::BorderLine2 aBorderLine
;
265 pBorders
[i
]->maValue
>>= aBorderLine
;
266 if( pBorderWidths
[i
] )
268 table::BorderLine2 aBorderLineWidth
;
269 pBorderWidths
[i
]->maValue
>>= aBorderLineWidth
;
270 aBorderLine
.OuterLineWidth
= aBorderLineWidth
.OuterLineWidth
;
271 aBorderLine
.InnerLineWidth
= aBorderLineWidth
.InnerLineWidth
;
272 aBorderLine
.LineDistance
= aBorderLineWidth
.LineDistance
;
273 aBorderLine
.LineWidth
= aBorderLineWidth
.LineWidth
;
274 pBorders
[i
]->maValue
<<= aBorderLine
;
277 if (pAllHeaderPaddingProperty
&& !pHeaderPadding
[i
])
278 pHeaderNewPadding
[i
] = new XMLPropertyState(pAllHeaderPaddingProperty
->mnIndex
+ 1 + i
, pAllHeaderPaddingProperty
->maValue
);
279 if (pAllHeaderBorderProperty
&& !pHeaderBorders
[i
])
280 pHeaderNewBorders
[i
] = new XMLPropertyState(pAllHeaderBorderProperty
->mnIndex
+ 1 + i
, pAllHeaderBorderProperty
->maValue
);
281 if( !pHeaderBorderWidths
[i
] )
282 pHeaderBorderWidths
[i
] = pAllHeaderBorderWidthProperty
;
284 pHeaderBorderWidths
[i
]->mnIndex
= -1;
285 if( pHeaderBorders
[i
] )
287 table::BorderLine2 aBorderLine
;
288 pHeaderBorders
[i
]->maValue
>>= aBorderLine
;
289 if( pHeaderBorderWidths
[i
] )
291 table::BorderLine2 aBorderLineWidth
;
292 pHeaderBorderWidths
[i
]->maValue
>>= aBorderLineWidth
;
293 aBorderLine
.OuterLineWidth
= aBorderLineWidth
.OuterLineWidth
;
294 aBorderLine
.InnerLineWidth
= aBorderLineWidth
.InnerLineWidth
;
295 aBorderLine
.LineDistance
= aBorderLineWidth
.LineDistance
;
296 aBorderLine
.LineWidth
= aBorderLineWidth
.LineWidth
;
297 pHeaderBorders
[i
]->maValue
<<= aBorderLine
;
300 if (pAllFooterPaddingProperty
&& !pFooterPadding
[i
])
301 pFooterNewPadding
[i
] = new XMLPropertyState(pAllFooterPaddingProperty
->mnIndex
+ 1 + i
, pAllFooterPaddingProperty
->maValue
);
302 if (pAllFooterBorderProperty
&& !pFooterBorders
[i
])
303 pFooterNewBorders
[i
] = new XMLPropertyState(pAllFooterBorderProperty
->mnIndex
+ 1 + i
, pAllFooterBorderProperty
->maValue
);
304 if( !pFooterBorderWidths
[i
] )
305 pFooterBorderWidths
[i
] = pAllFooterBorderWidthProperty
;
307 pFooterBorderWidths
[i
]->mnIndex
= -1;
308 if( pFooterBorders
[i
] )
310 table::BorderLine2 aBorderLine
;
311 pFooterBorders
[i
]->maValue
>>= aBorderLine
;
312 if( pFooterBorderWidths
[i
] )
314 table::BorderLine2 aBorderLineWidth
;
315 pFooterBorderWidths
[i
]->maValue
>>= aBorderLineWidth
;
316 aBorderLine
.OuterLineWidth
= aBorderLineWidth
.OuterLineWidth
;
317 aBorderLine
.InnerLineWidth
= aBorderLineWidth
.InnerLineWidth
;
318 aBorderLine
.LineDistance
= aBorderLineWidth
.LineDistance
;
319 aBorderLine
.LineWidth
= aBorderLineWidth
.LineWidth
;
320 pFooterBorders
[i
]->maValue
<<= aBorderLine
;
327 xHeaderDynamic
.emplace(pHeaderHeight
->mnIndex
+ 2, Any(false));
329 if (pHeaderMinHeight
)
331 xHeaderDynamic
.emplace(pHeaderMinHeight
->mnIndex
+ 1, Any(true));
335 xFooterDynamic
.emplace(pFooterHeight
->mnIndex
+ 2, Any(false));
337 if (pFooterMinHeight
)
339 xFooterDynamic
.emplace(pFooterMinHeight
->mnIndex
+ 1, Any(true));
342 // fdo#38056: nerf the various AllFoo properties so they do not override
343 // the individual Foo properties later on
344 if (pAllPaddingProperty
)
346 pAllPaddingProperty
->mnIndex
= -1;
348 if (pAllBorderProperty
)
350 pAllBorderProperty
->mnIndex
= -1;
352 if (pAllBorderWidthProperty
)
354 pAllBorderWidthProperty
->mnIndex
= -1;
356 if (pAllHeaderPaddingProperty
)
358 pAllHeaderPaddingProperty
->mnIndex
= -1;
360 if (pAllHeaderBorderProperty
)
362 pAllHeaderBorderProperty
->mnIndex
= -1;
364 if (pAllHeaderBorderWidthProperty
)
366 pAllHeaderBorderWidthProperty
->mnIndex
= -1;
368 if (pAllFooterPaddingProperty
)
370 pAllFooterPaddingProperty
->mnIndex
= -1;
372 if (pAllFooterBorderProperty
)
374 pAllFooterBorderProperty
->mnIndex
= -1;
376 if (pAllFooterBorderWidthProperty
)
378 pAllFooterBorderWidthProperty
->mnIndex
= -1;
380 if (pAllMarginProperty
)
382 pAllMarginProperty
->mnIndex
= -1;
384 if (pAllHeaderMarginProperty
)
386 pAllHeaderMarginProperty
->mnIndex
= -1;
388 if (pAllFooterMarginProperty
)
390 pAllFooterMarginProperty
->mnIndex
= -1;
395 sal_Int32 nGutterMargin
{};
396 pMarginGutter
->maValue
>>= nGutterMargin
;
399 uno::Reference
<lang::XServiceInfo
> xSI(GetImport().GetModel(), uno::UNO_QUERY
);
400 if (xSI
.is() && xSI
->supportsService("com.sun.star.text.TextDocument"))
402 uno::Reference
<lang::XMultiServiceFactory
> xFac(GetImport().GetModel(), uno::UNO_QUERY
);
405 uno::Reference
<beans::XPropertySet
> xProps(
406 xFac
->createInstance("com.sun.star.document.Settings"), uno::UNO_QUERY
);
409 xProps
->getPropertyValue("GutterAtTop") >>= bGutterAtTop
;
415 if (nGutterMargin
&& pMargins
[XML_LINE_TOP
])
417 // Decrease top margin to not include gutter.
418 sal_Int32 nTopMargin
{};
419 pMargins
[XML_LINE_TOP
]->maValue
>>= nTopMargin
;
420 nTopMargin
-= nGutterMargin
;
421 pMargins
[XML_LINE_TOP
]->maValue
<<= nTopMargin
;
427 if (nGutterMargin
&& pRtlGutter
)
429 pRtlGutter
->maValue
>>= bRtlGutter
;
433 if (nGutterMargin
&& pMargins
[XML_LINE_RIGHT
])
435 // Decrease right margin to not include gutter.
436 sal_Int32 nRightMargin
{};
437 pMargins
[XML_LINE_RIGHT
]->maValue
>>= nRightMargin
;
438 nRightMargin
-= nGutterMargin
;
439 pMargins
[XML_LINE_RIGHT
]->maValue
<<= nRightMargin
;
444 if (nGutterMargin
&& pMargins
[XML_LINE_LEFT
])
446 // Decrease left margin to not include gutter.
447 sal_Int32 nLeftMargin
{};
448 pMargins
[XML_LINE_LEFT
]->maValue
>>= nLeftMargin
;
449 nLeftMargin
-= nGutterMargin
;
450 pMargins
[XML_LINE_LEFT
]->maValue
<<= nLeftMargin
;
457 // The following code adds into the rProperties vector, so all the
458 // XMLPropertyState* pointers that are pointing to the rProperties
459 // elements could potentially be deallocated, so don't use them after
461 for (sal_uInt16 i
= 0; i
< 4; i
++)
465 rProperties
.push_back(*pNewMargins
[i
]);
467 if (pNewHeaderMargins
[i
])
469 rProperties
.push_back(*pNewHeaderMargins
[i
]);
471 if (pNewFooterMargins
[i
])
473 rProperties
.push_back(*pNewFooterMargins
[i
]);
477 rProperties
.push_back(*pNewPadding
[i
]);
478 delete pNewPadding
[i
];
482 rProperties
.push_back(*pNewBorders
[i
]);
483 delete pNewBorders
[i
];
485 if (pHeaderNewPadding
[i
])
487 rProperties
.push_back(*pHeaderNewPadding
[i
]);
488 delete pHeaderNewPadding
[i
];
490 if (pHeaderNewBorders
[i
])
492 rProperties
.push_back(*pHeaderNewBorders
[i
]);
493 delete pHeaderNewBorders
[i
];
495 if (pFooterNewPadding
[i
])
497 rProperties
.push_back(*pFooterNewPadding
[i
]);
498 delete pFooterNewPadding
[i
];
500 if (pFooterNewBorders
[i
])
502 rProperties
.push_back(*pFooterNewBorders
[i
]);
503 delete pFooterNewBorders
[i
];
506 // CAUTION - do not use XMLPropertyState* pointers (like pMargins,
507 // pMarginGutter) after this.
511 rProperties
.push_back(*xHeaderDynamic
);
512 xHeaderDynamic
.reset();
516 rProperties
.push_back(*xFooterDynamic
);
517 xFooterDynamic
.reset();
521 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */