SUMO - Simulation of Urban MObility
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
RORouteHandler.h
Go to the documentation of this file.
1 /****************************************************************************/
9 // Parser and container for routes during their loading
10 /****************************************************************************/
11 // SUMO, Simulation of Urban MObility; see http://sumo-sim.org/
12 // Copyright (C) 2001-2014 DLR (http://www.dlr.de/) and contributors
13 /****************************************************************************/
14 //
15 // This file is part of SUMO.
16 // SUMO is free software: you can redistribute it and/or modify
17 // it under the terms of the GNU General Public License as published by
18 // the Free Software Foundation, either version 3 of the License, or
19 // (at your option) any later version.
20 //
21 /****************************************************************************/
22 #ifndef RORouteHandler_h
23 #define RORouteHandler_h
24 
25 
26 // ===========================================================================
27 // included modules
28 // ===========================================================================
29 #ifdef _MSC_VER
30 #include <windows_config.h>
31 #else
32 #include <config.h>
33 #endif
34 
35 #include <string>
36 #include <vector>
38 #include <utils/common/SUMOTime.h>
41 
42 
43 // ===========================================================================
44 // class declarations
45 // ===========================================================================
47 class ROEdge;
48 class ROLane;
49 class RONet;
50 class RORoute;
51 class RORouteDef;
52 
53 
54 // ===========================================================================
55 // class definitions
56 // ===========================================================================
66 public:
68  RORouteHandler(RONet& net, const std::string& file,
69  const bool tryRepair,
70  const bool emptyDestinationsAllowed,
71  const bool ignoreErrors);
72 
74  virtual ~RORouteHandler();
75 
76 protected:
78 
79 
87  virtual void myStartElement(int element,
88  const SUMOSAXAttributes& attrs);
89 
90 
97  virtual void myEndElement(int element);
99 
100 
107  void parseFromViaTo(std::string element,
108  const SUMOSAXAttributes& attrs);
109 
110 
113 
116 
118  void openRoute(const SUMOSAXAttributes& attrs);
119 
125  void closeRoute(const bool mayBeDisconnected = false);
126 
128  void openRouteDistribution(const SUMOSAXAttributes& attrs);
129 
131  void closeRouteDistribution();
132 
134  void closeVehicle();
135 
137  void closePerson();
138 
140  void closeFlow();
141 
143  void addStop(const SUMOSAXAttributes& attrs);
144 
146  void parseEdges(const std::string& desc, std::vector<const ROEdge*>& into,
147  const std::string& rid);
148 
150  bool routePedestrian(const SUMOSAXAttributes& attrs, OutputDevice& plan);
151 
152 protected:
156 
159 
161  std::vector<const ROEdge*> myActiveRoute;
162 
165 
168 
170  const bool myTryRepair;
171 
174 
177 
180 
183 
186 
189 
190 private:
192  RORouteHandler(const RORouteHandler& s);
193 
196 
197 };
198 
199 
200 #endif
201 
202 /****************************************************************************/
203 
RORouteDef * myCurrentAlternatives
The currently parsed route alternatives.
const bool myEmptyDestinationsAllowed
Information whether the "to" attribute is mandatory.
void closeVehicleTypeDistribution()
SUMOReal myCurrentCosts
The currently parsed route costs.
A single lane the router may use.
Definition: ROLane.h:52
std::vector< const ROEdge * > myActiveRoute
The current route.
void closePerson()
Ends the processing of a person.
void openRouteDistribution(const SUMOSAXAttributes &attrs)
ROPedestrianRouterDijkstra * myPedestrianRouter
virtual void myStartElement(int element, const SUMOSAXAttributes &attrs)
Called on the opening of a tag;.
MsgHandler *const myErrorOutput
Depending on the "ignore-errors" option different outputs are used.
virtual void myEndElement(int element)
Called when a closing tag occurs.
void openVehicleTypeDistribution(const SUMOSAXAttributes &attrs)
void closeVehicle()
Ends the processing of a vehicle.
RandomDistributor< SUMOVTypeParameter * > * myCurrentVTypeDistribution
The currently parsed distribution of vehicle types (probability->vehicle type)
RORouteHandler(RONet &net, const std::string &file, const bool tryRepair, const bool emptyDestinationsAllowed, const bool ignoreErrors)
standard constructor
RONet & myNet
The current route.
Encapsulated SAX-Attributes.
void addStop(const SUMOSAXAttributes &attrs)
Processing of a stop.
int myActivePlanSize
The number of stages in myActivePlan.
RORouteHandler & operator=(const RORouteHandler &s)
Invalidated assignment operator.
PedestrianRouterDijkstra< ROEdge, ROLane, RONode > ROPedestrianRouterDijkstra
the router for pedestrians
A basic edge for routing applications.
Definition: ROEdge.h:69
void parseEdges(const std::string &desc, std::vector< const ROEdge * > &into, const std::string &rid)
Parse edges from strings.
Parser for routes during their loading.
The router's network representation.
Definition: RONet.h:67
void openRoute(const SUMOSAXAttributes &attrs)
const bool myTryRepair
Information whether routes shall be repaired.
Parser and container for routes during their loading.
Base class for a vehicle's route definition.
Definition: RORouteDef.h:64
void closeRoute(const bool mayBeDisconnected=false)
OutputDevice_String * myActivePlan
The plan of the current person.
virtual ~RORouteHandler()
standard destructor
Static storage of an output device and its base (abstract) implementation.
Definition: OutputDevice.h:71
#define SUMOReal
Definition: config.h:215
bool routePedestrian(const SUMOSAXAttributes &attrs, OutputDevice &plan)
route a walking person and write the corresponding walk element (return whether sucessful) ...
void closeFlow()
Ends the processing of a flow.
void parseFromViaTo(std::string element, const SUMOSAXAttributes &attrs)
Called for parsing from and to and the corresponding taz attributes.
A complete router's route.
Definition: RORoute.h:61
An output device that encapsulates an ofstream.
void closeRouteDistribution()
std::string myCurrentVTypeDistributionID
The id of the currently parsed vehicle type distribution.