Warning, file /office/calligra/braindump/src/Utils.cpp was not indexed or was modified since last indexation (in which case cross-reference links may be missing, inaccurate or erroneous).

0001 /*
0002  *  Copyright (c) 2009 Cyrille Berger <cberger@cberger.net>
0003  *
0004  * This library is free software; you can redistribute it and/or
0005  * modify it under the terms of the GNU Lesser General Public
0006  * License as published by the Free Software Foundation;
0007  * either version 2, or (at your option) any later version of the License.
0008  *
0009  * This library is distributed in the hope that it will be useful,
0010  * but WITHOUT ANY WARRANTY; without even the implied warranty of
0011  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
0012  * Lesser General Public License for more details.
0013  *
0014  * You should have received a copy of the GNU Lesser General Public License
0015  * along with this library; see the file COPYING.  If not, write to
0016  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
0017  * Boston, MA 02110-1301, USA.
0018  */
0019 
0020 #include "Utils.h"
0021 
0022 #include <QRectF>
0023 
0024 #include <KoShape.h>
0025 
0026 #include <KoShapeContainer.h>
0027 
0028 #include "SectionGroup.h"
0029 #include "Section.h"
0030 #include "SectionContainer.h"
0031 
0032 void Utils::containerBoundRec(QList<KoShape*> shapes, QRectF& b)
0033 {
0034     foreach(KoShape * shape, shapes) {
0035         containerBoundRec(shape, b);
0036     }
0037 }
0038 
0039 void Utils::containerBoundRec(KoShape* shape, QRectF& b)
0040 {
0041     b |= shape->boundingRect();
0042     KoShapeContainer* cont = dynamic_cast<KoShapeContainer*>(shape);
0043     if(cont) {
0044         containerBoundRec(cont->shapes(), b);
0045     }
0046 }
0047 
0048 Section* Utils::sectionForLayer(KoShapeLayer* _layer, SectionGroup* _sectionGroup)
0049 {
0050     foreach(Section * section, _sectionGroup->sections()) {
0051         if(section->sectionContainer()->layer() == _layer) {
0052             return section;
0053         }
0054         if(Section* ls = sectionForLayer(_layer, section)) {
0055             return ls;
0056         }
0057     }
0058     return 0;
0059 }