LibreOffice Module xmloff (master)  1
AttributeContainerHandler.cxx
Go to the documentation of this file.
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3  * This file is part of the LibreOffice project.
4  *
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/.
8  *
9  * This file incorporates work covered by the following license notice:
10  *
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 .
18  */
19 
20 #include <com/sun/star/container/XNameContainer.hpp>
21 #include <com/sun/star/xml/AttributeData.hpp>
22 #include <com/sun/star/uno/Any.hxx>
23 
25 
26 using namespace ::com::sun::star;
27 using namespace ::com::sun::star::uno;
28 using namespace ::com::sun::star::container;
29 
30 
31 
32 
34 {
35  // nothing to do
36 }
37 
39  const Any& r1,
40  const Any& r2 ) const
41 {
42  Reference< XNameContainer > xContainer1;
43  Reference< XNameContainer > xContainer2;
44 
45  if( ( r1 >>= xContainer1 ) && ( r2 >>= xContainer2 ) )
46  {
47  const uno::Sequence< OUString > aAttribNames1( xContainer1->getElementNames() );
48  uno::Sequence< OUString > aAttribNames2( xContainer2->getElementNames() );
49 
50  if( aAttribNames1.getLength() == aAttribNames2.getLength() )
51  {
52  xml::AttributeData aData1;
53  xml::AttributeData aData2;
54 
55  for( const OUString& rAttribName : aAttribNames1 )
56  {
57  if( !xContainer2->hasByName( rAttribName ) )
58  return false;
59 
60  xContainer1->getByName( rAttribName ) >>= aData1;
61  xContainer2->getByName( rAttribName ) >>= aData2;
62 
63  if( ( aData1.Namespace != aData2.Namespace ) ||
64  ( aData1.Type != aData2.Type ) ||
65  ( aData1.Value != aData2.Value ) )
66  return false;
67  }
68 
69  return true;
70  }
71  }
72 
73  return false;
74 }
75 
76 bool XMLAttributeContainerHandler::importXML( const OUString& /*rStrImpValue*/, Any& /*rValue*/, const SvXMLUnitConverter& /*rUnitConverter*/ ) const
77 {
78  return true;
79 }
80 
81 bool XMLAttributeContainerHandler::exportXML( OUString& /*rStrExpValue*/, const Any& /*rValue*/, const SvXMLUnitConverter& /*rUnitConverter*/ ) const
82 {
83  return true;
84 }
85 
86 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
the SvXMLTypeConverter converts values of various types from their internal representation to the tex...
Definition: xmluconv.hxx:77
virtual bool importXML(const OUString &rStrImpValue, css::uno::Any &rValue, const SvXMLUnitConverter &rUnitConverter) const override
Imports the given value according to the XML-data-type corresponding to the derived class...
virtual bool exportXML(OUString &rStrExpValue, const css::uno::Any &rValue, const SvXMLUnitConverter &rUnitConverter) const override
Exports the given value according to the XML-data-type corresponding to the derived class...
virtual bool equals(const css::uno::Any &r1, const css::uno::Any &r2) const override
Compares two Any's in case of the given XML-data-type.