LCOV - code coverage report
Current view: top level - src/netimport/vissim/tempstructs - NIVissimDisturbance.h (source / functions) Coverage Total Hit
Test: lcov.info Lines: 100.0 % 2 2
Test Date: 2024-11-22 15:46:21 Functions: - 0 0

            Line data    Source code
       1              : /****************************************************************************/
       2              : // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
       3              : // Copyright (C) 2002-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    NIVissimDisturbance.h
      15              : /// @author  Daniel Krajzewicz
      16              : /// @author  Michael Behrisch
      17              : /// @date    Sept 2002
      18              : ///
      19              : // -------------------
      20              : /****************************************************************************/
      21              : #pragma once
      22              : #include <config.h>
      23              : 
      24              : #include <map>
      25              : #include <string>
      26              : #include <utils/geom/AbstractPoly.h>
      27              : #include <netbuild/NBConnection.h>
      28              : #include "NIVissimExtendedEdgePoint.h"
      29              : #include "NIVissimBoundedClusterObject.h"
      30              : #include "NIVissimNodeParticipatingEdgeVector.h"
      31              : 
      32              : 
      33              : // ===========================================================================
      34              : // class declarations
      35              : // ===========================================================================
      36              : class NBNode;
      37              : class NBEdge;
      38              : class NBDistrictCont;
      39              : 
      40              : class NIVissimDisturbance
      41              :     : public NIVissimBoundedClusterObject {
      42              : public:
      43              :     NIVissimDisturbance(int id, const std::string& name,
      44              :                         const NIVissimExtendedEdgePoint& edge,
      45              :                         const NIVissimExtendedEdgePoint& by);
      46              :     virtual ~NIVissimDisturbance();
      47              :     void computeBounding();
      48              :     bool addToNode(NBNode* node, NBDistrictCont& dc,
      49              :                    NBNodeCont& nc, NBEdgeCont& ec);
      50              :     int getEdgeID() const {
      51         4018 :         return myEdge.getEdgeID();
      52              :     }
      53              :     int getDisturbanceID() const {
      54         4018 :         return myDisturbance.getEdgeID();
      55              :     }
      56              :     NBConnection getConnection(NBNode* node, int aedgeid);
      57              : 
      58              : public:
      59              :     static bool dictionary(const std::string& name,
      60              :                            const NIVissimExtendedEdgePoint& edge,
      61              :                            const NIVissimExtendedEdgePoint& by);
      62              :     static bool dictionary(int id, NIVissimDisturbance* o);
      63              :     static NIVissimDisturbance* dictionary(int id);
      64              :     static std::vector<int> getWithin(const AbstractPoly& poly);
      65              :     static void clearDict();
      66              :     static void dict_SetDisturbances();
      67              :     static void reportRefused();
      68              : 
      69              : private:
      70              :     int myID;
      71              :     int myNode;
      72              :     std::string myName;
      73              :     NIVissimExtendedEdgePoint myEdge;
      74              :     NIVissimExtendedEdgePoint myDisturbance;
      75              : 
      76              :     typedef std::map<int, NIVissimDisturbance*> DictType;
      77              :     static DictType myDict;
      78              :     static int myRunningID;
      79              :     static int refusedProhibits;
      80              : };
        

Generated by: LCOV version 2.0-1