Path: blob/main/src/netedit/changes/GNEChange_Additional.h
169678 views
/****************************************************************************/1// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo2// Copyright (C) 2001-2025 German Aerospace Center (DLR) and others.3// This program and the accompanying materials are made available under the4// terms of the Eclipse Public License 2.0 which is available at5// https://www.eclipse.org/legal/epl-2.0/6// This Source Code may also be made available under the following Secondary7// Licenses when the conditions for such availability set forth in the Eclipse8// Public License 2.0 are satisfied: GNU General Public License, version 29// or later which is available at10// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html11// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later12/****************************************************************************/13/// @file GNEChange_Additional.h14/// @author Pablo Alvarez Lopez15/// @date Nov 201516///17// A network change in which a additional element is created or deleted18/****************************************************************************/19#pragma once20#include <config.h>2122#include "GNEChange.h"232425// ===========================================================================26// class definitions27// ===========================================================================28/**29* @class GNEChange_Additional30* A network change in which a additional element is created or deleted31*/32class GNEChange_Additional : public GNEChange {33FXDECLARE_ABSTRACT(GNEChange_Additional)3435public:36/**@brief Constructor for creating/deleting an additional element37* @param[in] additional The additional element to be created/deleted38* @param[in] forward Whether to create/delete (true/false)39*/40GNEChange_Additional(GNEAdditional* additional, bool forward);4142/// @brief Destructor43~GNEChange_Additional();4445/// @name inherited from GNEChange46/// @{47/// @brief get undo Name48std::string undoName() const;4950/// @brief get Redo name51std::string redoName() const;5253/// @brief undo action54void undo();5556/// @brief redo action57void redo();58/// @}5960private:61/**@brief full information regarding the additional element that is to be created/deleted62* @note we assume shared responsibility for the pointer (via reference counting)63*/64GNEAdditional* myAdditional;65};666768