Avoid potential negative array index access to cached text.
[LibreOffice.git] / writerfilter / source / dmapper / PropertyMapHelper.cxx
bloba944dc147aa493c2d2eabe34289292e2c3341e4e
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 #include <com/sun/star/text/TableColumnSeparator.hpp>
21 #include "TagLogger.hxx"
22 #include "PropertyMapHelper.hxx"
24 namespace writerfilter::dmapper
26 using namespace ::com::sun::star;
28 void lcl_DumpTableColumnSeparators(const uno::Any& rTableColumnSeparators)
30 #ifdef DBG_UTIL
31 uno::Sequence<text::TableColumnSeparator> aSeq;
32 rTableColumnSeparators >>= aSeq;
34 TagLogger::getInstance().startElement("property.TableColumnSeparators");
36 sal_uInt32 nLength = aSeq.getLength();
37 for (sal_uInt32 n = 0; n < nLength; ++n)
39 TagLogger::getInstance().startElement("separator");
41 TagLogger::getInstance().attribute("position", aSeq[n].Position);
42 TagLogger::getInstance().attribute("visible", sal_uInt32(aSeq[n].IsVisible));
44 TagLogger::getInstance().endElement();
47 TagLogger::getInstance().endElement();
48 #else
49 (void)rTableColumnSeparators;
50 #endif // DBG_UTIL
53 #ifdef DBG_UTIL
54 void lcl_DumpPropertyValues(beans::PropertyValues const& rValues)
56 TagLogger::getInstance().startElement("propertyValues");
58 for (beans::PropertyValue const& propVal : rValues)
60 TagLogger::getInstance().startElement("propertyValue");
62 TagLogger::getInstance().attribute("name", propVal.Name);
64 try
66 sal_Int32 aInt = 0;
67 propVal.Value >>= aInt;
68 TagLogger::getInstance().attribute("value", aInt);
70 catch (...)
74 if (propVal.Name == "TableColumnSeparators")
76 lcl_DumpTableColumnSeparators(propVal.Value);
79 TagLogger::getInstance().endElement();
81 TagLogger::getInstance().endElement();
84 void lcl_DumpPropertyValueSeq(css::uno::Sequence<css::beans::PropertyValues> const& rPropValSeq)
86 TagLogger::getInstance().startElement("PropertyValueSeq");
88 for (auto const& propVal : rPropValSeq)
90 lcl_DumpPropertyValues(propVal);
93 TagLogger::getInstance().endElement();
95 #endif // DBG_UTIL
98 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */