Eclipse SUMO - Simulation of Urban MObility
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
GNEChange_TLS Class Reference

#include <GNEChange_TLS.h>

Inheritance diagram for GNEChange_TLS:
[legend]
Collaboration diagram for GNEChange_TLS:
[legend]

Public Member Functions

 GNEChange_TLS (GNEJunction *junction, NBTrafficLightDefinition *tlDef, bool forward, bool forceInsert=false, const std::string tlID="")
 Constructor for creating/deleting a TLS.
 
 GNEChange_TLS (GNEJunction *junction, NBTrafficLightDefinition *tlDef, bool forward, TrafficLightType type, bool forceInsert=false, const std::string tlID="")
 Constructor for creating/deleting a TLS.
 
 GNEChange_TLS (GNEJunction *junction, NBTrafficLightDefinition *tlDef, const std::string &newID)
 Constructor for renaming a TLS.
 
 ~GNEChange_TLS ()
 Destructor.
 
inherited from GNEChange

get undo Name

std::string undoName () const
 return undoName
 
std::string redoName () const
 get Redo name
 
void undo ()
 undo action
 
void redo ()
 redo action
 

Private Attributes

const bool myForceInsert
 check if forceInsert is enabled
 
GNEJunctionmyJunction
 we need the junction because it is the target of our change commands
 
const std::string myNewID
 
const std::string myOldID
 variables used for renaming TLS
 
NBTrafficLightDefinitionmyTlDef
 the traffic light to be created/deleted. We assume no responsibility for the pointer
 

friend class

GNEChangenext
 
virtual int size () const
 Return the size of the command group.
 
Supermode getSupermode () const
 get supermode
 
bool canMerge () const
 Return TRUE if this command can be merged with previous undo commands. This is useful to combine e.g. multiple consecutive single-character text changes into a single block change. The default implementation returns FALSE.
 
bool mergeWith (GNEChange *command)
 Called by the undo system to try and merge the new incoming command with this command; should return TRUE if merging was possible. The default implementation returns FALSE.
 
const Supermode mySupermode
 supermode related with this change
 
const GNEHierarchicalStructureParents myParents
 Hierarchical container with parents.
 
bool myForward
 we group antagonistic commands (create junction/delete junction) and keep them apart by this flag
 
const bool mySelectedElement
 flag for check if element is selected
 
template<typename T >
void addElementInParentsAndChildren (T *element)
 add given element in parents and children
 
template<typename T >
void removeElementFromParentsAndChildren (T *element)
 remove given element from parents and children
 

Detailed Description

A network change in which a traffic light is created or deleted

Definition at line 34 of file GNEChange_TLS.h.

Constructor & Destructor Documentation

◆ GNEChange_TLS() [1/3]

GNEChange_TLS::GNEChange_TLS ( GNEJunction junction,
NBTrafficLightDefinition tlDef,
bool  forward,
bool  forceInsert = false,
const std::string  tlID = "" 
)

Constructor for creating/deleting a TLS.

Parameters
[in]junctionThe junction to which the traffic light belong
[in]tlDefThe traffic light definition (may be 0 on creation)
[in]forwardWhether to create/delete (true/false)
[in]tlIDThe id for the newly created tlDef (set to junction id if * "" is given)

Definition at line 40 of file GNEChange_TLS.cpp.

References StringBijection< T >::get(), OptionsCont::getOptions(), and SUMOXMLDefinitions::TrafficLightTypes.

◆ GNEChange_TLS() [2/3]

GNEChange_TLS::GNEChange_TLS ( GNEJunction junction,
NBTrafficLightDefinition tlDef,
bool  forward,
TrafficLightType  type,
bool  forceInsert = false,
const std::string  tlID = "" 
)

Constructor for creating/deleting a TLS.

Parameters
[in]junctionThe junction to which the traffic light belong
[in]tlDefThe traffic light definition (may be 0 on creation)
[in]forwardWhether to create/delete (true/false)
[in]tlIDThe id for the newly created tlDef (set to junction id if * "" is given)
[in]typeTrafficLightType

Definition at line 62 of file GNEChange_TLS.cpp.

References NBNode::getControllingTLS(), GUIGlObject::getMicrosimID(), GNEJunction::getNBNode(), GNEReferenceCounter::incRef(), NBNode::isTLControlled(), myJunction, and myTlDef.

◆ GNEChange_TLS() [3/3]

GNEChange_TLS::GNEChange_TLS ( GNEJunction junction,
NBTrafficLightDefinition tlDef,
const std::string &  newID 
)

Constructor for renaming a TLS.

Parameters
[in]junctionThe junction to which the traffic light belong
[in]tlDefThe traffic light definition (may be 0 on creation)
[in]newIDnew TL ID

Definition at line 83 of file GNEChange_TLS.cpp.

References GNEReferenceCounter::incRef(), and myJunction.

◆ ~GNEChange_TLS()

Member Function Documentation

◆ addElementInParentsAndChildren()

template<typename T >
void GNEChange::addElementInParentsAndChildren ( T *  element)
inlineprotectedinherited

◆ canMerge()

bool GNEChange::canMerge ( ) const
inherited

Return TRUE if this command can be merged with previous undo commands. This is useful to combine e.g. multiple consecutive single-character text changes into a single block change. The default implementation returns FALSE.

Definition at line 72 of file GNEChange.cpp.

Referenced by GNEUndoList::add().

Here is the caller graph for this function:

◆ getSupermode()

Supermode GNEChange::getSupermode ( ) const
inherited

get supermode

Definition at line 66 of file GNEChange.cpp.

References GNEChange::mySupermode.

