LCOV - code coverage report
Current view: top level - src/netimport/vissim/typeloader - NIVissimSingleTypeParser_Zeitenverteilungsdefinition.cpp (source / functions) Hit Total Coverage
Test: lcov.info Lines: 12 19 63.2 %
Date: 2024-05-01 15:34:42 Functions: 4 4 100.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    NIVissimSingleTypeParser_Zeitenverteilungsdefinition.cpp
      15             : /// @author  Daniel Krajzewicz
      16             : /// @author  Michael Behrisch
      17             : /// @date    Wed, 18 Dec 2002
      18             : ///
      19             : //
      20             : /****************************************************************************/
      21             : #include <config.h>
      22             : 
      23             : #include <iostream>
      24             : #include <utils/geom/Position.h>
      25             : #include <utils/geom/PositionVector.h>
      26             : #include <utils/common/StringUtils.h>
      27             : #include <netimport/vissim/NIImporter_Vissim.h>
      28             : #include <utils/distribution/Distribution_Parameterized.h>
      29             : #include <utils/distribution/Distribution_Points.h>
      30             : #include <utils/distribution/DistributionCont.h>
      31             : #include "NIVissimSingleTypeParser_Zeitenverteilungsdefinition.h"
      32             : 
      33             : 
      34             : // ===========================================================================
      35             : // method definitions
      36             : // ===========================================================================
      37           9 : NIVissimSingleTypeParser_Zeitenverteilungsdefinition::NIVissimSingleTypeParser_Zeitenverteilungsdefinition(NIImporter_Vissim& parent)
      38           9 :     : NIImporter_Vissim::VissimSingleTypeParser(parent) {}
      39             : 
      40             : 
      41          18 : NIVissimSingleTypeParser_Zeitenverteilungsdefinition::~NIVissimSingleTypeParser_Zeitenverteilungsdefinition() {}
      42             : 
      43             : 
      44             : bool
      45           7 : NIVissimSingleTypeParser_Zeitenverteilungsdefinition::parse(std::istream& from) {
      46             :     // id
      47             :     std::string id;
      48           7 :     from >> id;
      49             :     // list of points
      50           7 :     Distribution_Points* points = new Distribution_Points(id);
      51             :     std::string tag;
      52             :     do {
      53          14 :         tag = readEndSecure(from);
      54           7 :         if (tag == "mittelwert") {
      55             :             double mean, deviation;
      56             :             from >> mean;
      57           7 :             from >> tag;
      58             :             from >> deviation;
      59           7 :             delete points;
      60          14 :             return DistributionCont::dictionary("times", id,
      61           7 :                                                 new Distribution_Parameterized(id, mean, deviation));
      62             :         }
      63           0 :         if (tag != "DATAEND") {
      64           0 :             double p1 = StringUtils::toDouble(tag);
      65           0 :             from >> tag;
      66           0 :             double p2 = StringUtils::toDouble(tag);
      67           0 :             points->add(p1, p2);
      68             :         }
      69           0 :     } while (tag != "DATAEND");
      70           0 :     return DistributionCont::dictionary("times", id, points);
      71             : }
      72             : 
      73             : 
      74             : /****************************************************************************/

Generated by: LCOV version 1.14