LCOV - code coverage report
Current view: top level - src/dfrouter - RODFDetectorHandler.cpp (source / functions) Hit Total Coverage
Test: lcov.info Lines: 31 34 91.2 %
Date: 2024-09-16 15:39:55 Functions: 3 4 75.0 %

          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    RODFDetectorHandler.cpp
      15             : /// @author  Daniel Krajzewicz
      16             : /// @author  Eric Nicolay
      17             : /// @author  Jakob Erdmann
      18             : /// @author  Michael Behrisch
      19             : /// @date    Thu, 16.03.2006
      20             : ///
      21             : // A handler for loading detector descriptions
      22             : /****************************************************************************/
      23             : #include <config.h>
      24             : 
      25             : #include <string>
      26             : #include <utils/options/OptionsCont.h>
      27             : #include <utils/common/MsgHandler.h>
      28             : #include <utils/common/StringTokenizer.h>
      29             : #include <utils/common/UtilExceptions.h>
      30             : #include <utils/common/StringUtils.h>
      31             : #include <utils/common/ToString.h>
      32             : #include <utils/xml/SUMOSAXHandler.h>
      33             : #include <utils/xml/SUMOXMLDefinitions.h>
      34             : #include "RODFDetectorHandler.h"
      35             : #include "RODFNet.h"
      36             : 
      37             : 
      38             : // ===========================================================================
      39             : // method definitions
      40             : // ===========================================================================
      41         239 : RODFDetectorHandler::RODFDetectorHandler(RODFNet* optNet, bool ignoreErrors, RODFDetectorCon& con,
      42         239 :         const std::string& file)
      43             :     : SUMOSAXHandler(file),
      44         478 :       myNet(optNet), myIgnoreErrors(ignoreErrors), myContainer(con) {}
      45             : 
      46             : 
      47         239 : RODFDetectorHandler::~RODFDetectorHandler() {}
      48             : 
      49             : 
      50             : void
      51        1997 : RODFDetectorHandler::myStartElement(int element,
      52             :                                     const SUMOSAXAttributes& attrs) {
      53        1997 :     if (element == SUMO_TAG_DETECTOR_DEFINITION || element == SUMO_TAG_E1DETECTOR || element == SUMO_TAG_INDUCTION_LOOP) {
      54             :         try {
      55        1759 :             bool ok = true;
      56             :             // get the id, report an error if not given or empty...
      57        1759 :             std::string id = attrs.get<std::string>(SUMO_ATTR_ID, nullptr, ok);
      58        1759 :             if (!ok) {
      59           0 :                 throw ProcessError();
      60             :             }
      61        1759 :             std::string lane = attrs.get<std::string>(SUMO_ATTR_LANE, id.c_str(), ok);
      62        1759 :             if (!ok) {
      63           4 :                 throw ProcessError();
      64             :             }
      65        5382 :             ROEdge* edge = myNet->getEdge(SUMOXMLDefinitions::getEdgeIDFromLane(lane));
      66        1755 :             int laneIndex = SUMOXMLDefinitions::getIndexFromLane(lane);
      67        1755 :             if (edge == nullptr || laneIndex >= edge->getNumLanes()) {
      68           6 :                 throw ProcessError("Unknown lane '" + lane + "' for detector '" + id + "' in '" + getFileName() + "'.");
      69             :             }
      70        1752 :             double pos = attrs.get<double>(SUMO_ATTR_POSITION, id.c_str(), ok);
      71        1765 :             std::string mml_type = attrs.getOpt<std::string>(SUMO_ATTR_TYPE, id.c_str(), ok, "");
      72        1752 :             if (!ok) {
      73           6 :                 throw ProcessError();
      74             :             }
      75             :             RODFDetectorType type = TYPE_NOT_DEFINED;
      76        1746 :             if (mml_type == "between") {
      77             :                 type = BETWEEN_DETECTOR;
      78        3317 :             } else if (mml_type == "source" || mml_type == "highway_source") { // !!! highway-source is legacy (removed accoring output on 06.08.2007)
      79             :                 type = SOURCE_DETECTOR;
      80        1636 :             } else if (mml_type == "sink") {
      81             :                 type = SINK_DETECTOR;
      82             :             }
      83        1746 :             RODFDetector* detector = new RODFDetector(id, lane, pos, type);
      84        1746 :             if (!myContainer.addDetector(detector)) {
      85           0 :                 delete detector;
      86           0 :                 throw ProcessError(TLF("Could not add detector '%' (probably the id is already used).", id));
      87             :             }
      88          13 :         } catch (ProcessError& e) {
      89          13 :             if (myIgnoreErrors) {
      90           1 :                 WRITE_WARNING(e.what());
      91             :             } else {
      92          24 :                 throw e;
      93             :             }
      94          13 :         }
      95             :     }
      96        1985 : }
      97             : 
      98             : 
      99             : /****************************************************************************/

Generated by: LCOV version 1.14