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"
28 // ============================================================================
30 using namespace ::com::sun::star::awt
;
31 using namespace ::com::sun::star::drawing
;
32 using namespace ::com::sun::star::uno
;
34 // ============================================================================
38 template< typename ShapeType
>
39 void lclMapShapesById( RefMap
< OUString
, ShapeType
>& orMap
, const RefVector
< ShapeType
>& rVector
)
41 for( typename RefVector
< ShapeType
>::const_iterator aIt
= rVector
.begin(), aEnd
= rVector
.end(); aIt
!= aEnd
; ++aIt
)
43 const OUString
& rShapeId
= (*aIt
)->getShapeId();
44 OSL_ENSURE( !rShapeId
.isEmpty(), "lclMapShapesById - missing shape identifier" );
45 if( !rShapeId
.isEmpty() )
47 OSL_ENSURE( orMap
.find( rShapeId
) == orMap
.end(), "lclMapShapesById - shape identifier already used " );
48 orMap
[ rShapeId
] = *aIt
;
55 // ============================================================================
57 ShapeContainer::ShapeContainer( Drawing
& rDrawing
) :
62 ShapeContainer::~ShapeContainer()
66 ShapeType
& ShapeContainer::createShapeType()
68 ::boost::shared_ptr
< ShapeType
> xShape( new ShapeType( mrDrawing
) );
69 maTypes
.push_back( xShape
);
73 void ShapeContainer::finalizeFragmentImport()
75 // map all shape templates by shape identifier
76 lclMapShapesById( maTypesById
, maTypes
);
77 // map all shapes by shape identifier
78 lclMapShapesById( maShapesById
, maShapes
);
79 /* process all shapes (map all children templates/shapes in group shapes,
80 resolve template references in all shapes) */
81 maShapes
.forEachMem( &ShapeBase::finalizeFragmentImport
);
84 const ShapeType
* ShapeContainer::getShapeTypeById( const OUString
& rShapeId
, bool bDeep
) const
86 // search in own shape template list
87 if( const ShapeType
* pType
= maTypesById
.get( rShapeId
).get() )
89 // search deep in child shapes
91 for( ShapeVector::const_iterator aVIt
= maShapes
.begin(), aVEnd
= maShapes
.end(); aVIt
!= aVEnd
; ++aVIt
)
92 if( const ShapeType
* pType
= (*aVIt
)->getChildTypeById( rShapeId
) )
97 const ShapeBase
* ShapeContainer::getShapeById( const OUString
& rShapeId
, bool bDeep
) const
99 // search in own shape list
100 if( const ShapeBase
* pShape
= maShapesById
.get( rShapeId
).get() )
102 // search deep in child shapes
104 for( ShapeVector::const_iterator aVIt
= maShapes
.begin(), aVEnd
= maShapes
.end(); aVIt
!= aVEnd
; ++aVIt
)
105 if( const ShapeBase
* pShape
= (*aVIt
)->getChildById( rShapeId
) )
110 boost::shared_ptr
< ShapeBase
> ShapeContainer::takeLastShape()
112 OSL_ENSURE( mrDrawing
.getType() == VMLDRAWING_WORD
, "ShapeContainer::takeLastShape - illegal call, Word filter only" );
113 assert( !markStack
.empty());
114 if( markStack
.top() >= maShapes
.size())
115 return boost::shared_ptr
< ShapeBase
>();
116 boost::shared_ptr
< ShapeBase
> ret
= maShapes
.back();
121 void ShapeContainer::pushMark()
123 markStack
.push( maShapes
.size());
126 void ShapeContainer::popMark()
128 assert( !markStack
.empty());
132 void ShapeContainer::convertAndInsert( const Reference
< XShapes
>& rxShapes
, const ShapeParentAnchor
* pParentAnchor
) const
134 for( ShapeVector::const_iterator aIt
= maShapes
.begin(), aEnd
= maShapes
.end(); aIt
!= aEnd
; ++aIt
)
135 (*aIt
)->convertAndInsert( rxShapes
, pParentAnchor
);
138 // ============================================================================
143 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */