Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/src/netedit/changes/GNEChange_DataSet.cpp
169678 views
1
/****************************************************************************/
2
// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3
// Copyright (C) 2001-2025 German Aerospace Center (DLR) and others.
4
// This program and the accompanying materials are made available under the
5
// terms of the Eclipse Public License 2.0 which is available at
6
// https://www.eclipse.org/legal/epl-2.0/
7
// This Source Code may also be made available under the following Secondary
8
// Licenses when the conditions for such availability set forth in the Eclipse
9
// Public License 2.0 are satisfied: GNU General Public License, version 2
10
// or later which is available at
11
// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13
/****************************************************************************/
14
/// @file GNEChange_DataSet.cpp
15
/// @author Pablo Alvarez Lopez
16
/// @date Jan 2020
17
///
18
// A network change in which a data set element is created or deleted
19
/****************************************************************************/
20
21
#include <netedit/GNENet.h>
22
#include <netedit/GNEViewNet.h>
23
#include <netedit/GNEViewParent.h>
24
#include <netedit/GNEApplicationWindow.h>
25
#include <netedit/elements/data/GNEDataSet.h>
26
27
#include "GNEChange_DataSet.h"
28
29
// ===========================================================================
30
// FOX-declarations
31
// ===========================================================================
32
33
FXIMPLEMENT_ABSTRACT(GNEChange_DataSet, GNEChange, nullptr, 0)
34
35
// ===========================================================================
36
// member method definitions
37
// ===========================================================================
38
39
GNEChange_DataSet::GNEChange_DataSet(GNEDataSet* dataSet, bool forward) :
40
GNEChange(Supermode::DATA, forward, dataSet->isAttributeCarrierSelected()),
41
myDataSet(dataSet) {
42
myDataSet->incRef("GNEChange_DataSet");
43
}
44
45
46
GNEChange_DataSet::~GNEChange_DataSet() {
47
// only continue we have undo-redo mode enabled
48
if (myDataSet->getNet()->getViewNet()->getViewParent()->getGNEAppWindows()->isUndoRedoAllowed()) {
49
myDataSet->decRef("GNEChange_DataSet");
50
if (myDataSet->unreferenced() &&
51
myDataSet->getNet()->getAttributeCarriers()->retrieveDataSet(myDataSet->getID(), false)) {
52
// make sure that element isn't in net before removing
53
myDataSet->getNet()->getAttributeCarriers()->deleteDataSet(myDataSet);
54
// delete data set
55
delete myDataSet;
56
}
57
}
58
}
59
60
61
void
62
GNEChange_DataSet::undo() {
63
if (myForward) {
64
// delete data set from net
65
myDataSet->getNet()->getAttributeCarriers()->deleteDataSet(myDataSet);
66
} else {
67
// insert data set into net
68
myDataSet->getNet()->getAttributeCarriers()->insertDataSet(myDataSet);
69
}
70
// require always save elements
71
myDataSet->getNet()->getSavingStatus()->requireSaveDataElements();
72
}
73
74
75
void
76
GNEChange_DataSet::redo() {
77
if (myForward) {
78
// insert data set into net
79
myDataSet->getNet()->getAttributeCarriers()->insertDataSet(myDataSet);
80
} else {
81
// delete data set from net
82
myDataSet->getNet()->getAttributeCarriers()->deleteDataSet(myDataSet);
83
}
84
// require always save elements
85
myDataSet->getNet()->getSavingStatus()->requireSaveDataElements();
86
}
87
88
89
std::string
90
GNEChange_DataSet::undoName() const {
91
if (myForward) {
92
return (TL("Undo create ") + myDataSet->getTagStr() + " '" + myDataSet->getID() + "'");
93
} else {
94
return (TL("Undo delete ") + myDataSet->getTagStr() + " '" + myDataSet->getID() + "'");
95
}
96
}
97
98
99
std::string
100
GNEChange_DataSet::redoName() const {
101
if (myForward) {
102
return (TL("Redo create ") + myDataSet->getTagStr() + " '" + myDataSet->getID() + "'");
103
} else {
104
return (TL("Redo delete ") + myDataSet->getTagStr() + " '" + myDataSet->getID() + "'");
105
}
106
}
107
108
109
/****************************************************************************/
110
111