Referenced by GNEUndoList::getRedoSupermode(), and GNEUndoList::getUndoSupermode().

Here is the caller graph for this function:

◆ mergeWith()

bool GNEChange::mergeWith ( GNEChange command)
inherited

Called by the undo system to try and merge the new incoming command with this command; should return TRUE if merging was possible. The default implementation returns FALSE.

Definition at line 78 of file GNEChange.cpp.

Referenced by GNEUndoList::add().

Here is the caller graph for this function:

◆ redo()

◆ redoName()

std::string GNEChange_TLS::redoName ( ) const
virtual

get Redo name

Implements GNEChange.

Definition at line 164 of file GNEChange_TLS.cpp.

References GNEAttributeCarrier::getID(), GNEChange::myForward, myJunction, and TL.

◆ removeElementFromParentsAndChildren()

template<typename T >
void GNEChange::removeElementFromParentsAndChildren ( T *  element)
inlineprotectedinherited

◆ size()

int GNEChange::size ( ) const
virtualinherited

Return the size of the command group.

Reimplemented in GNEChangeGroup.

Definition at line 59 of file GNEChange.cpp.

Referenced by GNEUndoList::currentCommandGroupSize(), and GNEChangeGroup::size().

Here is the caller graph for this function:

◆ undo()

◆ undoName()

std::string GNEChange_TLS::undoName ( ) const
virtual

return undoName

Implements GNEChange.

Definition at line 154 of file GNEChange_TLS.cpp.

References GNEAttributeCarrier::getID(), GNEChange::myForward, myJunction, and TL.

Field Documentation

◆ myForceInsert

const bool GNEChange_TLS::myForceInsert
private

check if forceInsert is enabled

Definition at line 94 of file GNEChange_TLS.h.

Referenced by redo(), and undo().

◆ myForward

bool GNEChange::myForward
protectedinherited

we group antagonistic commands (create junction/delete junction) and keep them apart by this flag

Definition at line 180 of file GNEChange.h.

Referenced by GNEChange_Additional::redo(), GNEChange_Children::redo(), GNEChange_Connection::redo(), GNEChange_Crossing::redo(), GNEChange_DataInterval::redo(), GNEChange_DataSet::redo(), GNEChange_DemandElement::redo(), GNEChange_Edge::redo(), GNEChange_EdgeType::redo(), GNEChange_GenericData::redo(), GNEChange_Junction::redo(), GNEChange_Lane::redo(), GNEChange_MeanData::redo(), GNEChange_TAZSourceSink::redo(), redo(), GNEChange_Additional::redoName(), GNEChange_Children::redoName(), GNEChange_Connection::redoName(), GNEChange_Crossing::redoName(), GNEChange_DataInterval::redoName(), GNEChange_DataSet::redoName(), GNEChange_DemandElement::redoName(), GNEChange_Edge::redoName(), GNEChange_EdgeType::redoName(), GNEChange_GenericData::redoName(), GNEChange_Junction::redoName(), GNEChange_Lane::redoName(), GNEChange_MeanData::redoName(), GNEChange_TAZSourceSink::redoName(), redoName(), GNEChange_Additional::undo(), GNEChange_Children::undo(), GNEChange_Connection::undo(), GNEChange_Crossing::undo(), GNEChange_DataInterval::undo(), GNEChange_DataSet::undo(), GNEChange_DemandElement::undo(), GNEChange_Edge::undo(), GNEChange_EdgeType::undo(), GNEChange_GenericData::undo(), GNEChange_Junction::undo(), GNEChange_Lane::undo(), GNEChange_MeanData::undo(), GNEChange_TAZSourceSink::undo(), undo(), GNEChange_Additional::undoName(), GNEChange_Children::undoName(), GNEChange_Connection::undoName(), GNEChange_Crossing::undoName(), GNEChange_DataInterval::undoName(), GNEChange_DataSet::undoName(), GNEChange_DemandElement::undoName(), GNEChange_Edge::undoName(), GNEChange_EdgeType::undoName(), GNEChange_GenericData::undoName(), GNEChange_Junction::undoName(), GNEChange_Lane::undoName(), GNEChange_MeanData::undoName(), GNEChange_TAZSourceSink::undoName(), and undoName().

◆ myJunction

GNEJunction* GNEChange_TLS::myJunction
private

we need the junction because it is the target of our change commands

Note
we assume shared responsibilty for the junction via reference counting

Definition at line 86 of file GNEChange_TLS.h.

Referenced by GNEChange_TLS(), GNEChange_TLS(), redo(), redoName(), undo(), undoName(), and ~GNEChange_TLS().

◆ myNewID

const std::string GNEChange_TLS::myNewID
private

Definition at line 98 of file GNEChange_TLS.h.

Referenced by redo(), and undo().

◆ myOldID

const std::string GNEChange_TLS::myOldID
private

variables used for renaming TLS

Definition at line 97 of file GNEChange_TLS.h.

Referenced by redo(), and undo().

◆ myParents

const GNEHierarchicalStructureParents GNEChange::myParents
protectedinherited

◆ mySelectedElement

◆ mySupermode

const Supermode GNEChange::mySupermode
protectedinherited

supermode related with this change

Definition at line 174 of file GNEChange.h.

Referenced by GNEChange::getSupermode().

◆ myTlDef

NBTrafficLightDefinition* GNEChange_TLS::myTlDef
private

the traffic light to be created/deleted. We assume no responsibility for the pointer

Note
since it is hard to track by which NBnodes a tlDef is used (may be more than one).

Definition at line 91 of file GNEChange_TLS.h.

Referenced by GNEChange_TLS(), redo(), and undo().

◆ next


The documentation for this class was generated from the following files: