Line data Source code
1 : /****************************************************************************/
2 : // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3 : // Copyright (C) 2001-2024 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 ODDistrictHandler.cpp
15 : /// @author Daniel Krajzewicz
16 : /// @author Jakob Erdmann
17 : /// @author Michael Behrisch
18 : /// @date Sept 2002
19 : ///
20 : // An XML-Handler for districts
21 : /****************************************************************************/
22 : #include <config.h>
23 :
24 : #include <string>
25 : #include <utility>
26 : #include <iostream>
27 : #include <utils/common/UtilExceptions.h>
28 : #include <utils/common/MsgHandler.h>
29 : #include <utils/common/ToString.h>
30 : #include <utils/xml/SUMOSAXHandler.h>
31 : #include <utils/xml/SUMOXMLDefinitions.h>
32 : #include "ODDistrict.h"
33 : #include "ODDistrictCont.h"
34 : #include "ODDistrictHandler.h"
35 :
36 :
37 : // ===========================================================================
38 : // method definitions
39 : // ===========================================================================
40 142 : ODDistrictHandler::ODDistrictHandler(ODDistrictCont& cont,
41 142 : const std::string& file)
42 284 : : SUMOSAXHandler(file), myContainer(cont), myCurrentDistrict(nullptr) {}
43 :
44 :
45 142 : ODDistrictHandler::~ODDistrictHandler() {}
46 :
47 :
48 : void
49 1434 : ODDistrictHandler::myStartElement(int element,
50 : const SUMOSAXAttributes& attrs) {
51 1434 : switch (element) {
52 341 : case SUMO_TAG_TAZ:
53 341 : openDistrict(attrs);
54 341 : break;
55 331 : case SUMO_TAG_TAZSOURCE:
56 331 : addSource(attrs);
57 331 : break;
58 620 : case SUMO_TAG_TAZSINK:
59 620 : addSink(attrs);
60 620 : break;
61 : default:
62 : break;
63 : }
64 1434 : }
65 :
66 :
67 : void
68 1434 : ODDistrictHandler::myEndElement(int element) {
69 1434 : if (element == SUMO_TAG_TAZ) {
70 341 : closeDistrict();
71 : }
72 1434 : }
73 :
74 :
75 : void
76 341 : ODDistrictHandler::openDistrict(const SUMOSAXAttributes& attrs) {
77 341 : myCurrentDistrict = nullptr;
78 : // get the id, report an error if not given or empty...
79 341 : bool ok = true;
80 341 : std::string id = attrs.get<std::string>(SUMO_ATTR_ID, nullptr, ok);
81 341 : if (!ok) {
82 : return;
83 : }
84 341 : myCurrentDistrict = new ODDistrict(id);
85 341 : if (attrs.hasAttribute(SUMO_ATTR_EDGES)) {
86 2 : const std::vector<std::string>& desc = attrs.get<std::vector<std::string> >(SUMO_ATTR_EDGES, id.c_str(), ok);
87 5 : for (const std::string& eID : desc) {
88 3 : myCurrentDistrict->addSource(eID, 1.);
89 3 : myCurrentDistrict->addSink(eID, 1.);
90 : }
91 2 : }
92 : }
93 :
94 :
95 : void
96 331 : ODDistrictHandler::addSource(const SUMOSAXAttributes& attrs) {
97 331 : std::pair<std::string, double> vals = parseTAZ(attrs);
98 331 : if (vals.second >= 0) {
99 331 : myCurrentDistrict->addSource(vals.first, vals.second);
100 : }
101 331 : }
102 :
103 :
104 : void
105 620 : ODDistrictHandler::addSink(const SUMOSAXAttributes& attrs) {
106 620 : std::pair<std::string, double> vals = parseTAZ(attrs);
107 620 : if (vals.second >= 0) {
108 620 : myCurrentDistrict->addSink(vals.first, vals.second);
109 : }
110 620 : }
111 :
112 :
113 :
114 : std::pair<std::string, double>
115 951 : ODDistrictHandler::parseTAZ(const SUMOSAXAttributes& attrs) {
116 : // check the current district first
117 951 : if (myCurrentDistrict == nullptr) {
118 : return std::pair<std::string, double>("", -1);
119 : }
120 : // get the id, report an error if not given or empty...
121 951 : bool ok = true;
122 951 : std::string id = attrs.get<std::string>(SUMO_ATTR_ID, nullptr, ok);
123 951 : if (!ok) {
124 : return std::pair<std::string, double>("", -1);
125 : }
126 : // get the weight
127 951 : double weight = attrs.get<double>(SUMO_ATTR_WEIGHT, id.c_str(), ok);
128 951 : if (ok) {
129 951 : if (weight < 0) {
130 0 : WRITE_ERRORF(TL("'probability' must be positive (in definition of % '%')."), attrs.getObjectType(), id);
131 : } else {
132 : return std::pair<std::string, double>(id, weight);
133 : }
134 : }
135 : return std::pair<std::string, double>("", -1);
136 : }
137 :
138 :
139 : void
140 341 : ODDistrictHandler::closeDistrict() {
141 341 : if (myCurrentDistrict != nullptr) {
142 341 : myContainer.add(myCurrentDistrict->getID(), myCurrentDistrict);
143 : }
144 341 : }
145 :
146 :
147 : /****************************************************************************/
|