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 #include <oox/vml/vmlshapecontainer.hxx>
22 #include <oox/vml/vmldrawing.hxx>
23 #include <oox/vml/vmlshape.hxx>
25 #include <osl/diagnose.h>
30 using namespace ::com::sun::star::awt
;
31 using namespace ::com::sun::star::drawing
;
32 using namespace ::com::sun::star::uno
;
36 template< typename ShapeType
>
37 void lclMapShapesById( RefMap
< OUString
, ShapeType
>& orMap
, const RefVector
< ShapeType
>& rVector
)
39 for (auto const& elem
: rVector
)
41 const OUString
& rShapeId
= elem
->getShapeId();
42 OSL_ENSURE( !rShapeId
.isEmpty(), "lclMapShapesById - missing shape identifier" );
43 if( !rShapeId
.isEmpty() )
45 OSL_ENSURE( orMap
.find( rShapeId
) == orMap
.end(), "lclMapShapesById - shape identifier already used " );
46 orMap
[ rShapeId
] = elem
;
53 ShapeContainer::ShapeContainer( Drawing
& rDrawing
) :
58 ShapeContainer::~ShapeContainer()
62 std::shared_ptr
<ShapeType
> ShapeContainer::createShapeType()
64 std::shared_ptr
< ShapeType
> xShape( new ShapeType( mrDrawing
) );
65 maTypes
.push_back( xShape
);
69 void ShapeContainer::finalizeFragmentImport()
71 // map all shape templates by shape identifier
72 lclMapShapesById( maTypesById
, maTypes
);
73 // map all shapes by shape identifier
74 lclMapShapesById( maShapesById
, maShapes
);
75 /* process all shapes (map all children templates/shapes in group shapes,
76 resolve template references in all shapes) */
77 maShapes
.forEachMem( &ShapeBase::finalizeFragmentImport
);
80 const ShapeType
* ShapeContainer::getShapeTypeById( const OUString
& rShapeId
) const
82 // search in own shape template list
83 if( const ShapeType
* pType
= maTypesById
.get( rShapeId
).get() )
85 // search deep in child shapes
86 for (auto const& shape
: maShapes
)
87 if( const ShapeType
* pType
= shape
->getChildTypeById( rShapeId
) )
92 const ShapeBase
* ShapeContainer::getShapeById( const OUString
& rShapeId
) const
94 // search in own shape list
95 if( const ShapeBase
* pShape
= maShapesById
.get( rShapeId
).get() )
97 // search deep in child shapes
98 for (auto const& shape
: maShapes
)
99 if( const ShapeBase
* pShape
= shape
->getChildById( rShapeId
) )
104 std::shared_ptr
< ShapeBase
> ShapeContainer::takeLastShape()
106 OSL_ENSURE( mrDrawing
.getType() == VMLDRAWING_WORD
, "ShapeContainer::takeLastShape - illegal call, Word filter only" );
107 assert( !markStack
.empty());
108 if( markStack
.top() >= maShapes
.size())
109 return std::shared_ptr
< ShapeBase
>();
110 std::shared_ptr
< ShapeBase
> ret
= maShapes
.back();
115 void ShapeContainer::pushMark()
117 markStack
.push( maShapes
.size());
120 void ShapeContainer::popMark()
122 assert( !markStack
.empty());
126 void ShapeContainer::convertAndInsert( const Reference
< XShapes
>& rxShapes
, const ShapeParentAnchor
* pParentAnchor
) const
128 for (auto const& shape
: maShapes
)
129 shape
->convertAndInsert( rxShapes
, pParentAnchor
);
135 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */