1
////////////////////////////////////////////////////////////////////////////////
3
// This file is part of Toolkit for Conceptual Modeling (TCM).
4
// (c) copyright 1995, Vrije Universiteit Amsterdam.
5
// Author: Frank Dehne (frank@cs.vu.nl).
7
// TCM is free software; you can redistribute it and/or modify
8
// it under the terms of the GNU General Public License as published by
9
// the Free Software Foundation; either version 2 of the License, or
10
// (at your option) any later version.
12
// TCM is distributed in the hope that it will be useful,
13
// but WITHOUT ANY WARRANTY; without even the implied warranty of
14
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
// GNU General Public License for more details.
17
// You should have received a copy of the GNU General Public License
18
// along with TCM; if not, write to the Free Software
19
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
21
////////////////////////////////////////////////////////////////////////////////
22
#include "diagramviewer.h"
23
#include "shapeview.h"
26
#include "selectallcmd.h"
28
SelectAllCmd::SelectAllCmd(ShapeView *v):
29
Command(v->GetViewer()->GetDiagram(), v->GetViewer()) {
31
oldSelection = new List<GShape *>(*view->GetSelection());
34
SelectAllCmd::~SelectAllCmd() {
38
void SelectAllCmd::Execute() {
39
List<GShape *> *shapes = view->GetShapes();
40
for (shapes->first(); !shapes->done(); shapes->next()) {
41
GShape *shape = shapes->cur();
42
if (!shape->IsSelected() && shape->IsVisible())
43
view->SelectShape(shape);
49
void SelectAllCmd::UnExecute() {
51
for (oldSelection->first(); !oldSelection->done();
52
oldSelection->next()) {
53
GShape *shape = oldSelection->cur();
54
view->SelectShape(shape);