Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/src/netedit/changes/GNEChange_Children.h
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_Children.h
15
/// @author Pablo Alvarez Lopez
16
/// @date Jul 2019
17
///
18
// A network change used to modify sorting of hierarchical element children
19
/****************************************************************************/
20
#pragma once
21
#include <config.h>
22
23
#include "GNEChange.h"
24
25
// ===========================================================================
26
// class definitions
27
// ===========================================================================
28
/**
29
* @class GNEChange_Children
30
* A network change in which a additional element is created or deleted
31
*/
32
class GNEChange_Children : public GNEChange {
33
FXDECLARE_ABSTRACT(GNEChange_Children)
34
35
public:
36
// @brief operation over child demand element
37
enum Operation {
38
MOVE_FRONT = 0, // Move element one position front
39
MOVE_BACK = 1 // Move element one position back
40
};
41
42
/**@brief Constructor for creating/deleting an additional element
43
* @param[in] additional The additional element to be created/deleted
44
* @param[in] forward Whether to create/delete (true/false)
45
*/
46
GNEChange_Children(GNEDemandElement* demandElementParent, GNEDemandElement* demandElementChild, const Operation operation);
47
48
/// @brief Destructor
49
~GNEChange_Children();
50
51
/// @name inherited from GNEChange
52
/// @{
53
/// @brief get undo Name
54
std::string undoName() const;
55
56
/// @brief get Redo name
57
std::string redoName() const;
58
59
/// @brief undo action
60
void undo();
61
62
/// @brief redo action
63
void redo();
64
/// @}
65
66
private:
67
/**@brief full information regarding the parent demand element element that will be modified
68
* @note we assume shared responsibility for the pointer (via reference counting)
69
*/
70
GNEDemandElement* myParentDemandElement;
71
72
/// @brief demand element which position will be edited edited
73
GNEDemandElement* myChildDemandElement;
74
75
// @brief Operation to be apply
76
const Operation myOperation;
77
78
/// @brief copy of child demand elements before apply operation
79
const GNEHierarchicalContainerChildren<GNEDemandElement*> myOriginalChildElements;
80
81
/// @brief element children after apply operation
82
GNEHierarchicalContainerChildren<GNEDemandElement*> myEditedChildElements;
83
};
84
85